1*8d67ca89SAndroid Build Coastguard Worker /* 2*8d67ca89SAndroid Build Coastguard Worker * Copyright (C) 2008 The Android Open Source Project 3*8d67ca89SAndroid Build Coastguard Worker * All rights reserved. 4*8d67ca89SAndroid Build Coastguard Worker * 5*8d67ca89SAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without 6*8d67ca89SAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions 7*8d67ca89SAndroid Build Coastguard Worker * are met: 8*8d67ca89SAndroid Build Coastguard Worker * * Redistributions of source code must retain the above copyright 9*8d67ca89SAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer. 10*8d67ca89SAndroid Build Coastguard Worker * * Redistributions in binary form must reproduce the above copyright 11*8d67ca89SAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in 12*8d67ca89SAndroid Build Coastguard Worker * the documentation and/or other materials provided with the 13*8d67ca89SAndroid Build Coastguard Worker * distribution. 14*8d67ca89SAndroid Build Coastguard Worker * 15*8d67ca89SAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 16*8d67ca89SAndroid Build Coastguard Worker * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 17*8d67ca89SAndroid Build Coastguard Worker * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 18*8d67ca89SAndroid Build Coastguard Worker * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 19*8d67ca89SAndroid Build Coastguard Worker * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 20*8d67ca89SAndroid Build Coastguard Worker * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 21*8d67ca89SAndroid Build Coastguard Worker * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 22*8d67ca89SAndroid Build Coastguard Worker * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 23*8d67ca89SAndroid Build Coastguard Worker * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 24*8d67ca89SAndroid Build Coastguard Worker * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 25*8d67ca89SAndroid Build Coastguard Worker * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26*8d67ca89SAndroid Build Coastguard Worker * SUCH DAMAGE. 27*8d67ca89SAndroid Build Coastguard Worker */ 28*8d67ca89SAndroid Build Coastguard Worker 29*8d67ca89SAndroid Build Coastguard Worker #pragma once 30*8d67ca89SAndroid Build Coastguard Worker 31*8d67ca89SAndroid Build Coastguard Worker /** 32*8d67ca89SAndroid Build Coastguard Worker * @defgroup apilevels API Levels 33*8d67ca89SAndroid Build Coastguard Worker * 34*8d67ca89SAndroid Build Coastguard Worker * Defines functions and constants for working with Android API levels. 35*8d67ca89SAndroid Build Coastguard Worker * @{ 36*8d67ca89SAndroid Build Coastguard Worker */ 37*8d67ca89SAndroid Build Coastguard Worker 38*8d67ca89SAndroid Build Coastguard Worker /** 39*8d67ca89SAndroid Build Coastguard Worker * @file android/api-level.h 40*8d67ca89SAndroid Build Coastguard Worker * @brief Functions and constants for dealing with multiple API levels. 41*8d67ca89SAndroid Build Coastguard Worker * 42*8d67ca89SAndroid Build Coastguard Worker * See 43*8d67ca89SAndroid Build Coastguard Worker * https://android.googlesource.com/platform/bionic/+/main/docs/defines.md. 44*8d67ca89SAndroid Build Coastguard Worker */ 45*8d67ca89SAndroid Build Coastguard Worker 46*8d67ca89SAndroid Build Coastguard Worker #include <sys/cdefs.h> 47*8d67ca89SAndroid Build Coastguard Worker 48*8d67ca89SAndroid Build Coastguard Worker __BEGIN_DECLS 49*8d67ca89SAndroid Build Coastguard Worker 50*8d67ca89SAndroid Build Coastguard Worker /** 51*8d67ca89SAndroid Build Coastguard Worker * Magic version number for an Android OS build which has not yet turned 52*8d67ca89SAndroid Build Coastguard Worker * into an official release, for comparison against `__ANDROID_API__`. See 53*8d67ca89SAndroid Build Coastguard Worker * https://android.googlesource.com/platform/bionic/+/main/docs/defines.md. 54*8d67ca89SAndroid Build Coastguard Worker */ 55*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_FUTURE__ 10000 56*8d67ca89SAndroid Build Coastguard Worker 57*8d67ca89SAndroid Build Coastguard Worker /* This #ifndef should never be true except when doxygen is generating docs. */ 58*8d67ca89SAndroid Build Coastguard Worker #ifndef __ANDROID_API__ 59*8d67ca89SAndroid Build Coastguard Worker /** 60*8d67ca89SAndroid Build Coastguard Worker * `__ANDROID_API__` is the [API 61*8d67ca89SAndroid Build Coastguard Worker * level](https://developer.android.com/guide/topics/manifest/uses-sdk-element#ApiLevels) 62*8d67ca89SAndroid Build Coastguard Worker * this code is being built for. The resulting binaries are only guaranteed to 63*8d67ca89SAndroid Build Coastguard Worker * be compatible with devices which have an API level greater than or equal to 64*8d67ca89SAndroid Build Coastguard Worker * `__ANDROID_API__`. 65*8d67ca89SAndroid Build Coastguard Worker * 66*8d67ca89SAndroid Build Coastguard Worker * For NDK and APEX builds, this macro will always be defined. It is set 67*8d67ca89SAndroid Build Coastguard Worker * automatically by Clang using the version suffix that is a part of the target 68*8d67ca89SAndroid Build Coastguard Worker * name. For example, `__ANDROID_API__` will be 24 when Clang is given the 69*8d67ca89SAndroid Build Coastguard Worker * argument `-target aarch64-linux-android24`. 70*8d67ca89SAndroid Build Coastguard Worker * 71*8d67ca89SAndroid Build Coastguard Worker * For non-APEX OS code, this defaults to __ANDROID_API_FUTURE__. 72*8d67ca89SAndroid Build Coastguard Worker * 73*8d67ca89SAndroid Build Coastguard Worker * The value of `__ANDROID_API__` can be compared to the named constants in 74*8d67ca89SAndroid Build Coastguard Worker * `<android/api-level.h>`. 75*8d67ca89SAndroid Build Coastguard Worker * 76*8d67ca89SAndroid Build Coastguard Worker * The interpretation of `__ANDROID_API__` is similar to the AndroidManifest.xml 77*8d67ca89SAndroid Build Coastguard Worker * `minSdkVersion`. In most cases `__ANDROID_API__` will be identical to 78*8d67ca89SAndroid Build Coastguard Worker * `minSdkVersion`, but as it is a build time constant it is possible for 79*8d67ca89SAndroid Build Coastguard Worker * library code to use a different value than the app it will be included in. 80*8d67ca89SAndroid Build Coastguard Worker * When libraries and applications build for different API levels, the 81*8d67ca89SAndroid Build Coastguard Worker * `minSdkVersion` of the application must be at least as high as the highest 82*8d67ca89SAndroid Build Coastguard Worker * API level used by any of its libraries which are loaded unconditionally. 83*8d67ca89SAndroid Build Coastguard Worker * 84*8d67ca89SAndroid Build Coastguard Worker * Note that in some cases the resulting binaries may load successfully on 85*8d67ca89SAndroid Build Coastguard Worker * devices with an older API level. That behavior should not be relied upon, 86*8d67ca89SAndroid Build Coastguard Worker * even if you are careful to avoid using new APIs, as the toolchain may make 87*8d67ca89SAndroid Build Coastguard Worker * use of new features by default. For example, additional FORTIFY features may 88*8d67ca89SAndroid Build Coastguard Worker * implicitly make use of new APIs, SysV hashes may be omitted in favor of GNU 89*8d67ca89SAndroid Build Coastguard Worker * hashes to improve library load times, or relocation packing may be enabled to 90*8d67ca89SAndroid Build Coastguard Worker * reduce binary size. 91*8d67ca89SAndroid Build Coastguard Worker * 92*8d67ca89SAndroid Build Coastguard Worker * See android_get_device_api_level(), 93*8d67ca89SAndroid Build Coastguard Worker * android_get_application_target_sdk_version() and 94*8d67ca89SAndroid Build Coastguard Worker * https://android.googlesource.com/platform/bionic/+/main/docs/defines.md. 95*8d67ca89SAndroid Build Coastguard Worker */ 96*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API__ __ANDROID_API_FUTURE__ 97*8d67ca89SAndroid Build Coastguard Worker #endif 98*8d67ca89SAndroid Build Coastguard Worker 99*8d67ca89SAndroid Build Coastguard Worker /** Names the Gingerbread API level (9), for comparison against `__ANDROID_API__`. */ 100*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_G__ 9 101*8d67ca89SAndroid Build Coastguard Worker 102*8d67ca89SAndroid Build Coastguard Worker /** Names the Ice-Cream Sandwich API level (14), for comparison against `__ANDROID_API__`. */ 103*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_I__ 14 104*8d67ca89SAndroid Build Coastguard Worker 105*8d67ca89SAndroid Build Coastguard Worker /** Names the Jellybean API level (16), for comparison against `__ANDROID_API__`. */ 106*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_J__ 16 107*8d67ca89SAndroid Build Coastguard Worker 108*8d67ca89SAndroid Build Coastguard Worker /** Names the Jellybean MR1 API level (17), for comparison against `__ANDROID_API__`. */ 109*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_J_MR1__ 17 110*8d67ca89SAndroid Build Coastguard Worker 111*8d67ca89SAndroid Build Coastguard Worker /** Names the Jellybean MR2 API level (18), for comparison against `__ANDROID_API__`. */ 112*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_J_MR2__ 18 113*8d67ca89SAndroid Build Coastguard Worker 114*8d67ca89SAndroid Build Coastguard Worker /** Names the KitKat API level (19), for comparison against `__ANDROID_API__`. */ 115*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_K__ 19 116*8d67ca89SAndroid Build Coastguard Worker 117*8d67ca89SAndroid Build Coastguard Worker /** Names the Lollipop API level (21), for comparison against `__ANDROID_API__`. */ 118*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_L__ 21 119*8d67ca89SAndroid Build Coastguard Worker 120*8d67ca89SAndroid Build Coastguard Worker /** Names the Lollipop MR1 API level (22), for comparison against `__ANDROID_API__`. */ 121*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_L_MR1__ 22 122*8d67ca89SAndroid Build Coastguard Worker 123*8d67ca89SAndroid Build Coastguard Worker /** Names the Marshmallow API level (23), for comparison against `__ANDROID_API__`. */ 124*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_M__ 23 125*8d67ca89SAndroid Build Coastguard Worker 126*8d67ca89SAndroid Build Coastguard Worker /** Names the Nougat API level (24), for comparison against `__ANDROID_API__`. */ 127*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_N__ 24 128*8d67ca89SAndroid Build Coastguard Worker 129*8d67ca89SAndroid Build Coastguard Worker /** Names the Nougat MR1 API level (25), for comparison against `__ANDROID_API__`. */ 130*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_N_MR1__ 25 131*8d67ca89SAndroid Build Coastguard Worker 132*8d67ca89SAndroid Build Coastguard Worker /** Names the Oreo API level (26), for comparison against `__ANDROID_API__`. */ 133*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_O__ 26 134*8d67ca89SAndroid Build Coastguard Worker 135*8d67ca89SAndroid Build Coastguard Worker /** Names the Oreo MR1 API level (27), for comparison against `__ANDROID_API__`. */ 136*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_O_MR1__ 27 137*8d67ca89SAndroid Build Coastguard Worker 138*8d67ca89SAndroid Build Coastguard Worker /** Names the Pie API level (28), for comparison against `__ANDROID_API__`. */ 139*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_P__ 28 140*8d67ca89SAndroid Build Coastguard Worker 141*8d67ca89SAndroid Build Coastguard Worker /** 142*8d67ca89SAndroid Build Coastguard Worker * Names the Android 10 (aka "Q" or "Quince Tart") API level (29), for 143*8d67ca89SAndroid Build Coastguard Worker * comparison against `__ANDROID_API__`. 144*8d67ca89SAndroid Build Coastguard Worker */ 145*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_Q__ 29 146*8d67ca89SAndroid Build Coastguard Worker 147*8d67ca89SAndroid Build Coastguard Worker /** 148*8d67ca89SAndroid Build Coastguard Worker * Names the Android 11 (aka "R" or "Red Velvet Cake") API level (30), for 149*8d67ca89SAndroid Build Coastguard Worker * comparison against `__ANDROID_API__`. 150*8d67ca89SAndroid Build Coastguard Worker */ 151*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_R__ 30 152*8d67ca89SAndroid Build Coastguard Worker 153*8d67ca89SAndroid Build Coastguard Worker /** 154*8d67ca89SAndroid Build Coastguard Worker * Names the Android 12 (aka "S" or "Snowcone") API level (31), for 155*8d67ca89SAndroid Build Coastguard Worker * comparison against `__ANDROID_API__`. 156*8d67ca89SAndroid Build Coastguard Worker */ 157*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_S__ 31 158*8d67ca89SAndroid Build Coastguard Worker 159*8d67ca89SAndroid Build Coastguard Worker /** 160*8d67ca89SAndroid Build Coastguard Worker * Names the Android 13 (aka "T" or "Tiramisu") API level (33), for 161*8d67ca89SAndroid Build Coastguard Worker * comparison against `__ANDROID_API__`. 162*8d67ca89SAndroid Build Coastguard Worker */ 163*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_T__ 33 164*8d67ca89SAndroid Build Coastguard Worker 165*8d67ca89SAndroid Build Coastguard Worker /** 166*8d67ca89SAndroid Build Coastguard Worker * Names the Android 14 (aka "U" or "UpsideDownCake") API level (34), 167*8d67ca89SAndroid Build Coastguard Worker * for comparison against `__ANDROID_API__`. 168*8d67ca89SAndroid Build Coastguard Worker */ 169*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_U__ 34 170*8d67ca89SAndroid Build Coastguard Worker 171*8d67ca89SAndroid Build Coastguard Worker /** 172*8d67ca89SAndroid Build Coastguard Worker * Names the Android 15 (aka "V" or "VanillaIceCream") API level (35), 173*8d67ca89SAndroid Build Coastguard Worker * for comparison against `__ANDROID_API__`. 174*8d67ca89SAndroid Build Coastguard Worker */ 175*8d67ca89SAndroid Build Coastguard Worker #define __ANDROID_API_V__ 35 176*8d67ca89SAndroid Build Coastguard Worker 177*8d67ca89SAndroid Build Coastguard Worker /* This file is included in <features.h>, and might be used from .S files. */ 178*8d67ca89SAndroid Build Coastguard Worker #if !defined(__ASSEMBLY__) 179*8d67ca89SAndroid Build Coastguard Worker 180*8d67ca89SAndroid Build Coastguard Worker /** 181*8d67ca89SAndroid Build Coastguard Worker * Returns the `targetSdkVersion` of the caller, or `__ANDROID_API_FUTURE__` if 182*8d67ca89SAndroid Build Coastguard Worker * there is no known target SDK version (for code not running in the context of 183*8d67ca89SAndroid Build Coastguard Worker * an app). 184*8d67ca89SAndroid Build Coastguard Worker * 185*8d67ca89SAndroid Build Coastguard Worker * The returned values correspond to the named constants in `<android/api-level.h>`, 186*8d67ca89SAndroid Build Coastguard Worker * and is equivalent to the AndroidManifest.xml `targetSdkVersion`. 187*8d67ca89SAndroid Build Coastguard Worker * 188*8d67ca89SAndroid Build Coastguard Worker * See also android_get_device_api_level(). 189*8d67ca89SAndroid Build Coastguard Worker * 190*8d67ca89SAndroid Build Coastguard Worker * Available since API level 24. 191*8d67ca89SAndroid Build Coastguard Worker */ 192*8d67ca89SAndroid Build Coastguard Worker 193*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(24) 194*8d67ca89SAndroid Build Coastguard Worker int android_get_application_target_sdk_version() __INTRODUCED_IN(24); 195*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(24) */ 196*8d67ca89SAndroid Build Coastguard Worker 197*8d67ca89SAndroid Build Coastguard Worker 198*8d67ca89SAndroid Build Coastguard Worker #if __ANDROID_API__ < 29 199*8d67ca89SAndroid Build Coastguard Worker 200*8d67ca89SAndroid Build Coastguard Worker /* android_get_device_api_level is a static inline before API level 29. */ 201*8d67ca89SAndroid Build Coastguard Worker #define __BIONIC_GET_DEVICE_API_LEVEL_INLINE static __inline 202*8d67ca89SAndroid Build Coastguard Worker #include <bits/get_device_api_level_inlines.h> 203*8d67ca89SAndroid Build Coastguard Worker #undef __BIONIC_GET_DEVICE_API_LEVEL_INLINE 204*8d67ca89SAndroid Build Coastguard Worker 205*8d67ca89SAndroid Build Coastguard Worker #else 206*8d67ca89SAndroid Build Coastguard Worker 207*8d67ca89SAndroid Build Coastguard Worker /** 208*8d67ca89SAndroid Build Coastguard Worker * Returns the API level of the device we're actually running on, or -1 on failure. 209*8d67ca89SAndroid Build Coastguard Worker * The returned values correspond to the named constants in `<android/api-level.h>`, 210*8d67ca89SAndroid Build Coastguard Worker * and is equivalent to the Java `Build.VERSION.SDK_INT` API. 211*8d67ca89SAndroid Build Coastguard Worker * 212*8d67ca89SAndroid Build Coastguard Worker * See also android_get_application_target_sdk_version(). 213*8d67ca89SAndroid Build Coastguard Worker */ 214*8d67ca89SAndroid Build Coastguard Worker int android_get_device_api_level() __INTRODUCED_IN(29); 215*8d67ca89SAndroid Build Coastguard Worker 216*8d67ca89SAndroid Build Coastguard Worker #endif 217*8d67ca89SAndroid Build Coastguard Worker 218*8d67ca89SAndroid Build Coastguard Worker #endif /* defined(__ASSEMBLY__) */ 219*8d67ca89SAndroid Build Coastguard Worker 220*8d67ca89SAndroid Build Coastguard Worker __END_DECLS 221*8d67ca89SAndroid Build Coastguard Worker 222*8d67ca89SAndroid Build Coastguard Worker /** @} */ 223