diff options
author | 2020-11-17 14:44:20 -0800 | |
---|---|---|
committer | 2020-11-17 14:44:20 -0800 | |
commit | 1576534b4699ed971a89ea79641dc592b15da4ae (patch) | |
tree | e69e37324ad88e08f9796ef6e39644444e093de0 | |
parent | ac4a6fcc46d8e7069be2a291b6d737f16a2fbd37 (diff) |
ActivityManager: return status for register/unregisterUidObserver
bug: 172942349
bug: 159172726
Change-Id: I1420d5a9e14aca4f70e8c6cbd26613dd85db51f1
-rw-r--r-- | libs/binder/ActivityManager.cpp | 12 | ||||
-rw-r--r-- | libs/binder/IActivityManager.cpp | 16 | ||||
-rw-r--r-- | libs/binder/include/binder/ActivityManager.h | 4 | ||||
-rw-r--r-- | libs/binder/include/binder/IActivityManager.h | 4 |
4 files changed, 24 insertions, 12 deletions
diff --git a/libs/binder/ActivityManager.cpp b/libs/binder/ActivityManager.cpp index 727ea6024b..e45a656d29 100644 --- a/libs/binder/ActivityManager.cpp +++ b/libs/binder/ActivityManager.cpp @@ -62,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) diff --git a/libs/binder/IActivityManager.cpp b/libs/binder/IActivityManager.cpp index e9f5aae347..cf9bb46b21 100644 --- a/libs/binder/IActivityManager.cpp +++ b/libs/binder/IActivityManager.cpp @@ -59,7 +59,7 @@ public: return fd; } - virtual void registerUidObserver(const sp<IUidObserver>& observer, + virtual status_t registerUidObserver(const sp<IUidObserver>& observer, const int32_t event, const int32_t cutpoint, const String16& callingPackage) @@ -70,15 +70,23 @@ public: data.writeInt32(event); data.writeInt32(cutpoint); data.writeString16(callingPackage); - remote()->transact(REGISTER_UID_OBSERVER_TRANSACTION, data, &reply); + status_t err = remote()->transact(REGISTER_UID_OBSERVER_TRANSACTION, data, &reply); + if (err != NO_ERROR || ((err = reply.readExceptionCode()) != NO_ERROR)) { + return err; + } + return OK; } - virtual void unregisterUidObserver(const sp<IUidObserver>& observer) + virtual status_t unregisterUidObserver(const sp<IUidObserver>& observer) { Parcel data, reply; data.writeInterfaceToken(IActivityManager::getInterfaceDescriptor()); data.writeStrongBinder(IInterface::asBinder(observer)); - remote()->transact(UNREGISTER_UID_OBSERVER_TRANSACTION, data, &reply); + status_t err = remote()->transact(UNREGISTER_UID_OBSERVER_TRANSACTION, data, &reply); + if (err != NO_ERROR || ((err = reply.readExceptionCode()) != NO_ERROR)) { + return err; + } + return OK; } virtual bool isUidActive(const uid_t uid, const String16& callingPackage) diff --git a/libs/binder/include/binder/ActivityManager.h b/libs/binder/include/binder/ActivityManager.h index 02408580bd..830971b1e6 100644 --- a/libs/binder/include/binder/ActivityManager.h +++ b/libs/binder/include/binder/ActivityManager.h @@ -74,11 +74,11 @@ public: ActivityManager(); int openContentUri(const String16& stringUri); - void registerUidObserver(const sp<IUidObserver>& observer, + status_t registerUidObserver(const sp<IUidObserver>& observer, const int32_t event, const int32_t cutpoint, const String16& callingPackage); - void unregisterUidObserver(const sp<IUidObserver>& observer); + status_t unregisterUidObserver(const sp<IUidObserver>& observer); bool isUidActive(const uid_t uid, const String16& callingPackage); int getUidProcessState(const uid_t uid, const String16& callingPackage); status_t checkPermission(const String16& permission, const pid_t pid, const uid_t uid, int32_t* outResult); diff --git a/libs/binder/include/binder/IActivityManager.h b/libs/binder/include/binder/IActivityManager.h index e2081ff009..2d58c462c2 100644 --- a/libs/binder/include/binder/IActivityManager.h +++ b/libs/binder/include/binder/IActivityManager.h @@ -31,11 +31,11 @@ public: DECLARE_META_INTERFACE(ActivityManager) virtual int openContentUri(const String16& stringUri) = 0; - virtual void registerUidObserver(const sp<IUidObserver>& observer, + virtual status_t registerUidObserver(const sp<IUidObserver>& observer, const int32_t event, const int32_t cutpoint, const String16& callingPackage) = 0; - virtual void unregisterUidObserver(const sp<IUidObserver>& observer) = 0; + virtual status_t unregisterUidObserver(const sp<IUidObserver>& observer) = 0; virtual bool isUidActive(const uid_t uid, const String16& callingPackage) = 0; virtual int32_t getUidProcessState(const uid_t uid, const String16& callingPackage) = 0; virtual status_t checkPermission(const String16& permission, |