diff options
| author | 2021-10-06 22:53:36 +0000 | |
|---|---|---|
| committer | 2021-10-06 22:53:36 +0000 | |
| commit | 097d2a50873100486d65a69cb1cbabf37fb3b188 (patch) | |
| tree | c2f19f92e4503b2de0afeebdd9bf7aeb1bb2e9c1 /libs/binder/ActivityManager.cpp | |
| parent | cbfb18e134845deeace954bbba818acda48cb80f (diff) | |
| parent | adcb6a2733c1baf66e5ad72365965ab504f5f959 (diff) | |
Merge Android 12
Bug: 202323961
Merged-In: Ifb27b3eb12454fa96f07e6797745c697b4f831c4
Change-Id: I2a7f5931477fddb51564c2eabcdc96ce58888ce8
Diffstat (limited to 'libs/binder/ActivityManager.cpp')
| -rw-r--r-- | libs/binder/ActivityManager.cpp | 25 |
1 files changed, 21 insertions, 4 deletions
diff --git a/libs/binder/ActivityManager.cpp b/libs/binder/ActivityManager.cpp index 5e4c98fc7a..e45a656d29 100644 --- a/libs/binder/ActivityManager.cpp +++ b/libs/binder/ActivityManager.cpp @@ -17,6 +17,7 @@ #include <mutex> #include <unistd.h> +#include <android/permission_manager.h> #include <binder/ActivityManager.h> #include <binder/Binder.h> #include <binder/IServiceManager.h> @@ -61,23 +62,27 @@ int ActivityManager::openContentUri(const String16& stringUri) return service != nullptr ? service->openContentUri(stringUri) : -1; } -void ActivityManager::registerUidObserver(const sp<IUidObserver>& observer, +status_t ActivityManager::registerUidObserver(const sp<IUidObserver>& observer, const int32_t event, const int32_t cutpoint, const String16& callingPackage) { sp<IActivityManager> service = getService(); if (service != nullptr) { - service->registerUidObserver(observer, event, cutpoint, callingPackage); + return service->registerUidObserver(observer, event, cutpoint, callingPackage); } + // ActivityManagerService appears dead. Return usual error code for dead service. + return DEAD_OBJECT; } -void ActivityManager::unregisterUidObserver(const sp<IUidObserver>& observer) +status_t ActivityManager::unregisterUidObserver(const sp<IUidObserver>& observer) { sp<IActivityManager> service = getService(); if (service != nullptr) { - service->unregisterUidObserver(observer); + return service->unregisterUidObserver(observer); } + // ActivityManagerService appears dead. Return usual error code for dead service. + return DEAD_OBJECT; } bool ActivityManager::isUidActive(const uid_t uid, const String16& callingPackage) @@ -98,6 +103,18 @@ int32_t ActivityManager::getUidProcessState(const uid_t uid, const String16& cal return PROCESS_STATE_UNKNOWN; } +status_t ActivityManager::checkPermission(const String16& permission, + const pid_t pid, + const uid_t uid, + int32_t* outResult) { + sp<IActivityManager> service = getService(); + if (service != nullptr) { + return service->checkPermission(permission, pid, uid, outResult); + } + // ActivityManagerService appears dead. Return usual error code for dead service. + return DEAD_OBJECT; +} + status_t ActivityManager::linkToDeath(const sp<IBinder::DeathRecipient>& recipient) { sp<IActivityManager> service = getService(); if (service != nullptr) { |