NDK r28 beta 1
Pre-releaseDownloads
android {
ndkVersion "28.0.12433566"
}
Platform | Package | Size (Bytes) | SHA1 Checksum |
---|---|---|---|
Windows | android-ndk-r28-beta1-windows.zip | 746848976 | 97328457d44dceae79f1cf488684419e0fec851a |
macOS | android-ndk-r28-beta1-darwin.dmg | 892872146 | f51c4f49d6576106fb20b22b51694208c3157cff |
Linux | android-ndk-r28-beta1-linux.zip | 626833250 | 92dd6d941340624c4fc702ebc7e7cbd6faeb703d |
Changelog
Report issues to GitHub.
For Android Studio issues, go to https://b.android.com and file a bug using the
Android Studio component, not the NDK component.
If you're a build system maintainer that needs to use the tools in the NDK
directly, see the build system maintainers guide.
Announcements
- The 16 KiB page size compatibility option that was added in r27 is now on by
default. If necessary, you can still opt-out (see below).
Changes
-
Updated LLVM to clang-r530567. See
clang_source_info.md
in the toolchain
directory for version information.- Runtime libraries for non-Android have been removed reduce disk usage.
-
PAGE_SIZE
is no longer defined by default for arm64-v8a or x86_64. To
re-enable, setAPP_SUPPORT_FLEXIBLE_PAGE_SIZES
(ndk-build) or
ANDROID_SUPPORT_FLEXIBLE_PAGE_SIZES
(CMake) to false. See Support 16 KB
page sizes for more information. -
The default alignment of shared libraries for arm64-v86 and x86_64 is now 16k.
To revert to 4k alignment, setAPP_SUPPORT_FLEXIBLE_PAGE_SIZES
(ndk-build)
orANDROID_SUPPORT_FLEXIBLE_PAGE_SIZES
(CMake) to false. See Support 16 KB
page sizes for more information. -
Issue 1307: Removed non-NDK binder headers. A number of binder headers that
should have been shipped with aidl were mistakenly shipped in the NDK. These
headers are tightly coupled to the version of aidl used, so this introduced an
unwanted version restriction between build-tools and the NDK. If you are using
the NDK aidl backend, you will need to pass the aidl include path when
building. See the aidl backend docs for more information. -
Issue 2058: Weak API references now work for libc APIs. This was enabled
by removing the explicit#if __ANDROID_API__ >= ...
guards that previously
wrapped declarations in libc headers.If your project contains polyfills for any of those APIs, this change may
break your build due to the conflicting declarations. The simplest fix is to
rename your polyfill to not collide with libc. For example, rename
conflicting_api
toconflicting_api_fallback
and call that instead. Use
#define conflicting_api() conflicting_api_fallback()
if you want to avoid
rewriting callsites.Please open a bug if you run into issues with existing polyfills. We may be
able to add the polyfill directly to the NDK.