fix: shellcheck for modules.d/90lvm/lvm_scan.sh
parent
6e70e9f1b1
commit
d586ff7001
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
# run lvm scan if udev has settled
|
# run lvm scan if udev has settled
|
||||||
|
|
||||||
extraargs="$@"
|
extraargs="$*"
|
||||||
type getarg >/dev/null 2>&1 || . /lib/dracut-lib.sh
|
type getarg >/dev/null 2>&1 || . /lib/dracut-lib.sh
|
||||||
|
|
||||||
VGS=$(getargs rd.lvm.vg -d rd_LVM_VG=)
|
VGS=$(getargs rd.lvm.vg -d rd_LVM_VG=)
|
||||||
|
@ -10,6 +10,7 @@ LVS=$(getargs rd.lvm.lv -d rd_LVM_LV=)
|
||||||
SNAPSHOT=$(getargs rd.lvm.snapshot -d rd_LVM_SNAPSHOT=)
|
SNAPSHOT=$(getargs rd.lvm.snapshot -d rd_LVM_SNAPSHOT=)
|
||||||
SNAPSIZE=$(getargs rd.lvm.snapsize -d rd_LVM_SNAPSIZE=)
|
SNAPSIZE=$(getargs rd.lvm.snapsize -d rd_LVM_SNAPSIZE=)
|
||||||
|
|
||||||
|
# shellcheck disable=SC2174
|
||||||
[ -d /etc/lvm ] || mkdir -m 0755 -p /etc/lvm
|
[ -d /etc/lvm ] || mkdir -m 0755 -p /etc/lvm
|
||||||
# build a list of devices to scan
|
# build a list of devices to scan
|
||||||
lvmdevs=$(
|
lvmdevs=$(
|
||||||
|
@ -24,13 +25,13 @@ if [ ! -e /etc/lvm/lvm.conf ]; then
|
||||||
echo 'devices {';
|
echo 'devices {';
|
||||||
printf ' filter = [ '
|
printf ' filter = [ '
|
||||||
for dev in $lvmdevs; do
|
for dev in $lvmdevs; do
|
||||||
printf '"a|^/dev/%s$|", ' $dev;
|
printf '"a|^/dev/%s$|", ' "$dev";
|
||||||
done;
|
done;
|
||||||
echo '"r/.*/" ]';
|
echo '"r/.*/" ]';
|
||||||
echo '}';
|
echo '}';
|
||||||
|
|
||||||
# establish LVM locking
|
# establish LVM locking
|
||||||
if [ -n $SNAPSHOT ]; then
|
if [ -n "$SNAPSHOT" ]; then
|
||||||
echo 'global {';
|
echo 'global {';
|
||||||
echo ' locking_type = 1';
|
echo ' locking_type = 1';
|
||||||
echo ' use_lvmetad = 0';
|
echo ' use_lvmetad = 0';
|
||||||
|
@ -50,11 +51,11 @@ check_lvm_ver() {
|
||||||
min=$2
|
min=$2
|
||||||
ver=$3
|
ver=$3
|
||||||
# --poll is supported since 2.2.57
|
# --poll is supported since 2.2.57
|
||||||
[ $4 -lt $maj ] && return 1
|
[ "$4" -lt "$maj" ] && return 1
|
||||||
[ $4 -gt $maj ] && return 0
|
[ "$4" -gt "$maj" ] && return 0
|
||||||
[ $5 -lt $min ] && return 1
|
[ "$5" -lt "$min" ] && return 1
|
||||||
[ $5 -gt $min ] && return 0
|
[ "$5" -gt "$min" ] && return 0
|
||||||
[ $6 -ge $ver ] && return 0
|
[ "$6" -ge "$ver" ] && return 0
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,7 +63,8 @@ check_lvm_ver() {
|
||||||
# LVM version: 2.02.53(1) (2009-09-25)
|
# LVM version: 2.02.53(1) (2009-09-25)
|
||||||
OLDIFS=$IFS
|
OLDIFS=$IFS
|
||||||
IFS=.
|
IFS=.
|
||||||
set $(lvm version 2>/dev/null)
|
# shellcheck disable=SC2046
|
||||||
|
set -- $(lvm version 2>/dev/null)
|
||||||
IFS=$OLDIFS
|
IFS=$OLDIFS
|
||||||
maj=${1##*:}
|
maj=${1##*:}
|
||||||
min=$2
|
min=$2
|
||||||
|
@ -72,14 +74,14 @@ sub=${sub%%\(*};
|
||||||
lvm_ignorelockingfailure="--ignorelockingfailure"
|
lvm_ignorelockingfailure="--ignorelockingfailure"
|
||||||
lvm_quirk_args="--ignorelockingfailure --ignoremonitoring"
|
lvm_quirk_args="--ignorelockingfailure --ignoremonitoring"
|
||||||
|
|
||||||
check_lvm_ver 2 2 57 $maj $min $sub && \
|
check_lvm_ver 2 2 57 "$maj" "$min" "$sub" && \
|
||||||
lvm_quirk_args="$lvm_quirk_args --poll n"
|
lvm_quirk_args="$lvm_quirk_args --poll n"
|
||||||
|
|
||||||
if check_lvm_ver 2 2 65 $maj $min $sub; then
|
if check_lvm_ver 2 2 65 "$maj" "$min" "$sub"; then
|
||||||
lvm_quirk_args=" --sysinit $extraargs"
|
lvm_quirk_args=" --sysinit $extraargs"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if check_lvm_ver 2 2 221 $maj $min $sub; then
|
if check_lvm_ver 2 2 221 "$maj" "$min" "$sub"; then
|
||||||
lvm_quirk_args=" $extraargs"
|
lvm_quirk_args=" $extraargs"
|
||||||
unset lvm_ignorelockingfailure
|
unset lvm_ignorelockingfailure
|
||||||
fi
|
fi
|
||||||
|
@ -98,27 +100,27 @@ if [ -n "$SNAPSHOT" ] ; then
|
||||||
SNAP_LV=${SNAPSHOT##*:}
|
SNAP_LV=${SNAPSHOT##*:}
|
||||||
|
|
||||||
info "Removing existing LVM snapshot $SNAP_LV"
|
info "Removing existing LVM snapshot $SNAP_LV"
|
||||||
lvm lvremove --force $SNAP_LV 2>&1| vinfo
|
lvm lvremove --force "$SNAP_LV" 2>&1| vinfo
|
||||||
|
|
||||||
# Determine snapshot size
|
# Determine snapshot size
|
||||||
if [ -z "$SNAPSIZE" ] ; then
|
if [ -z "$SNAPSIZE" ] ; then
|
||||||
SNAPSIZE=$(lvm lvs --noheadings --units m --options lv_size $ORIG_LV)
|
SNAPSIZE=$(lvm lvs --noheadings --units m --options lv_size "$ORIG_LV")
|
||||||
info "No LVM snapshot size provided, using size of $ORIG_LV ($SNAPSIZE)"
|
info "No LVM snapshot size provided, using size of $ORIG_LV ($SNAPSIZE)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
info "Creating LVM snapshot $SNAP_LV ($SNAPSIZE)"
|
info "Creating LVM snapshot $SNAP_LV ($SNAPSIZE)"
|
||||||
lvm lvcreate -s -n $SNAP_LV -L $SNAPSIZE $ORIG_LV 2>&1| vinfo
|
lvm lvcreate -s -n "$SNAP_LV" -L "$SNAPSIZE" "$ORIG_LV" 2>&1| vinfo
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -n "$LVS" ] ; then
|
if [ -n "$LVS" ] ; then
|
||||||
info "Scanning devices $lvmdevs for LVM logical volumes $LVS"
|
info "Scanning devices $lvmdevs for LVM logical volumes $LVS"
|
||||||
lvm lvscan $lvm_ignorelockingfailure 2>&1 | vinfo
|
lvm lvscan $lvm_ignorelockingfailure 2>&1 | vinfo
|
||||||
for LV in $LVS; do
|
for LV in $LVS; do
|
||||||
lvm lvchange --yes -K -ay $lvm_quirk_args $LV 2>&1 | vinfo
|
lvm lvchange --yes -K -ay $lvm_quirk_args "$LV" 2>&1 | vinfo
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -z "$LVS" -o -n "$VGS" ]; then
|
if [ -z "$LVS" ] || [ -n "$VGS" ]; then
|
||||||
info "Scanning devices $lvmdevs for LVM volume groups $VGS"
|
info "Scanning devices $lvmdevs for LVM volume groups $VGS"
|
||||||
lvm vgscan $lvm_ignorelockingfailure 2>&1 | vinfo
|
lvm vgscan $lvm_ignorelockingfailure 2>&1 | vinfo
|
||||||
lvm vgchange -ay $lvm_quirk_args $VGS 2>&1 | vinfo
|
lvm vgchange -ay $lvm_quirk_args $VGS 2>&1 | vinfo
|
||||||
|
|
Loading…
Reference in New Issue