diff options
| author | 2023-06-21 23:04:09 +0000 | |
|---|---|---|
| committer | 2023-06-21 23:04:09 +0000 | |
| commit | 0206fed4ebbd9f1554a412a4c4857a499f10f0fb (patch) | |
| tree | 81df3b4a7b7a7b5af33c44e7e4f1863b0c1c19ae /cmds/servicemanager/ServiceManager.cpp | |
| parent | 7c853f50a8dbbac170a0084082bdd09216d654fb (diff) | |
| parent | efea66bc80fc52c5764dd99dfd73884339f9891c (diff) | |
Merge "servicemanager: guaranteeClient on wait register"
Diffstat (limited to 'cmds/servicemanager/ServiceManager.cpp')
| -rw-r--r-- | cmds/servicemanager/ServiceManager.cpp | 12 | 
1 files changed, 8 insertions, 4 deletions
| diff --git a/cmds/servicemanager/ServiceManager.cpp b/cmds/servicemanager/ServiceManager.cpp index 98a70ed973..cae9684cc4 100644 --- a/cmds/servicemanager/ServiceManager.cpp +++ b/cmds/servicemanager/ServiceManager.cpp @@ -404,14 +404,13 @@ Status ServiceManager::addService(const std::string& name, const sp<IBinder>& bi              .allowIsolated = allowIsolated,              .dumpPriority = dumpPriority,              .hasClients = prevClients, // see b/279898063, matters if existing callbacks -            .guaranteeClient = false,  // handled below +            .guaranteeClient = false,              .ctx = ctx,      };      if (auto it = mNameToRegistrationCallback.find(name); it != mNameToRegistrationCallback.end()) { -        // TODO: this is only needed once -        // See also getService - handles case where client never gets the service, -        // we want the service to quit. +        // If someone is currently waiting on the service, notify the service that +        // we're waiting and flush it to the service.          mNameToService[name].guaranteeClient = true;          CHECK(handleServiceClientCallback(2 /* sm + transaction */, name, false));          mNameToService[name].guaranteeClient = true; @@ -714,6 +713,11 @@ Status ServiceManager::registerClientCallback(const std::string& name, const sp<      mNameToClientCallback[name].push_back(cb); +    // Flush updated info to client callbacks (especially if guaranteeClient +    // and !hasClient, see b/285202885). We may or may not have clients at +    // this point, so ignore the return value. +    (void)handleServiceClientCallback(2 /* sm + transaction */, name, false); +      return Status::ok();  } |