Switch on retry on device remove for libdevmapper.
authorMilan Broz <gmazyland@gmail.com>
Wed, 2 May 2012 12:17:34 +0000 (14:17 +0200)
committerMilan Broz <gmazyland@gmail.com>
Wed, 2 May 2012 12:18:04 +0000 (14:18 +0200)
ChangeLog
configure.in
lib/libdevmapper.c

index b073b73a5bd2ac0b9af283e5c790c1b6e3b6bc63..3511fc18d95380392bdbf28fb122500cec143475 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -2,6 +2,7 @@
        * Fix loop mapping on readonly file.
        * Relax --shared test, allow mapping even for overlapping segments.
        * Support shared flag for LUKS devices (dangerous).
+       * Switch on retry on device remove for libdevmapper.
 
 2012-04-09  Milan Broz  <gmazyland@gmail.com>
        * Fix header check to support old (cryptsetup 1.0.0) header alignment. (1.4.0)
index 40cf0666a9dd12047b7d9e822002219823fa7f8e..43c607f6593511630a66c73dae8b4c5a1944af7b 100644 (file)
@@ -166,6 +166,7 @@ LIBS=$saved_LIBS
 
 LIBS="$LIBS $DEVMAPPER_LIBS"
 AC_CHECK_DECLS([dm_task_secure_data], [], [], [#include <libdevmapper.h>])
+AC_CHECK_DECLS([dm_task_retry_remove], [], [], [#include <libdevmapper.h>])
 AC_CHECK_DECLS([DM_UDEV_DISABLE_DISK_RULES_FLAG], [have_cookie=yes], [have_cookie=no], [#include <libdevmapper.h>])
 if test "x$enable_udev" = xyes; then
        if test "x$have_cookie" = xno; then
index 804403d69f0b62d11fc01e9089cb777b6efbb040..1997c13c99c7b374bad1e87bc441fff365eaa4a2 100644 (file)
@@ -295,6 +295,11 @@ static int _dm_simple(int task, const char *name, int udev_wait)
        if (name && !dm_task_set_name(dmt, name))
                goto out;
 
+#if HAVE_DECL_DM_TASK_RETRY_REMOVE
+       /* Used only in DM_DEVICE_REMOVE */
+       if (name && !dm_task_retry_remove(dmt))
+               goto out;
+#endif
        if (udev_wait && !_dm_task_set_cookie(dmt, &cookie, 0))
                goto out;