Loading cmds/dumpstate/dumpstate.cpp +31 −0 Original line number Diff line number Diff line Loading @@ -19,6 +19,7 @@ #include <dirent.h> #include <errno.h> #include <fcntl.h> #include <inttypes.h> #include <libgen.h> #include <limits.h> #include <stdbool.h> Loading Loading @@ -50,9 +51,11 @@ #include <android-base/stringprintf.h> #include <android-base/strings.h> #include <android-base/unique_fd.h> #include <android/content/pm/IPackageManagerNative.h> #include <android/hardware/dumpstate/1.0/IDumpstateDevice.h> #include <android/hidl/manager/1.0/IServiceManager.h> #include <android/os/IIncidentCompanion.h> #include <binder/IServiceManager.h> #include <cutils/native_handle.h> #include <cutils/properties.h> #include <debuggerd/client.h> Loading Loading @@ -204,6 +207,30 @@ static bool IsFileEmpty(const std::string& file_path) { return file.tellg() <= 0; } int64_t GetModuleMetadataVersion() { auto binder = defaultServiceManager()->getService(android::String16("package_native")); if (binder == nullptr) { MYLOGE("Failed to retrieve package_native service"); return 0L; } auto package_service = android::interface_cast<content::pm::IPackageManagerNative>(binder); std::string package_name; auto status = package_service->getModuleMetadataPackageName(&package_name); if (!status.isOk()) { MYLOGE("Failed to retrieve module metadata package name: %s", status.toString8().c_str()); return 0L; } MYLOGD("Module metadata package name: %s", package_name.c_str()); int64_t version_code; status = package_service->getVersionCodeForPackage(android::String16(package_name.c_str()), &version_code); if (!status.isOk()) { MYLOGE("Failed to retrieve module metadata version: %s", status.toString8().c_str()); return 0L; } return version_code; } } // namespace } // namespace os } // namespace android Loading Loading @@ -741,6 +768,10 @@ void Dumpstate::PrintHeader() const { printf("Bootloader: %s\n", bootloader.c_str()); printf("Radio: %s\n", radio.c_str()); printf("Network: %s\n", network.c_str()); int64_t module_metadata_version = android::os::GetModuleMetadataVersion(); if (module_metadata_version != 0) { printf("Module Metadata version: %" PRId64 "\n", module_metadata_version); } printf("Kernel: "); DumpFileToFd(STDOUT_FILENO, "", "/proc/version"); Loading libs/binder/aidl/android/content/pm/IPackageManagerNative.aidl +6 −0 Original line number Diff line number Diff line Loading @@ -81,4 +81,10 @@ interface IPackageManagerNative { * returned Status before using the result of this function. */ int getTargetSdkVersionForPackage(in String packageName); /** * Returns the name of module metadata package, or empty string if device doesn't have such * package. */ @utf8InCpp String getModuleMetadataPackageName(); } libs/binder/aidl/android/content/pm/OWNERS 0 → 100644 +4 −0 Original line number Diff line number Diff line narayan@google.com patb@google.com svetoslavganov@google.com toddke@google.com No newline at end of file libs/nativewindow/libnativewindow.map.txt +1 −0 Original line number Diff line number Diff line Loading @@ -8,6 +8,7 @@ LIBNATIVEWINDOW { AHardwareBuffer_isSupported; # introduced=29 AHardwareBuffer_lock; AHardwareBuffer_lockAndGetInfo; # introduced=29 AHardwareBuffer_lockPlanes; # introduced=29 AHardwareBuffer_recvHandleFromUnixSocket; AHardwareBuffer_release; AHardwareBuffer_sendHandleToUnixSocket; Loading Loading
cmds/dumpstate/dumpstate.cpp +31 −0 Original line number Diff line number Diff line Loading @@ -19,6 +19,7 @@ #include <dirent.h> #include <errno.h> #include <fcntl.h> #include <inttypes.h> #include <libgen.h> #include <limits.h> #include <stdbool.h> Loading Loading @@ -50,9 +51,11 @@ #include <android-base/stringprintf.h> #include <android-base/strings.h> #include <android-base/unique_fd.h> #include <android/content/pm/IPackageManagerNative.h> #include <android/hardware/dumpstate/1.0/IDumpstateDevice.h> #include <android/hidl/manager/1.0/IServiceManager.h> #include <android/os/IIncidentCompanion.h> #include <binder/IServiceManager.h> #include <cutils/native_handle.h> #include <cutils/properties.h> #include <debuggerd/client.h> Loading Loading @@ -204,6 +207,30 @@ static bool IsFileEmpty(const std::string& file_path) { return file.tellg() <= 0; } int64_t GetModuleMetadataVersion() { auto binder = defaultServiceManager()->getService(android::String16("package_native")); if (binder == nullptr) { MYLOGE("Failed to retrieve package_native service"); return 0L; } auto package_service = android::interface_cast<content::pm::IPackageManagerNative>(binder); std::string package_name; auto status = package_service->getModuleMetadataPackageName(&package_name); if (!status.isOk()) { MYLOGE("Failed to retrieve module metadata package name: %s", status.toString8().c_str()); return 0L; } MYLOGD("Module metadata package name: %s", package_name.c_str()); int64_t version_code; status = package_service->getVersionCodeForPackage(android::String16(package_name.c_str()), &version_code); if (!status.isOk()) { MYLOGE("Failed to retrieve module metadata version: %s", status.toString8().c_str()); return 0L; } return version_code; } } // namespace } // namespace os } // namespace android Loading Loading @@ -741,6 +768,10 @@ void Dumpstate::PrintHeader() const { printf("Bootloader: %s\n", bootloader.c_str()); printf("Radio: %s\n", radio.c_str()); printf("Network: %s\n", network.c_str()); int64_t module_metadata_version = android::os::GetModuleMetadataVersion(); if (module_metadata_version != 0) { printf("Module Metadata version: %" PRId64 "\n", module_metadata_version); } printf("Kernel: "); DumpFileToFd(STDOUT_FILENO, "", "/proc/version"); Loading
libs/binder/aidl/android/content/pm/IPackageManagerNative.aidl +6 −0 Original line number Diff line number Diff line Loading @@ -81,4 +81,10 @@ interface IPackageManagerNative { * returned Status before using the result of this function. */ int getTargetSdkVersionForPackage(in String packageName); /** * Returns the name of module metadata package, or empty string if device doesn't have such * package. */ @utf8InCpp String getModuleMetadataPackageName(); }
libs/binder/aidl/android/content/pm/OWNERS 0 → 100644 +4 −0 Original line number Diff line number Diff line narayan@google.com patb@google.com svetoslavganov@google.com toddke@google.com No newline at end of file
libs/nativewindow/libnativewindow.map.txt +1 −0 Original line number Diff line number Diff line Loading @@ -8,6 +8,7 @@ LIBNATIVEWINDOW { AHardwareBuffer_isSupported; # introduced=29 AHardwareBuffer_lock; AHardwareBuffer_lockAndGetInfo; # introduced=29 AHardwareBuffer_lockPlanes; # introduced=29 AHardwareBuffer_recvHandleFromUnixSocket; AHardwareBuffer_release; AHardwareBuffer_sendHandleToUnixSocket; Loading