From: Harald Hoyer Date: Thu, 5 May 2011 10:26:31 +0000 (+0200) Subject: umount: umount, until all umounts failed X-Git-Tag: v30~28^2~2 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=6f7f51f793e5f2a5d42e05e3f1e3101f49d37299 umount: umount, until all umounts failed --- diff --git a/src/umount.c b/src/umount.c index 290e6cad0..20db612ac 100644 --- a/src/umount.c +++ b/src/umount.c @@ -552,6 +552,8 @@ static int dm_points_list_detach(MountPoint **head, bool *changed) { int umount_all(bool *changed) { int r; + bool umount_changed; + LIST_HEAD(MountPoint, mp_list_head); LIST_HEAD_INIT(MountPoint, mp_list_head); @@ -560,7 +562,13 @@ int umount_all(bool *changed) { if (r < 0) goto end; - r = mount_points_list_umount(&mp_list_head, changed); + /* retry umount, until nothing can be umounted anymore */ + do { + umount_changed = false; + r = mount_points_list_umount(&mp_list_head, &umount_changed); + if (umount_changed) + *changed = true; + } while(umount_changed); if (r <= 0) goto end;