2012-10-23 19:40:13 +02:00
|
|
|
---
|
|
|
|
libdm/libdm-deptree.c | 14 ++++++++++++++
|
|
|
|
1 file changed, 14 insertions(+)
|
|
|
|
|
|
|
|
--- LVM2.2.02.98.orig/libdm/libdm-deptree.c
|
|
|
|
+++ LVM2.2.02.98/libdm/libdm-deptree.c
|
|
|
|
@@ -20,6 +20,7 @@
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <sys/param.h>
|
|
|
|
#include <sys/utsname.h>
|
|
|
|
+#include <time.h>
|
|
|
|
|
|
|
|
#define MAX_TARGET_PARAMSIZE 500000
|
|
|
|
|
|
|
|
@@ -1570,6 +1571,19 @@ static int _dm_tree_deactivate_children(
|
|
|
|
if ((child->presuspend_node &&
|
2012-10-18 10:15:42 +02:00
|
|
|
!_node_has_closed_parents(child->presuspend_node,
|
|
|
|
uuid_prefix, uuid_prefix_len))) {
|
|
|
|
+
|
|
|
|
+ int idx = 10;
|
|
|
|
+ while (info.open_count && idx--) {
|
|
|
|
+ struct timespec ts = {0, 500000000};
|
|
|
|
+ nanosleep(&ts, NULL);
|
2012-10-23 19:40:13 +02:00
|
|
|
+ _info_by_dev(dinfo->major, dinfo->minor, 1, &info, NULL, NULL, NULL);
|
2012-10-18 10:15:42 +02:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (info.open_count) {
|
|
|
|
+ log_error("give up on open_count");
|
|
|
|
+ continue;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
/* Only report error from (likely non-internal) dependency at top level */
|
|
|
|
if (!level) {
|
|
|
|
log_error("Unable to deactivate open %s (%" PRIu32
|