| commit | 59a8ed9c89a5e9c0f767a19747fc887d90dcd626 | [log] [tgz] |
|---|---|---|
| author | android-build-team Robot <[email protected]> | Thu Apr 08 00:30:52 2021 +0000 |
| committer | android-build-team Robot <[email protected]> | Thu Apr 08 00:30:52 2021 +0000 |
| tree | 98162465d0e22989b0215e2a6247a8295251370c | |
| parent | 63eb3cecb7edd59e6d990f8d6055faf07d7d63ea [diff] | |
| parent | fb59ed9c93fcc1a9bc481a5f7e834025c53840aa [diff] |
Snap for 7266504 from fb59ed9c93fcc1a9bc481a5f7e834025c53840aa to mainline-networkstack-release Change-Id: I024388ffdc5dfe7ea26b4635a4745a5c98c1cd0e
SdkExtensions is a module that decides the extension SDK level of the device, and provides APIs for applications to query the extension SDK level.
The module is packaged in an apex, com.android.sdkext, and has two components:
bin/derive_sdk: Native binary that runs early in the device boot process and reads metadata of other modules, to set system properties relating to the extension SDK (for instance build.version.extensions.r).javalib/framework-sdkextension.jar: This is a jar on the bootclasspath that exposes APIs to applications to query the extension SDK level.derive_sdk is a program that reads metadata stored in other apex modules, in the form of binary protobuf files in subpath etc/sdkinfo.binarypb inside each apex. The structure of this protobuf can be seen here. The exact steps for converting a set of metadata files to actual extension versions is likely to change over time, and should not be depended upon.
The module exposes a java class SdkExtensions in the package android.os.ext. The method getExtensionVersion(int) can be used to read the version of a particular sdk extension, e.g. getExtensionVersion(Build.VERSION_CODES.R).
For every new Android SDK level a new extension version should be defined. These are the steps necessary to do that:
derive_sdk.cpp by:GetSdkLevel with the new enum setderive_sdk_test.cpp verifying the new extensions worksSdkExtensions.getExtensionVersion API support the new extensions.RollbackManagerServiceImpl#getExtensionVersions to account for the new extension version.