summaryrefslogtreecommitdiff
path: root/init/builtins.cpp
diff options
context:
space:
mode:
authorTreehugger Robot <treehugger-gerrit@google.com>2016-11-10 02:43:08 +0000
committerGerrit Code Review <noreply-gerritcodereview@google.com>2016-11-10 02:43:08 +0000
commite759c83bdec4fd773c63e3e162b45f29740f024e (patch)
tree2d14c10f3993714a12bd79894c1377f54659b3da /init/builtins.cpp
parent5782f7271179fbdd0e0f027aa67fbff4a526d6f0 (diff)
parent039734c7deba32a5f6d27a31dcfdc0a9fa19b0fb (diff)
Merge "Implement Reboot bootloader via bootloader_message"
Diffstat (limited to 'init/builtins.cpp')
-rw-r--r--init/builtins.cpp9
1 files changed, 9 insertions, 0 deletions
diff --git a/init/builtins.cpp b/init/builtins.cpp
index f37ccc2fe..3e50f4da8 100644
--- a/init/builtins.cpp
+++ b/init/builtins.cpp
@@ -703,6 +703,15 @@ static int do_powerctl(const std::vector<std::string>& args) {
callback_on_ro_remount = unmount_and_fsck;
} else if (cmd == ANDROID_RB_RESTART2) {
reboot_target = &command[len + 1];
+ // When rebooting to the bootloader notify the bootloader writing
+ // also the BCB.
+ if (strcmp(reboot_target, "bootloader") == 0) {
+ std::string err;
+ if (!write_reboot_bootloader(&err)) {
+ LOG(ERROR) << "reboot-bootloader: Error writing "
+ "bootloader_message: " << err;
+ }
+ }
}
} else if (command[len] != '\0') {
LOG(ERROR) << "powerctl: unrecognized reboot target '" << &command[len] << "'";