Merge 97cf671d934e6562435586ecf3fa40ee9f28ea78 on remote branch
Change-Id: Ic0df65f55f5f4ccb687da0c5b588ef3781c2f174
diff --git a/ServiceManager.cpp b/ServiceManager.cpp
index 165a8d9..85d4974 100644
--- a/ServiceManager.cpp
+++ b/ServiceManager.cpp
@@ -284,6 +284,12 @@
// Let HidlService know that we handed out a client. If the client drops the service before the
// next time handleClientCallbacks is called, it will still know that the service had been handed out.
hidlService->guaranteeClient();
+ forEachExistingService([&] (HidlService *otherService) {
+ if (otherService != hidlService && interfacesEqual(service, otherService->getService())) {
+ otherService->guaranteeClient();
+ }
+ return true;
+ });
// This is executed immediately after the binder driver confirms the transaction. The driver
// will update the appropriate data structures to reflect the fact that the client now has the