From df48b430a4a85f923eaecb3fadf9c514692d2082 Mon Sep 17 00:00:00 2001 From: Jan Janssen Date: Wed, 18 May 2022 08:12:31 +0200 Subject: [PATCH] shutdown: Lazy unmount /oldroot/{dev,proc,sys} These should not prevent us from cleaning up the remainders of /oldroot if something in the kernel is blocking these from being unmounted. --- src/shutdown/umount.c | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/src/shutdown/umount.c b/src/shutdown/umount.c index 243a1f80ef..1e691379a4 100644 --- a/src/shutdown/umount.c +++ b/src/shutdown/umount.c @@ -648,6 +648,17 @@ static int umount_with_timeout(MountPoint *m, bool last_try) { if (r == -EBUSY && last_try) log_umount_blockers(m->path); + + /* If API filesystems under /oldroot cannot be unmounted we can still lazily unmount + * them to unblock /oldroot. They serve no function to us anymore and should be + * memory-only and hence safe to unmount like this. */ + if (in_initrd() && + PATH_STARTSWITH_SET(m->path, "/oldroot/dev", "/oldroot/proc", "/oldroot/sys")) { + log_info("Lazily unmounting '%s' instead.", m->path); + r = umount2(m->path, MNT_FORCE | MNT_DETACH); + if (r < 0) + log_error_errno(errno, "Failed to lazily unmount %s: %m", m->path); + } } _exit(r < 0 ? EXIT_FAILURE : EXIT_SUCCESS);