Android: Exit from update_engine_client when daemon dies.
When the update_engine daemon dies or is not running,
update_engine_client now exists with an error code and prints a message
stating a daemon-side failure.
Bug: 25631767
TEST=`update_engine_client --follow` and killed update_engine
Change-Id: I7c13df56bd384d2bdbc5df402f730b2797753a10
diff --git a/Android.mk b/Android.mk
index fb5af1b..686414d 100644
--- a/Android.mk
+++ b/Android.mk
@@ -460,6 +460,7 @@
external/cros/system_api/dbus
LOCAL_SHARED_LIBRARIES += \
libbinder \
+ libbinderwrapper \
libbrillo-binder \
libutils
LOCAL_AIDL_INCLUDES := $(LOCAL_PATH)/binder_bindings
diff --git a/update_engine_client_android.cc b/update_engine_client_android.cc
index 0193eed..5cbcd33 100644
--- a/update_engine_client_android.cc
+++ b/update_engine_client_android.cc
@@ -26,6 +26,7 @@
#include <base/logging.h>
#include <base/strings/string_split.h>
#include <binder/IServiceManager.h>
+#include <binderwrapper/binder_wrapper.h>
#include <brillo/binder_watcher.h>
#include <brillo/daemons/daemon.h>
#include <brillo/flag_helper.h>
@@ -37,8 +38,8 @@
#include "android/os/BnUpdateEngineCallback.h"
#include "android/os/IUpdateEngine.h"
#include "update_engine/client_library/include/update_engine/update_status.h"
-#include "update_engine/update_status_utils.h"
#include "update_engine/common/error_code.h"
+#include "update_engine/update_status_utils.h"
using android::binder::Status;
@@ -69,6 +70,9 @@
int OnInit() override;
+ // Called whenever the UpdateEngine daemon dies.
+ void UpdateEngineServiceDied();
+
// Copy of argc and argv passed to main().
int argc_;
char** argv_;
@@ -137,13 +141,18 @@
}
bool keep_running = false;
-
brillo::InitLog(brillo::kLogToStderr);
+
+ // Initialize a binder watcher early in the process before any interaction
+ // with the binder driver.
+ binder_watcher_.Init();
+
android::status_t status = android::getService(
android::String16("android.os.UpdateEngineService"), &service_);
if (status != android::OK) {
LOG(ERROR) << "Failed to get IUpdateEngine binder from service manager: "
<< Status::fromStatusT(status).toString8();
+ return ExitWhenIdle(1);
}
if (FLAGS_suspend) {
@@ -186,8 +195,14 @@
if (!keep_running)
return ExitWhenIdle(EX_OK);
- // Initialize a binder watcher.
- binder_watcher_.Init();
+ // When following updates status changes, exit if the update_engine daemon
+ // dies.
+ android::BinderWrapper::Create();
+ android::BinderWrapper::Get()->RegisterForDeathNotifications(
+ android::os::IUpdateEngine::asBinder(service_),
+ base::Bind(&UpdateEngineClientAndroid::UpdateEngineServiceDied,
+ base::Unretained(this)));
+
return EX_OK;
}
@@ -206,6 +221,11 @@
return EX_OK;
}
+void UpdateEngineClientAndroid::UpdateEngineServiceDied() {
+ LOG(ERROR) << "UpdateEngineService died.";
+ QuitWithExitCode(1);
+}
+
} // namespace internal
} // namespace chromeos_update_engine