From: Peter Rajnoha Date: Mon, 25 Nov 2013 13:38:00 +0000 (+0100) Subject: lvm: do not run pvscan for lvmetad update X-Git-Tag: 035~90 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=297b8edc050715d563d54cfa34e42bf5909b9a7b;p=thirdparty%2Fdracut.git lvm: do not run pvscan for lvmetad update The lvmetad daemon is not yet running in initramfs so there's no need to run pvscan (or instantiate any lvm2-pvscan systemd service). If pvscan was called in this case (either directly or via systemd instantiated service), it would fail because there's no lvmetad daemon to update. This could cause confusion, especially in systemd instantiated service which is run only once! --- diff --git a/modules.d/90lvm/module-setup.sh b/modules.d/90lvm/module-setup.sh index 87374da0b..a220a5599 100755 --- a/modules.d/90lvm/module-setup.sh +++ b/modules.d/90lvm/module-setup.sh @@ -76,6 +76,16 @@ install() { fi inst_rules 11-dm-lvm.rules 69-dm-lvm-metad.rules + + # Do not run lvmetad update via pvscan in udev rule - lvmetad is not running yet in dracut! + if grep -q SYSTEMD_WANTS ${initdir}/lib/udev/rules.d/69-dm-lvm-metad.rules; then + sed -i -e 's/^ENV{SYSTEMD_ALIAS}=.*/# No LVM pvscan in dracut - lvmetad is not running yet/' ${initdir}/lib/udev/rules.d/69-dm-lvm-metad.rules + sed -i -e 's/^ENV{ID_MODEL}=.*//' ${initdir}/lib/udev/rules.d/69-dm-lvm-metad.rules + sed -i -e 's/^ENV{SYSTEMD_WANTS}=.*//' ${initdir}/lib/udev/rules.d/69-dm-lvm-metad.rules + else + sed -i -e 's/.*lvm pvscan.*/# No LVM pvscan for in dracut - lvmetad is not running yet/' ${initdir}/lib/udev/rules.d/69-dm-lvm-metad.rules + fi + # Gentoo ebuild for LVM2 prior to 2.02.63-r1 doesn't install above rules # files, but provides the one below: inst_rules 64-device-mapper.rules