diff options
| author | 2022-07-29 18:48:09 +0000 | |
|---|---|---|
| committer | 2022-07-29 18:48:09 +0000 | |
| commit | 8be057ee2eeb5e942315548c78bb0a62b2f2700d (patch) | |
| tree | 269f8656966405d51f901425117ae663a977d2a3 /libs/binder/IServiceManager.cpp | |
| parent | c0268aa756f853c26b8bddc0735510d699abef16 (diff) | |
| parent | f4dee55aa19e5c840c0477ee5a24b6a9cc38f0ae (diff) | |
Merge "servicemanager started property" am: f4dee55aa1
Original change: https://android-review.googlesource.com/c/platform/frameworks/native/+/2161042
Change-Id: I3d2c71120b25d71edf5615c8e6d39bb9d92bd8d8
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
Diffstat (limited to 'libs/binder/IServiceManager.cpp')
| -rw-r--r-- | libs/binder/IServiceManager.cpp | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/libs/binder/IServiceManager.cpp b/libs/binder/IServiceManager.cpp index fd47783acd..c0a8d74195 100644 --- a/libs/binder/IServiceManager.cpp +++ b/libs/binder/IServiceManager.cpp @@ -21,6 +21,7 @@ #include <inttypes.h> #include <unistd.h> +#include <android-base/properties.h> #include <android/os/BnServiceCallback.h> #include <android/os/IServiceManager.h> #include <binder/IPCThreadState.h> @@ -140,6 +141,16 @@ protected: sp<IServiceManager> defaultServiceManager() { std::call_once(gSmOnce, []() { +#if defined(__BIONIC__) && !defined(__ANDROID_VNDK__) + /* wait for service manager */ { + using std::literals::chrono_literals::operator""s; + using android::base::WaitForProperty; + while (!WaitForProperty("servicemanager.ready", "true", 1s)) { + ALOGE("Waited for servicemanager.ready for a second, waiting another..."); + } + } +#endif + sp<AidlServiceManager> sm = nullptr; while (sm == nullptr) { sm = interface_cast<AidlServiceManager>(ProcessState::self()->getContextObject(nullptr)); |