commit | c02eb52548227cb395aa6b1121ac3f7758b266da | [log] [tgz] |
---|---|---|
author | Anton Hansson <hansson@google.com> | Wed Dec 30 11:33:31 2020 +0000 |
committer | Anton Hansson <hansson@google.com> | Thu Jan 07 12:52:59 2021 +0000 |
tree | cb5008eb5547bf96e8ba3f5eb1079feeb230fd9f | |
parent | 502b7756f8bb7c8e1a17435e08f33a01d39ae30c [diff] |
Add new proto database and tool to manage it This change adds the schema of the new extension database and the skeleton of a tool to manage it. Each extension version maps to set of module version requirements, and a text representation of this proto database is checked in (currently empty). The tool is currently only able to convert the database to its binary representation (which will be used on-device to derive what extension we have currently). Also add a test for the tool/binary generation. The tool will be extended in future CLs to be able to add/update/remove SDKs, as well performing various consistency checks on the DB. Bug: 173188089 Test: atest gen_sdk_test Change-Id: I918170a851719bcc5bc70568f4705629b500735b
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:
SdkExtensions.getExtensionVersion
API support the new extensions.RollbackManagerServiceImpl#getExtensionVersions
to account for the new extension version.TODO(b/173188089): expand this section when derive_sdk is reimplemented