X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fcore%2Fmount.c;h=f944c02e2bea7001bb922eebc4dc6c51d2a851a6;hb=cc98b3025eeb89addb76a27390cb2baca4eab8b9;hp=5c87ed31ef60a222b56d6b3ac5c487ff67ecd081;hpb=0c47569ac9eb365ebeb9342f47fb98d52bcc4704;p=elogind.git diff --git a/src/core/mount.c b/src/core/mount.c index 5c87ed31e..f944c02e2 100644 --- a/src/core/mount.c +++ b/src/core/mount.c @@ -378,13 +378,20 @@ static int mount_add_default_dependencies(Mount *m) { if (UNIT(m)->manager->running_as != SYSTEMD_SYSTEM) return 0; - p = get_mount_parameters(m); - - if (!p) + /* We do not add any default dependencies to / and /usr, since + * they are guaranteed to stay mounted the whole time, since + * our system is on it. Also, don't bother with anything + * mounted below virtual file systems, it's also going to be + * virtual, and hence not worth the effort. */ + if (path_equal(m->where, "/") || + path_equal(m->where, "/usr") || + path_startswith(m->where, "/proc") || + path_startswith(m->where, "/sys") || + path_startswith(m->where, "/dev")) return 0; - if (path_equal(m->where, "/") || - path_equal(m->where, "/usr")) + p = get_mount_parameters(m); + if (!p) return 0; if (mount_is_network(p)) { @@ -920,7 +927,7 @@ static void mount_enter_mounting(Mount *m) { _cleanup_free_ char *opts = NULL; r = fstab_filter_options(m->parameters_fragment.options, - "nofail\0" "fail\0" "noauto\0" "auto\0", NULL, NULL, &opts); + "nofail\0" "noauto\0" "auto\0", NULL, NULL, &opts); if (r < 0) goto fail;