blob: 2a4f7df0c9751d34fa4386e3ab7cfc84fb61a6e7 [file] [log] [blame]
David 'Digit' Turner23d24392010-12-06 12:05:11 +01001/*
2 * Copyright (C) 2008 The Android Open Source Project
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in
12 * the documentation and/or other materials provided with the
13 * distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 */
Elliott Hughes4aa2e6a2014-05-07 12:37:44 -070028
Elliott Hughesce934e32018-09-06 13:26:08 -070029#pragma once
30
31/**
Dan Albertd8f46912020-08-07 13:54:49 -070032 * @defgroup apilevels API Levels
33 *
Elliott Hughese9a34c52025-02-18 10:53:18 -080034 * Defines functions for working with Android API levels.
Dan Albertd8f46912020-08-07 13:54:49 -070035 * @{
36 */
37
38/**
Elliott Hughesce934e32018-09-06 13:26:08 -070039 * @file android/api-level.h
Elliott Hughese9a34c52025-02-18 10:53:18 -080040 * @brief Functions for dealing with multiple API levels.
Elliott Hughes80e9f652019-10-14 12:19:29 -070041 *
Elliott Hughes273080f2025-03-07 05:25:39 -080042 * See also
43 * https://developer.android.com/ndk/guides/using-newer-apis
44 * for more tutorial information on dealing with multiple API levels.
45 *
46 * See also
47 * https://android.googlesource.com/platform/bionic/+/main/docs/defines.md
48 * for when to use which `#define` when writing portable code.
Elliott Hughesce934e32018-09-06 13:26:08 -070049 */
David 'Digit' Turner23d24392010-12-06 12:05:11 +010050
Elliott Hughes203e13d2016-07-22 14:56:18 -070051#include <sys/cdefs.h>
52
Elliott Hughesc0f46562018-11-09 15:38:52 -080053__BEGIN_DECLS
54
Elliott Hughesce934e32018-09-06 13:26:08 -070055/**
Elliott Hughes80e9f652019-10-14 12:19:29 -070056 * Magic version number for an Android OS build which has not yet turned
57 * into an official release, for comparison against `__ANDROID_API__`. See
Elliott Hughes9c06d162023-10-04 23:36:14 +000058 * https://android.googlesource.com/platform/bionic/+/main/docs/defines.md.
Elliott Hughesce934e32018-09-06 13:26:08 -070059 */
Dan Albert495ec922016-09-21 01:08:44 -070060#define __ANDROID_API_FUTURE__ 10000
Dan Albert495ec922016-09-21 01:08:44 -070061
Elliott Hughes9823c922019-10-07 20:51:00 +000062/* This #ifndef should never be true except when doxygen is generating docs. */
Josh Gao99739d42016-04-13 17:16:47 -070063#ifndef __ANDROID_API__
Elliott Hughesce934e32018-09-06 13:26:08 -070064/**
Dan Albertd8f46912020-08-07 13:54:49 -070065 * `__ANDROID_API__` is the [API
66 * level](https://developer.android.com/guide/topics/manifest/uses-sdk-element#ApiLevels)
67 * this code is being built for. The resulting binaries are only guaranteed to
68 * be compatible with devices which have an API level greater than or equal to
69 * `__ANDROID_API__`.
70 *
71 * For NDK and APEX builds, this macro will always be defined. It is set
72 * automatically by Clang using the version suffix that is a part of the target
73 * name. For example, `__ANDROID_API__` will be 24 when Clang is given the
74 * argument `-target aarch64-linux-android24`.
75 *
76 * For non-APEX OS code, this defaults to __ANDROID_API_FUTURE__.
77 *
78 * The value of `__ANDROID_API__` can be compared to the named constants in
79 * `<android/api-level.h>`.
80 *
81 * The interpretation of `__ANDROID_API__` is similar to the AndroidManifest.xml
82 * `minSdkVersion`. In most cases `__ANDROID_API__` will be identical to
83 * `minSdkVersion`, but as it is a build time constant it is possible for
84 * library code to use a different value than the app it will be included in.
85 * When libraries and applications build for different API levels, the
86 * `minSdkVersion` of the application must be at least as high as the highest
87 * API level used by any of its libraries which are loaded unconditionally.
88 *
89 * Note that in some cases the resulting binaries may load successfully on
90 * devices with an older API level. That behavior should not be relied upon,
91 * even if you are careful to avoid using new APIs, as the toolchain may make
92 * use of new features by default. For example, additional FORTIFY features may
93 * implicitly make use of new APIs, SysV hashes may be omitted in favor of GNU
94 * hashes to improve library load times, or relocation packing may be enabled to
95 * reduce binary size.
96 *
97 * See android_get_device_api_level(),
98 * android_get_application_target_sdk_version() and
Elliott Hughes9c06d162023-10-04 23:36:14 +000099 * https://android.googlesource.com/platform/bionic/+/main/docs/defines.md.
Elliott Hughesce934e32018-09-06 13:26:08 -0700100 */
Dan Albert495ec922016-09-21 01:08:44 -0700101#define __ANDROID_API__ __ANDROID_API_FUTURE__
Josh Gao99739d42016-04-13 17:16:47 -0700102#endif
David 'Digit' Turner23d24392010-12-06 12:05:11 +0100103
Elliott Hughese9a34c52025-02-18 10:53:18 -0800104/** Deprecated name for API level 9. Prefer numeric API levels in new code. */
Elliott Hughes5bc78c82016-11-16 11:35:43 -0800105#define __ANDROID_API_G__ 9
Elliott Hughes5bc78c82016-11-16 11:35:43 -0800106
Elliott Hughese9a34c52025-02-18 10:53:18 -0800107/** Deprecated name for API level 14. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700108#define __ANDROID_API_I__ 14
109
Elliott Hughese9a34c52025-02-18 10:53:18 -0800110/** Deprecated name for API level 16. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700111#define __ANDROID_API_J__ 16
112
Elliott Hughese9a34c52025-02-18 10:53:18 -0800113/** Deprecated name for API level 17. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700114#define __ANDROID_API_J_MR1__ 17
115
Elliott Hughese9a34c52025-02-18 10:53:18 -0800116/** Deprecated name for API level 18. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700117#define __ANDROID_API_J_MR2__ 18
118
Elliott Hughese9a34c52025-02-18 10:53:18 -0800119/** Deprecated name for API level 19. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700120#define __ANDROID_API_K__ 19
121
Elliott Hughese9a34c52025-02-18 10:53:18 -0800122/** Deprecated name for API level 21. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700123#define __ANDROID_API_L__ 21
124
Elliott Hughese9a34c52025-02-18 10:53:18 -0800125/** Deprecated name for API level 22. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700126#define __ANDROID_API_L_MR1__ 22
127
Elliott Hughese9a34c52025-02-18 10:53:18 -0800128/** Deprecated name for API level 23. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700129#define __ANDROID_API_M__ 23
130
Elliott Hughese9a34c52025-02-18 10:53:18 -0800131/** Deprecated name for API level 24. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700132#define __ANDROID_API_N__ 24
133
Elliott Hughese9a34c52025-02-18 10:53:18 -0800134/** Deprecated name for API level 25. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700135#define __ANDROID_API_N_MR1__ 25
136
Elliott Hughese9a34c52025-02-18 10:53:18 -0800137/** Deprecated name for API level 26. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700138#define __ANDROID_API_O__ 26
139
Elliott Hughese9a34c52025-02-18 10:53:18 -0800140/** Deprecated name for API level 27. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700141#define __ANDROID_API_O_MR1__ 27
142
Elliott Hughese9a34c52025-02-18 10:53:18 -0800143/** Deprecated name for API level 28. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700144#define __ANDROID_API_P__ 28
145
Elliott Hughese9a34c52025-02-18 10:53:18 -0800146/** Deprecated name for API level 29. Prefer numeric API levels in new code. */
Elliott Hughesce934e32018-09-06 13:26:08 -0700147#define __ANDROID_API_Q__ 29
Elliott Hughesc0f46562018-11-09 15:38:52 -0800148
Elliott Hughese9a34c52025-02-18 10:53:18 -0800149/** Deprecated name for API level 30. Prefer numeric API levels in new code. */
Elliott Hughes42067112019-04-18 14:27:24 -0700150#define __ANDROID_API_R__ 30
151
Elliott Hughese9a34c52025-02-18 10:53:18 -0800152/** Deprecated name for API level 31. Prefer numeric API levels in new code. */
Dan Albert14dcbf82020-03-26 16:18:13 -0700153#define __ANDROID_API_S__ 31
154
Elliott Hughese9a34c52025-02-18 10:53:18 -0800155/** Deprecated name for API level 33. Prefer numeric API levels in new code. */
Dan Alberte7915522021-09-08 14:57:46 -0700156#define __ANDROID_API_T__ 33
157
Elliott Hughese9a34c52025-02-18 10:53:18 -0800158/** Deprecated name for API level 34. Prefer numeric API levels in new code. */
Michael Wright8cd2ebf2022-06-25 00:55:56 +0000159#define __ANDROID_API_U__ 34
160
Elliott Hughese9a34c52025-02-18 10:53:18 -0800161/** Deprecated name for API level 35. Prefer numeric API levels in new code. */
Dan Albertb3e895c2023-03-23 18:35:16 +0000162#define __ANDROID_API_V__ 35
163
Elliott Hughes43978a02021-01-07 17:15:41 -0800164/* This file is included in <features.h>, and might be used from .S files. */
165#if !defined(__ASSEMBLY__)
166
Elliott Hughesc0f46562018-11-09 15:38:52 -0800167/**
Dan Albertd8f46912020-08-07 13:54:49 -0700168 * Returns the `targetSdkVersion` of the caller, or `__ANDROID_API_FUTURE__` if
169 * there is no known target SDK version (for code not running in the context of
170 * an app).
Elliott Hughesc0f46562018-11-09 15:38:52 -0800171 *
172 * The returned values correspond to the named constants in `<android/api-level.h>`,
173 * and is equivalent to the AndroidManifest.xml `targetSdkVersion`.
174 *
175 * See also android_get_device_api_level().
176 *
177 * Available since API level 24.
178 */
Dan Albert02ce4012024-10-25 19:13:49 +0000179#if __BIONIC_AVAILABILITY_GUARD(24)
Elliott Hughesc0f46562018-11-09 15:38:52 -0800180int android_get_application_target_sdk_version() __INTRODUCED_IN(24);
Dan Albert02ce4012024-10-25 19:13:49 +0000181#endif /* __BIONIC_AVAILABILITY_GUARD(24) */
182
Elliott Hughesc0f46562018-11-09 15:38:52 -0800183
Elliott Hughes95c6cd72019-12-20 13:26:14 -0800184#if __ANDROID_API__ < 29
Elliott Hughesc0f46562018-11-09 15:38:52 -0800185
Elliott Hughes43978a02021-01-07 17:15:41 -0800186/* android_get_device_api_level is a static inline before API level 29. */
Dan Albert2237fcf2024-05-14 17:53:58 +0000187#define __BIONIC_GET_DEVICE_API_LEVEL_INLINE static __inline
Elliott Hughesc0f46562018-11-09 15:38:52 -0800188#include <bits/get_device_api_level_inlines.h>
189#undef __BIONIC_GET_DEVICE_API_LEVEL_INLINE
190
191#else
192
193/**
194 * Returns the API level of the device we're actually running on, or -1 on failure.
195 * The returned values correspond to the named constants in `<android/api-level.h>`,
196 * and is equivalent to the Java `Build.VERSION.SDK_INT` API.
197 *
198 * See also android_get_application_target_sdk_version().
Elliott Hughes273080f2025-03-07 05:25:39 -0800199 *
200 * Available since API level 29.
Elliott Hughesc0f46562018-11-09 15:38:52 -0800201 */
202int android_get_device_api_level() __INTRODUCED_IN(29);
203
204#endif
205
Elliott Hughes43978a02021-01-07 17:15:41 -0800206#endif /* defined(__ASSEMBLY__) */
207
Elliott Hughesc0f46562018-11-09 15:38:52 -0800208__END_DECLS
Dan Albertd8f46912020-08-07 13:54:49 -0700209
210/** @} */