X-Git-Url: https://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=discover%2Fdevice-handler.c;h=94abb514ab02f4ecd7c6f53aca81a94f7b8afb2f;hp=8b4046edd83e52a686a7ee0b29768a4bffb1f36f;hb=96eedc649c8c0909a564787afebcfbe0588fd651;hpb=bd6e384a0ba2c1464d9270baf829fea932b88224 diff --git a/discover/device-handler.c b/discover/device-handler.c index 8b4046e..94abb51 100644 --- a/discover/device-handler.c +++ b/discover/device-handler.c @@ -520,6 +520,7 @@ struct discover_context *device_handler_discover_context_create( ctx = talloc(handler, struct discover_context); ctx->device = device; ctx->conf_url = NULL; + ctx->test_data = NULL; list_init(&ctx->boot_options); return ctx; @@ -720,12 +721,15 @@ static bool check_existing_mount(struct discover_device *dev) continue; if (mntstat.st_rdev == devstat.st_rdev) { - pb_debug("%s: %s is already mounted at %s\n" - __func__, dev->device_path, - mnt->mnt_dir); dev->mount_path = talloc_strdup(dev, mnt->mnt_dir); + dev->mounted_rw = !!hasmntopt(mnt, "rw"); dev->mounted = true; dev->unmount = false; + + pb_debug("%s: %s is already mounted (r%c) at %s\n", + __func__, dev->device_path, + dev->mounted_rw ? 'w' : 'o', + mnt->mnt_dir); break; } } @@ -762,6 +766,7 @@ static int mount_device(struct discover_device *dev) "-o", "ro", NULL); if (!rc) { dev->mounted = true; + dev->mounted_rw = false; dev->unmount = true; return 0; } @@ -772,6 +777,7 @@ static int mount_device(struct discover_device *dev) if (!rc) { dev->mounted = true; + dev->mounted_rw = true; dev->unmount = true; return 0; } @@ -797,13 +803,47 @@ static int umount_device(struct discover_device *dev) return -1; dev->mounted = false; + + pb_rmdir_recursive(mount_base(), dev->mount_path); + talloc_free(dev->mount_path); dev->mount_path = NULL; - pb_rmdir_recursive(mount_base(), dev->mount_path); + return 0; +} + +int device_request_write(struct discover_device *dev, bool *release) +{ + int rc; + *release = false; + + if (!dev->mounted) + return -1; + + if (dev->mounted_rw) + return 0; + + rc = process_run_simple(dev, pb_system_apps.mount, dev->mount_path, + "-o", "remount,rw", NULL); + if (rc) + return -1; + + dev->mounted_rw = true; + *release = true; return 0; } + +void device_release_write(struct discover_device *dev, bool release) +{ + if (!release) + return; + + process_run_simple(dev, pb_system_apps.mount, dev->mount_path, + "-o", "remount,ro", NULL); + dev->mounted_rw = false; +} + #else static int umount_device(struct discover_device *dev __attribute__((unused))) @@ -817,5 +857,17 @@ static int __attribute__((unused)) mount_device( return 0; } +int device_request_write(struct discover_device *dev __attribute__((unused)), + bool *release) +{ + *release = true; + return 0; +} + +void device_release_write(struct discover_device *dev __attribute__((unused)), + bool release __attribute__((unused))) +{ +} + #endif