summaryrefslogtreecommitdiff
path: root/bootctrl/BootControlShared.cpp
diff options
context:
space:
mode:
authorXin Li <delphij@google.com>2020-09-08 16:55:28 -0700
committerXin Li <delphij@google.com>2020-09-08 16:55:28 -0700
commit35d16423fb2c1ab97a543f1adfa966e5fe155986 (patch)
tree18ff8b7c2bbe4be5996d1916c561b648b3c688fc /bootctrl/BootControlShared.cpp
parent7a489f84aba93b2f6da99afabd6554045f6252bd (diff)
parente2c629010dfa50f7be8759179452308d1468474d (diff)
Merge Android R
Bug: 168057903 Merged-In: I9b4071d1f54f4867c29d013b8c0eaf80bbf087d0 Change-Id: Ibec477a6ef0ae1b37c2c36cc815a2cd2f645cf36
Diffstat (limited to 'bootctrl/BootControlShared.cpp')
-rw-r--r--bootctrl/BootControlShared.cpp60
1 files changed, 60 insertions, 0 deletions
diff --git a/bootctrl/BootControlShared.cpp b/bootctrl/BootControlShared.cpp
new file mode 100644
index 0000000..125bec4
--- /dev/null
+++ b/bootctrl/BootControlShared.cpp
@@ -0,0 +1,60 @@
+/*
+ * Copyright (C) 2019 The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#define LOG_TAG "bootcontrolhal"
+
+#include <android-base/file.h>
+#include <android-base/logging.h>
+#include <android-base/unique_fd.h>
+#include <bootloader_message/bootloader_message.h>
+#include <libboot_control/libboot_control.h>
+
+#include "BootControlShared.h"
+
+namespace android {
+namespace hardware {
+namespace boot {
+namespace V1_1 {
+namespace implementation {
+
+using android::bootable::GetMiscVirtualAbMergeStatus;
+using android::bootable::InitMiscVirtualAbMessageIfNeeded;
+using android::bootable::SetMiscVirtualAbMergeStatus;
+using android::hardware::boot::V1_1::MergeStatus;
+
+BootControlShared::BootControlShared() {}
+
+bool BootControlShared::Init() {
+ return InitMiscVirtualAbMessageIfNeeded();
+}
+
+Return<bool> BootControlShared::setSnapshotMergeStatus(MergeStatus status) {
+ return SetMiscVirtualAbMergeStatus(getCurrentSlot(), status);
+}
+
+Return<MergeStatus> BootControlShared::getSnapshotMergeStatus() {
+ MergeStatus status;
+ if (!GetMiscVirtualAbMergeStatus(getCurrentSlot(), &status)) {
+ return MergeStatus::UNKNOWN;
+ }
+ return status;
+}
+
+} // namespace implementation
+} // namespace V1_1
+} // namespace boot
+} // namespace hardware
+} // namespace android