From b282107fa947817f1fc0bce6ae88b0a83c275847 Mon Sep 17 00:00:00 2001 From: Harald Hoyer Date: Fri, 18 Feb 2011 10:58:39 +0100 Subject: [PATCH] lvm: use --sysinit, if lvm version >= v2.02.65 --- modules.d/90lvm/lvm_scan.sh | 50 +++++++++++++++++++++++++++++------------- 1 files changed, 34 insertions(+), 16 deletions(-) diff --git a/modules.d/90lvm/lvm_scan.sh b/modules.d/90lvm/lvm_scan.sh index e705d39..7d56fce 100755 --- a/modules.d/90lvm/lvm_scan.sh +++ b/modules.d/90lvm/lvm_scan.sh @@ -45,30 +45,40 @@ if [ ! -e /etc/lvm/lvm.conf ]; then fi check_lvm_ver() { + maj=$1; shift; + min=$1; shift; + ver=$1; shift; # --poll is supported since 2.2.57 - [ $1 -lt 2 ] && return 1 - [ $1 -gt 2 ] && return 0 - # major is 2 - [ $2 -lt 2 ] && return 1 - [ $2 -gt 2 ] && return 0 - # minor is 2, check for - # greater or equal 57 - [ $3 -ge 57 ] && return 0 + [ $1 -lt $maj ] && return 1 + [ $1 -gt $maj ] && return 0 + [ $2 -lt $min ] && return 1 + [ $2 -gt $min ] && return 0 + [ $3 -ge $ver ] && return 0 return 1 } +lvm version 2>/dev/null | ( \ + IFS=. read maj min sub; + maj=${maj##*:}; + sub=${sub%% *}; sub=${sub%%\(*}; + ) 2>/dev/null + nopoll=$( # hopefully this output format will never change, e.g.: # LVM version: 2.02.53(1) (2009-09-25) - lvm version 2>/dev/null | ( \ - IFS=. read maj min sub; - maj=${maj##*:}; - sub=${sub%% *}; sub=${sub%%\(*}; - check_lvm_ver $maj $min $sub && \ + check_lvm_ver 2 2 57 $maj $min $sub && \ echo " --poll n "; - ) 2>/dev/null ) +sysinit=$( + # hopefully this output format will never change, e.g.: + # LVM version: 2.02.53(1) (2009-09-25) + check_lvm_ver 2 2 65 $maj $min $sub && \ + echo " --sysinit "; +) + +export LVM_SUPPRESS_LOCKING_FAILURE_MESSAGES=1 + if [ -n "$SNAPSHOT" ] ; then # HACK - this should probably be done elsewhere or turned into a function # Enable read-write LVM locking @@ -94,13 +104,21 @@ fi if [ -n "$LVS" ] ; then info "Scanning devices $lvmdevs for LVM logical volumes $LVS" lvm lvscan --ignorelockingfailure 2>&1 | vinfo - lvm lvchange -ay --ignorelockingfailure $nopoll --ignoremonitoring $LVS 2>&1 | vinfo + if [ -z "$sysinit" ]; then + lvm lvchange -ay --ignorelockingfailure $nopoll --ignoremonitoring $LVS 2>&1 | vinfo + else + lvm lvchange -ay $sysinit $LVS 2>&1 | vinfo + fi fi if [ -z "$LVS" -o -n "$VGS" ]; then info "Scanning devices $lvmdevs for LVM volume groups $VGS" lvm vgscan --ignorelockingfailure 2>&1 | vinfo - lvm vgchange -ay --ignorelockingfailure $nopoll --ignoremonitoring $VGS 2>&1 | vinfo + if [ -z "$sysinit" ]; then + lvm vgchange -ay --ignorelockingfailure $nopoll --ignoremonitoring $VGS 2>&1 | vinfo + else + lvm vgchange -ay $sysinit $VGS 2>&1 | vinfo + fi fi if [ "$lvmwritten" ]; then