From: Lily Foster Date: Thu, 6 Jul 2023 20:13:53 +0000 (-0400) Subject: fstab-generator: unify initrd-root-device.target dependency handling code X-Git-Tag: v254-rc2~80 X-Git-Url: http://git-history.diyao.me/?a=commitdiff_plain;h=9cf2203524baad8d7ebd298d46633e900daad821;p=systemd%2F.git fstab-generator: unify initrd-root-device.target dependency handling code This fixes a bug from #26038 where it would actually write generator stuff during sysroot check when it was only supposed to check for daemon reload. --- diff --git a/src/fstab-generator/fstab-generator.c b/src/fstab-generator/fstab-generator.c index cdcbb0deec..b39d93195a 100644 --- a/src/fstab-generator/fstab-generator.c +++ b/src/fstab-generator/fstab-generator.c @@ -607,6 +607,12 @@ static int add_mount( if (r < 0) return r; + if (in_initrd() && path_equal(where, "/sysroot") && is_device_path(what)) { + r = generator_write_initrd_root_device_deps(dest, what); + if (r < 0) + return r; + } + r = write_mount_timeout(f, where, opts); if (r < 0) return r; @@ -897,12 +903,6 @@ static int parse_fstab_one( mount_is_network(fstype, options) ? SPECIAL_REMOTE_FS_TARGET : SPECIAL_LOCAL_FS_TARGET; - if (is_sysroot && is_device_path(what)) { - r = generator_write_initrd_root_device_deps(arg_dest, what); - if (r < 0) - return r; - } - r = add_mount(source, arg_dest, what, @@ -1090,12 +1090,6 @@ static int add_sysroot_mount(void) { log_debug("Found entry what=%s where=/sysroot type=%s opts=%s", what, strna(arg_root_fstype), strempty(opts)); - if (is_device_path(what)) { - r = generator_write_initrd_root_device_deps(arg_dest, what); - if (r < 0) - return r; - } - makefs = fstab_test_option(opts, "x-systemd.makefs\0"); flags = makefs * MOUNT_MAKEFS;