remount: Do not allow remounting during checkpoints.
Bug: 157540389 Test: manual test Change-Id: I5931a583e48ddac05f319629ae2f7f5f0f6cf032 Merged-In: I5931a583e48ddac05f319629ae2f7f5f0f6cf032
This commit is contained in:
parent
54e693e6d7
commit
9aeae82f69
|
@ -162,10 +162,13 @@ cc_binary {
|
||||||
defaults: ["fs_mgr_defaults"],
|
defaults: ["fs_mgr_defaults"],
|
||||||
static_libs: [
|
static_libs: [
|
||||||
"libavb_user",
|
"libavb_user",
|
||||||
|
"libutils",
|
||||||
|
"libvold_binder",
|
||||||
],
|
],
|
||||||
shared_libs: [
|
shared_libs: [
|
||||||
"libbootloader_message",
|
"libbootloader_message",
|
||||||
"libbase",
|
"libbase",
|
||||||
|
"libbinder",
|
||||||
"libcutils",
|
"libcutils",
|
||||||
"libcrypto",
|
"libcrypto",
|
||||||
"libext4_utils",
|
"libext4_utils",
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
#include <thread>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
@ -31,6 +32,8 @@
|
||||||
#include <android-base/logging.h>
|
#include <android-base/logging.h>
|
||||||
#include <android-base/properties.h>
|
#include <android-base/properties.h>
|
||||||
#include <android-base/strings.h>
|
#include <android-base/strings.h>
|
||||||
|
#include <android/os/IVold.h>
|
||||||
|
#include <binder/IServiceManager.h>
|
||||||
#include <bootloader_message/bootloader_message.h>
|
#include <bootloader_message/bootloader_message.h>
|
||||||
#include <cutils/android_reboot.h>
|
#include <cutils/android_reboot.h>
|
||||||
#include <fec/io.h>
|
#include <fec/io.h>
|
||||||
|
@ -103,8 +106,23 @@ void MyLogger(android::base::LogId id, android::base::LogSeverity severity, cons
|
||||||
::exit(0); // SUCCESS
|
::exit(0); // SUCCESS
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static android::sp<android::os::IVold> GetVold() {
|
||||||
|
while (true) {
|
||||||
|
if (auto sm = android::defaultServiceManager()) {
|
||||||
|
if (auto binder = sm->getService(android::String16("vold"))) {
|
||||||
|
if (auto vold = android::interface_cast<android::os::IVold>(binder)) {
|
||||||
|
return vold;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
std::this_thread::sleep_for(2s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
|
using namespace std::chrono_literals;
|
||||||
|
|
||||||
static int do_remount(int argc, char* argv[]) {
|
static int do_remount(int argc, char* argv[]) {
|
||||||
enum {
|
enum {
|
||||||
SUCCESS = 0,
|
SUCCESS = 0,
|
||||||
|
@ -118,6 +136,9 @@ static int do_remount(int argc, char* argv[]) {
|
||||||
BAD_OVERLAY,
|
BAD_OVERLAY,
|
||||||
NO_MOUNTS,
|
NO_MOUNTS,
|
||||||
REMOUNT_FAILED,
|
REMOUNT_FAILED,
|
||||||
|
MUST_REBOOT,
|
||||||
|
BINDER_ERROR,
|
||||||
|
CHECKPOINTING
|
||||||
} retval = SUCCESS;
|
} retval = SUCCESS;
|
||||||
|
|
||||||
// If somehow this executable is delivered on a "user" build, it can
|
// If somehow this executable is delivered on a "user" build, it can
|
||||||
|
@ -191,6 +212,22 @@ static int do_remount(int argc, char* argv[]) {
|
||||||
return NO_FSTAB;
|
return NO_FSTAB;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (android::base::GetBoolProperty("ro.virtual_ab.enabled", false) &&
|
||||||
|
!android::base::GetBoolProperty("ro.virtual_ab.retrofit", false)) {
|
||||||
|
// Virtual A/B devices can use /data as backing storage; make sure we're
|
||||||
|
// not checkpointing.
|
||||||
|
auto vold = GetVold();
|
||||||
|
bool checkpointing = false;
|
||||||
|
if (!vold->isCheckpointing(&checkpointing).isOk()) {
|
||||||
|
LOG(ERROR) << "Could not determine checkpointing status.";
|
||||||
|
return BINDER_ERROR;
|
||||||
|
}
|
||||||
|
if (checkpointing) {
|
||||||
|
LOG(ERROR) << "Cannot use remount when a checkpoint is in progress.";
|
||||||
|
return CHECKPOINTING;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Generate the list of supported overlayfs mount points.
|
// Generate the list of supported overlayfs mount points.
|
||||||
auto overlayfs_candidates = fs_mgr_overlayfs_candidate_list(fstab);
|
auto overlayfs_candidates = fs_mgr_overlayfs_candidate_list(fstab);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue