diff options
author | Yabin Cui <yabinc@google.com> | 2016-06-21 11:00:44 -0700 |
---|---|---|
committer | Yabin Cui <yabinc@google.com> | 2016-06-21 11:09:38 -0700 |
commit | bf049bffe2ea70e788e5c54ca307839232eb2f5d (patch) | |
tree | fc7c54a8c23f5849d29d11ffa09c3e641997dc02 /uncrypt/uncrypt.cpp | |
parent | 23af9abbc8597dda65369b9e05dc100a4231b9cb (diff) | |
parent | ed4c49c199224dfe2cf99a26864c5848487da2c3 (diff) | |
download | android_bootable_recovery-bf049bffe2ea70e788e5c54ca307839232eb2f5d.tar.gz android_bootable_recovery-bf049bffe2ea70e788e5c54ca307839232eb2f5d.tar.bz2 android_bootable_recovery-bf049bffe2ea70e788e5c54ca307839232eb2f5d.zip |
resolve merge conflicts of ed4c49c to nyc-mr1-dev-plus-aosp
Change-Id: I8788cc80473dc77bfa0cd2682f3acb6e17ac36df
Diffstat (limited to 'uncrypt/uncrypt.cpp')
-rw-r--r-- | uncrypt/uncrypt.cpp | 19 |
1 files changed, 18 insertions, 1 deletions
diff --git a/uncrypt/uncrypt.cpp b/uncrypt/uncrypt.cpp index 5697712a..0f2487d3 100644 --- a/uncrypt/uncrypt.cpp +++ b/uncrypt/uncrypt.cpp @@ -501,14 +501,31 @@ static bool setup_bcb(const int socket) { return false; } ALOGI(" received command: [%s] (%zu)", content.c_str(), content.size()); + std::vector<std::string> options = android::base::Split(content, "\n"); + std::string wipe_package; + for (auto& option : options) { + if (android::base::StartsWith(option, "--wipe_package=")) { + std::string path = option.substr(strlen("--wipe_package=")); + if (!android::base::ReadFileToString(path, &wipe_package)) { + ALOGE("failed to read %s: %s", path.c_str(), strerror(errno)); + return false; + } + option = android::base::StringPrintf("--wipe_package_size=%zu", wipe_package.size()); + } + } // c8. setup the bcb command std::string err; - if (!write_bootloader_message({content}, &err)) { + if (!write_bootloader_message(options, &err)) { ALOGE("failed to set bootloader message: %s", err.c_str()); write_status_to_socket(-1, socket); return false; } + if (!wipe_package.empty() && !write_wipe_package(wipe_package, &err)) { + ALOGE("failed to set wipe package: %s", err.c_str()); + write_status_to_socket(-1, socket); + return false; + } // c10. send "100" status write_status_to_socket(100, socket); return true; |