summaryrefslogtreecommitdiffstats
path: root/init/builtins.cpp
diff options
context:
space:
mode:
authorSami Tolvanen <samitolvanen@google.com>2015-03-19 10:00:34 +0000
committerSami Tolvanen <samitolvanen@google.com>2015-03-19 10:11:17 +0000
commitacbf9bef43bc650ed84ba891183ebdf689dafb64 (patch)
treec09a6fee40c660e73d11090b8d79573047ca162a /init/builtins.cpp
parentb054582b90de67a5839345b3a39ad683329f1453 (diff)
downloadsystem_core-acbf9bef43bc650ed84ba891183ebdf689dafb64.zip
system_core-acbf9bef43bc650ed84ba891183ebdf689dafb64.tar.gz
system_core-acbf9bef43bc650ed84ba891183ebdf689dafb64.tar.bz2
Add init command to set verified properties
Add a command that updates dm-verity state and sets partition.%.verified properties used by adb remount. This is needed in init since fs_mgr cannot set properties: I6a28cccb1ccce960841af20a4b20c32d424b5524 Change-Id: I0fdf5bc29c56690dcadff9d0eb216d3c68483538
Diffstat (limited to 'init/builtins.cpp')
-rw-r--r--init/builtins.cpp24
1 files changed, 24 insertions, 0 deletions
diff --git a/init/builtins.cpp b/init/builtins.cpp
index fb1aa7c..01217c1 100644
--- a/init/builtins.cpp
+++ b/init/builtins.cpp
@@ -687,6 +687,30 @@ int do_verity_load_state(int nargs, char **args) {
return -1;
}
+static void verity_update_property(struct fstab_rec *fstab,
+ const char *mount_point, int status) {
+ char key[PROP_NAME_MAX];
+ int ret;
+
+ ret = snprintf(key, PROP_NAME_MAX, "partition.%s.verified", mount_point);
+ if (ret >= PROP_NAME_MAX) {
+ ERROR("Error setting verified property for %s: name too long\n",
+ mount_point);
+ return;
+ }
+
+ ret = property_set(key, "1");
+ if (ret < 0)
+ ERROR("Error setting verified property %s: %d\n", key, ret);
+}
+
+int do_verity_update_state(int nargs, char **args) {
+ if (nargs == 1) {
+ return fs_mgr_update_verity_state(verity_update_property);
+ }
+ return -1;
+}
+
int do_write(int nargs, char **args)
{
const char *path = args[1];