From: Hannes Reinecke Date: Thu, 25 Aug 2016 07:33:26 +0000 (+0200) Subject: 90multipath: add shutdown script X-Git-Tag: 047~50^2~2 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=239e8ba2ac3add751ac5f7b06477fada36625161;p=thirdparty%2Fdracut.git 90multipath: add shutdown script As the device-mapper module is removing all device-mapper tables during shutdown we need to make sure to disable queuing on the multipath devices; otherwise there might still be I/O pending and the removal will fail. References: bsc#994860 Signed-off-by: Hannes Reinecke --- diff --git a/modules.d/90multipath/module-setup.sh b/modules.d/90multipath/module-setup.sh index 0a680b177..983f6f240 100755 --- a/modules.d/90multipath/module-setup.sh +++ b/modules.d/90multipath/module-setup.sh @@ -89,6 +89,7 @@ install() { fi inst_hook cleanup 80 "$moddir/multipathd-needshutdown.sh" + inst_hook shutdown 20 "$moddir/multipath-shutdown.sh" inst_rules 40-multipath.rules 56-multipath.rules \ 62-multipath.rules 65-multipath.rules \ diff --git a/modules.d/90multipath/multipath-shutdown.sh b/modules.d/90multipath/multipath-shutdown.sh new file mode 100755 index 000000000..47e9990c6 --- /dev/null +++ b/modules.d/90multipath/multipath-shutdown.sh @@ -0,0 +1,7 @@ +#!/bin/bash + +for i in $(multipath -l -v1); do + if ! $(dmsetup table $i | sed -n '/.*queue_if_no_path.*/q1') ; then + dmsetup message $i 0 fail_if_no_path + fi +done diff --git a/modules.d/90multipath/multipathd-needshutdown.sh b/modules.d/90multipath/multipathd-needshutdown.sh index 214abd3af..ee9b69b4f 100755 --- a/modules.d/90multipath/multipathd-needshutdown.sh +++ b/modules.d/90multipath/multipathd-needshutdown.sh @@ -1,7 +1,8 @@ #!/bin/sh -for i in /dev/mapper/mpath*; do - [ -b "$i" ] || continue - need_shutdown - break +for i in $(multipath -l -v1); do + if $(dmsetup table $i | sed -n '/.*queue_if_no_path.*/q1') ; then + need_shutdown + break + fi done