]> git.ipfire.org Git - thirdparty/util-linux.git/commitdiff
libmount: Fix incorrect detach of reused loop device
authorStanislav Brabec <sbrabec@suse.cz>
Thu, 12 Jan 2017 14:45:42 +0000 (15:45 +0100)
committerKarel Zak <kzak@redhat.com>
Mon, 16 Jan 2017 11:25:45 +0000 (12:25 +0100)
If -oloop is used and the loop device is reused, the loop device is detached
after umount. It is incorrect as it could break the another task using the loop
device.

This is caused by mnt_context_enable_loopdel(,TRUE) that is called from
mnt_context_prepare_umount() whenever "loop" option is used, independently on
AUTOCLEAR flag.

Remove the "loop" option for reused devices to prevent detaching of reused loop
device.

Signed-off-by: Stanislav Brabec <sbrabec@suse.cz>
libmount/src/context_loopdev.c

index 18eb2cc56c760269541752150544f6572c7494bf..ab80bd110359b0f509f108ceca60af56443c45c7 100644 (file)
@@ -10,6 +10,7 @@
  */
 
 #include <blkid.h>
+#include <stdbool.h>
 
 #include "mountP.h"
 #include "loopdev.h"
@@ -142,6 +143,7 @@ int mnt_context_setup_loopdev(struct libmnt_context *cxt)
        struct loopdev_cxt lc;
        int rc = 0, lo_flags = 0;
        uint64_t offset = 0, sizelimit = 0;
+       bool reuse = FALSE;
 
        assert(cxt);
        assert(cxt->fs);
@@ -263,8 +265,10 @@ int mnt_context_setup_loopdev(struct libmnt_context *cxt)
                        if (loopval) {
                                rc = -MNT_ERR_LOOPOVERLAP;
                                goto done;
-                       } else
+                       } else {
+                               reuse = TRUE;
                                goto success;
+                       }
                }
                default: /* error */
                        goto done;
@@ -339,8 +343,8 @@ success:
                /* success */
                cxt->flags |= MNT_FL_LOOPDEV_READY;
 
-               if ((cxt->user_mountflags & MNT_MS_LOOP) &&
-                   loopcxt_is_autoclear(&lc)) {
+               if (reuse || ( (cxt->user_mountflags & MNT_MS_LOOP) &&
+                   loopcxt_is_autoclear(&lc))) {
                        /*
                         * autoclear flag accepted by the kernel, don't store
                         * the "loop=" option to mtab.