Blame SOURCES/0001-Revert-new-udev-autoactivation.patch

081d50
From 8b83a498fda9a8bcaaca3ee179832ab8f598a1a2 Mon Sep 17 00:00:00 2001
081d50
From: Marian Csontos <mcsontos@redhat.com>
081d50
Date: Fri, 3 Dec 2021 17:07:50 +0100
081d50
Subject: [PATCH 1/2] Revert "new udev autoactivation"
081d50
081d50
This reverts commit 67722b312390cdab29c076c912e14bd739c5c0f6.
081d50
---
081d50
 scripts/Makefile.in                |   1 +
081d50
 test/shell/udev-pvscan-vgchange.sh | 403 -----------------------------
081d50
 udev/69-dm-lvm.rules.in            |  87 -------
081d50
 udev/Makefile.in                   |   2 +-
081d50
 5 files changed, 4 insertions(+), 492 deletions(-)
081d50
 delete mode 100644 test/shell/udev-pvscan-vgchange.sh
081d50
 delete mode 100644 udev/69-dm-lvm.rules.in
081d50
081d50
diff --git a/scripts/Makefile.in b/scripts/Makefile.in
081d50
index 0d7f45680..ee0acb6f6 100644
081d50
--- a/scripts/Makefile.in
081d50
+++ b/scripts/Makefile.in
081d50
@@ -92,6 +92,7 @@ install_systemd_generators:
081d50
 install_systemd_units:	install_dbus_service
081d50
 	@echo "    [INSTALL] systemd_units"
081d50
 	$(Q) $(INSTALL_DIR) $(systemd_unit_dir)
081d50
+	$(Q) $(INSTALL_DATA) lvm2-pvscan.service $(systemd_unit_dir)/lvm2-pvscan@.service
081d50
 ifeq ("@BUILD_DMEVENTD@", "yes")
081d50
 	$(Q) $(INSTALL_DATA) dm_event_systemd_red_hat.socket $(systemd_unit_dir)/dm-event.socket
081d50
 	$(Q) $(INSTALL_DATA) dm_event_systemd_red_hat.service $(systemd_unit_dir)/dm-event.service
081d50
diff --git a/test/shell/udev-pvscan-vgchange.sh b/test/shell/udev-pvscan-vgchange.sh
081d50
deleted file mode 100644
081d50
index c81acf0ce..000000000
081d50
--- a/test/shell/udev-pvscan-vgchange.sh
081d50
+++ /dev/null
081d50
@@ -1,403 +0,0 @@
081d50
-#!/usr/bin/env bash
081d50
-
081d50
-# Copyright (C) 2021 Red Hat, Inc. All rights reserved.
081d50
-#
081d50
-# This copyrighted material is made available to anyone wishing to use,
081d50
-# modify, copy, or redistribute it subject to the terms and conditions
081d50
-# of the GNU General Public License v.2.
081d50
-#
081d50
-# You should have received a copy of the GNU General Public License
081d50
-# along with this program; if not, write to the Free Software Foundation,
081d50
-# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
081d50
-
081d50
-test_description='udev rule and systemd unit run vgchange'
081d50
-
081d50
-SKIP_WITH_LVMPOLLD=1
081d50
-SKIP_WITH_LVMLOCKD=1
081d50
-
081d50
-. lib/inittest
081d50
-
081d50
-#
081d50
-# $ cat /tmp/devs
081d50
-# /dev/sdb
081d50
-# /dev/sdc
081d50
-# /dev/sdd
081d50
-#
081d50
-# Specify this file as LVM_TEST_DEVICE_LIST=/tmp/devs
081d50
-# when running the test.
081d50
-#
081d50
-# This test will wipe these devices.
081d50
-#
081d50
-
081d50
-if [ -z ${LVM_TEST_DEVICE_LIST+x} ]; then echo "LVM_TEST_DEVICE_LIST is unset" && skip; else echo "LVM_TEST_DEVICE_LIST is set to '$LVM_TEST_DEVICE_LIST'"; fi
081d50
-
081d50
-test -e "$LVM_TEST_DEVICE_LIST" || skip
081d50
-
081d50
-num_devs=$(cat $LVM_TEST_DEVICE_LIST | wc -l)
081d50
-
081d50
-RUNDIR="/run"
081d50
-test -d "$RUNDIR" || RUNDIR="/var/run"
081d50
-PVS_ONLINE_DIR="$RUNDIR/lvm/pvs_online"
081d50
-VGS_ONLINE_DIR="$RUNDIR/lvm/vgs_online"
081d50
-PVS_LOOKUP_DIR="$RUNDIR/lvm/pvs_lookup"
081d50
-
081d50
-_clear_online_files() {
081d50
-	# wait till udev is finished
081d50
-	aux udev_wait
081d50
-	rm -f "$PVS_ONLINE_DIR"/*
081d50
-	rm -f "$VGS_ONLINE_DIR"/*
081d50
-	rm -f "$PVS_LOOKUP_DIR"/*
081d50
-}
081d50
-
081d50
-test -d "$PVS_ONLINE_DIR" || mkdir -p "$PVS_ONLINE_DIR"
081d50
-test -d "$VGS_ONLINE_DIR" || mkdir -p "$VGS_ONLINE_DIR"
081d50
-test -d "$PVS_LOOKUP_DIR" || mkdir -p "$PVS_LOOKUP_DIR"
081d50
-_clear_online_files
081d50
-
081d50
-aux prepare_real_devs
081d50
-
081d50
-aux lvmconf 'devices/dir = "/dev"'
081d50
-aux lvmconf 'devices/use_devicesfile = 1'
081d50
-DFDIR="$LVM_SYSTEM_DIR/devices"
081d50
-DF="$DFDIR/system.devices"
081d50
-mkdir $DFDIR || true
081d50
-not ls $DF
081d50
-
081d50
-get_real_devs
081d50
-
081d50
-wipe_all() {
081d50
-	for dev in "${REAL_DEVICES[@]}"; do
081d50
-		wipefs -a $dev
081d50
-	done
081d50
-}
081d50
-
081d50
-# udevadm trigger runs udev rule which runs systemd-run --no-wait vgchange -aay
081d50
-# Because of --no-wait, we need to wait for the transient systemd
081d50
-# service to be gone before checking the effects of the vgchange.
081d50
-
081d50
-wait_lvm_activate() {
081d50
-	local vgw=$1
081d50
-	local wait=0
081d50
-
081d50
-	while systemctl status lvm-activate-$vgw > /dev/null && test "$wait" -le 30; do
081d50
-		sleep .2
081d50
-		wait=$(( wait + 1 ))
081d50
-	done
081d50
-}
081d50
-
081d50
-# Test requires 3 devs
081d50
-test $num_devs -gt 2 || skip
081d50
-BDEV1=$(basename "$dev1")
081d50
-BDEV2=$(basename "$dev2")
081d50
-BDEV3=$(basename "$dev3")
081d50
-
081d50
-wipe_all
081d50
-touch $DF
081d50
-for dev in "${REAL_DEVICES[@]}"; do
081d50
-	pvcreate $dev
081d50
-done
081d50
-
081d50
-# 1 dev, 1 vg, 1 lv
081d50
-
081d50
-vgcreate $vg1 "$dev1"
081d50
-lvcreate -l1 -an -n $lv1 $vg1 "$dev1"
081d50
-
081d50
-PVID1=$(pvs "$dev1" --noheading -o uuid | tr -d - | awk '{print $1}')
081d50
-
081d50
-_clear_online_files
081d50
-udevadm trigger --settle -c add /sys/block/$BDEV1
081d50
-
081d50
-wait_lvm_activate $vg1
081d50
-
081d50
-ls "$RUNDIR/lvm/pvs_online/$PVID1"
081d50
-ls "$RUNDIR/lvm/vgs_online/$vg1"
081d50
-journalctl -u lvm-activate-$vg1 | tee out || true
081d50
-grep "now active" out
081d50
-check lv_field $vg1/$lv1 lv_active "active"
081d50
-
081d50
-vgchange -an $vg1
081d50
-vgremove -y $vg1
081d50
-
081d50
-
081d50
-# 2 devs, 1 vg, 2 lvs
081d50
-
081d50
-vgcreate $vg2 "$dev1" "$dev2"
081d50
-lvcreate -l1 -an -n $lv1 $vg2 "$dev1"
081d50
-lvcreate -l1 -an -n $lv2 $vg2 "$dev2"
081d50
-
081d50
-PVID1=$(pvs "$dev1" --noheading -o uuid | tr -d - | awk '{print $1}')
081d50
-PVID2=$(pvs "$dev2" --noheading -o uuid | tr -d - | awk '{print $1}')
081d50
-
081d50
-_clear_online_files
081d50
-
081d50
-udevadm trigger --settle -c add /sys/block/$BDEV1
081d50
-ls "$RUNDIR/lvm/pvs_online/$PVID1"
081d50
-not ls "$RUNDIR/lvm/vgs_online/$vg2"
081d50
-journalctl -u lvm-activate-$vg2 | tee out || true
081d50
-not grep "now active" out
081d50
-check lv_field $vg2/$lv1 lv_active ""
081d50
-check lv_field $vg2/$lv2 lv_active ""
081d50
-
081d50
-udevadm trigger --settle -c add /sys/block/$BDEV2
081d50
-ls "$RUNDIR/lvm/pvs_online/$PVID2"
081d50
-ls "$RUNDIR/lvm/vgs_online/$vg2"
081d50
-
081d50
-wait_lvm_activate $vg2
081d50
-
081d50
-journalctl -u lvm-activate-$vg2 | tee out || true
081d50
-grep "now active" out
081d50
-check lv_field $vg2/$lv1 lv_active "active"
081d50
-check lv_field $vg2/$lv2 lv_active "active"
081d50
-
081d50
-vgchange -an $vg2
081d50
-vgremove -y $vg2
081d50
-
081d50
-
081d50
-# 3 devs, 1 vg, 4 lvs, concurrent pvscans
081d50
-# (attempting to have the pvscans run concurrently and race
081d50
-# to activate the VG)
081d50
-
081d50
-vgcreate $vg3 "$dev1" "$dev2" "$dev3"
081d50
-lvcreate -l1 -an -n $lv1 $vg3 "$dev1"
081d50
-lvcreate -l1 -an -n $lv2 $vg3 "$dev2"
081d50
-lvcreate -l1 -an -n $lv3 $vg3 "$dev3"
081d50
-lvcreate -l8 -an -n $lv4 -i 2 $vg3 "$dev1" "$dev2"
081d50
-
081d50
-PVID1=$(pvs "$dev1" --noheading -o uuid | tr -d - | awk '{print $1}')
081d50
-PVID2=$(pvs "$dev2" --noheading -o uuid | tr -d - | awk '{print $1}')
081d50
-PVID3=$(pvs "$dev3" --noheading -o uuid | tr -d - | awk '{print $1}')
081d50
-
081d50
-_clear_online_files
081d50
-
081d50
-udevadm trigger -c add /sys/block/$BDEV1 &
081d50
-udevadm trigger -c add /sys/block/$BDEV2 &
081d50
-udevadm trigger -c add /sys/block/$BDEV3
081d50
-
081d50
-aux udev_wait
081d50
-wait_lvm_activate $vg3
081d50
-
081d50
-ls "$RUNDIR/lvm/pvs_online/$PVID1"
081d50
-ls "$RUNDIR/lvm/pvs_online/$PVID2"
081d50
-ls "$RUNDIR/lvm/pvs_online/$PVID3"
081d50
-ls "$RUNDIR/lvm/vgs_online/$vg3"
081d50
-journalctl -u lvm-activate-$vg3 | tee out || true
081d50
-grep "now active" out
081d50
-check lv_field $vg3/$lv1 lv_active "active"
081d50
-check lv_field $vg3/$lv2 lv_active "active"
081d50
-check lv_field $vg3/$lv3 lv_active "active"
081d50
-check lv_field $vg3/$lv4 lv_active "active"
081d50
-
081d50
-vgchange -an $vg3
081d50
-vgremove -y $vg3
081d50
-
081d50
-
081d50
-# 3 devs, 1 vg, 4 lvs, concurrent pvscans, metadata on only 1 PV
081d50
-
081d50
-wipe_all
081d50
-rm $DF
081d50
-touch $DF
081d50
-pvcreate --metadatacopies 0 "$dev1"
081d50
-pvcreate --metadatacopies 0 "$dev2"
081d50
-pvcreate "$dev3"
081d50
-
081d50
-vgcreate $vg4 "$dev1" "$dev2" "$dev3"
081d50
-lvcreate -l1 -an -n $lv1 $vg4 "$dev1"
081d50
-lvcreate -l1 -an -n $lv2 $vg4 "$dev2"
081d50
-lvcreate -l1 -an -n $lv3 $vg4 "$dev3"
081d50
-lvcreate -l8 -an -n $lv4 -i 2 $vg4 "$dev1" "$dev2"
081d50
-
081d50
-PVID1=$(pvs "$dev1" --noheading -o uuid | tr -d - | awk '{print $1}')
081d50
-PVID2=$(pvs "$dev2" --noheading -o uuid | tr -d - | awk '{print $1}')
081d50
-PVID3=$(pvs "$dev3" --noheading -o uuid | tr -d - | awk '{print $1}')
081d50
-
081d50
-_clear_online_files
081d50
-
081d50
-udevadm trigger -c add /sys/block/$BDEV1 &
081d50
-udevadm trigger -c add /sys/block/$BDEV2 &
081d50
-udevadm trigger -c add /sys/block/$BDEV3
081d50
-
081d50
-aux udev_wait
081d50
-wait_lvm_activate $vg4
081d50
-
081d50
-ls "$RUNDIR/lvm/pvs_online/$PVID1"
081d50
-ls "$RUNDIR/lvm/pvs_online/$PVID2"
081d50
-ls "$RUNDIR/lvm/pvs_online/$PVID3"
081d50
-ls "$RUNDIR/lvm/vgs_online/$vg4"
081d50
-journalctl -u lvm-activate-$vg4 | tee out || true
081d50
-grep "now active" out
081d50
-check lv_field $vg4/$lv1 lv_active "active"
081d50
-check lv_field $vg4/$lv2 lv_active "active"
081d50
-check lv_field $vg4/$lv3 lv_active "active"
081d50
-check lv_field $vg4/$lv4 lv_active "active"
081d50
-
081d50
-vgchange -an $vg4
081d50
-vgremove -y $vg4
081d50
-
081d50
-
081d50
-# 3 devs, 3 vgs, 2 lvs in each vg, concurrent pvscans
081d50
-
081d50
-wipe_all
081d50
-rm $DF
081d50
-touch $DF
081d50
-
081d50
-vgcreate $vg5 "$dev1"
081d50
-vgcreate $vg6 "$dev2"
081d50
-vgcreate $vg7 "$dev3"
081d50
-lvcreate -l1 -an -n $lv1 $vg5
081d50
-lvcreate -l1 -an -n $lv2 $vg5
081d50
-lvcreate -l1 -an -n $lv1 $vg6
081d50
-lvcreate -l1 -an -n $lv2 $vg6
081d50
-lvcreate -l1 -an -n $lv1 $vg7
081d50
-lvcreate -l1 -an -n $lv2 $vg7
081d50
-
081d50
-_clear_online_files
081d50
-
081d50
-udevadm trigger -c add /sys/block/$BDEV1 &
081d50
-udevadm trigger -c add /sys/block/$BDEV2 &
081d50
-udevadm trigger -c add /sys/block/$BDEV3
081d50
-
081d50
-aux udev_wait
081d50
-wait_lvm_activate $vg5
081d50
-wait_lvm_activate $vg6
081d50
-wait_lvm_activate $vg7
081d50
-
081d50
-ls "$RUNDIR/lvm/vgs_online/$vg5"
081d50
-ls "$RUNDIR/lvm/vgs_online/$vg6"
081d50
-ls "$RUNDIR/lvm/vgs_online/$vg7"
081d50
-journalctl -u lvm-activate-$vg5 | tee out || true
081d50
-grep "now active" out
081d50
-journalctl -u lvm-activate-$vg6 | tee out || true
081d50
-grep "now active" out
081d50
-journalctl -u lvm-activate-$vg7 | tee out || true
081d50
-grep "now active" out
081d50
-check lv_field $vg5/$lv1 lv_active "active"
081d50
-check lv_field $vg5/$lv2 lv_active "active"
081d50
-check lv_field $vg6/$lv1 lv_active "active"
081d50
-check lv_field $vg6/$lv2 lv_active "active"
081d50
-check lv_field $vg7/$lv1 lv_active "active"
081d50
-check lv_field $vg7/$lv2 lv_active "active"
081d50
-
081d50
-vgchange -an $vg5
081d50
-vgremove -y $vg5
081d50
-vgchange -an $vg6
081d50
-vgremove -y $vg6
081d50
-vgchange -an $vg7
081d50
-vgremove -y $vg7
081d50
-
081d50
-# 3 devs, 1 vg, 1000 LVs
081d50
-
081d50
-wipe_all
081d50
-rm $DF
081d50
-touch $DF
081d50
-pvcreate --metadatacopies 0 "$dev1"
081d50
-pvcreate "$dev2"
081d50
-pvcreate "$dev3"
081d50
-vgcreate -s 128K $vg8 "$dev1" "$dev2" "$dev3"
081d50
-
081d50
-# Number of LVs to create
081d50
-TEST_DEVS=1000
081d50
-# On low-memory boxes let's not stress too much
081d50
-test "$(aux total_mem)" -gt 524288 || TEST_DEVS=256
081d50
-
081d50
-vgcfgbackup -f data $vg8
081d50
-
081d50
-# Generate a lot of devices (size of 1 extent)
081d50
-awk -v TEST_DEVS=$TEST_DEVS '/^\t\}/ {
081d50
-    printf("\t}\n\tlogical_volumes {\n");
081d50
-    cnt=0;
081d50
-    for (i = 0; i < TEST_DEVS; i++) {
081d50
-        printf("\t\tlvol%06d  {\n", i);
081d50
-        printf("\t\t\tid = \"%06d-1111-2222-3333-2222-1111-%06d\"\n", i, i);
081d50
-        print "\t\t\tstatus = [\"READ\", \"WRITE\", \"VISIBLE\"]";
081d50
-        print "\t\t\tsegment_count = 1";
081d50
-        print "\t\t\tsegment1 {";
081d50
-        print "\t\t\t\tstart_extent = 0";
081d50
-        print "\t\t\t\textent_count = 1";
081d50
-        print "\t\t\t\ttype = \"striped\"";
081d50
-        print "\t\t\t\tstripe_count = 1";
081d50
-        print "\t\t\t\tstripes = [";
081d50
-        print "\t\t\t\t\t\"pv0\", " cnt++;
081d50
-        printf("\t\t\t\t]\n\t\t\t}\n\t\t}\n");
081d50
-      }
081d50
-  }
081d50
-  {print}
081d50
-' data >data_new
081d50
-
081d50
-vgcfgrestore -f data_new $vg8
081d50
-
081d50
-_clear_online_files
081d50
-
081d50
-udevadm trigger -c add /sys/block/$BDEV1 &
081d50
-udevadm trigger -c add /sys/block/$BDEV2 &
081d50
-udevadm trigger -c add /sys/block/$BDEV3
081d50
-
081d50
-aux udev_wait
081d50
-wait_lvm_activate $vg8
081d50
-
081d50
-ls "$RUNDIR/lvm/vgs_online/$vg8"
081d50
-journalctl -u lvm-activate-$vg8 | tee out || true
081d50
-grep "now active" out
081d50
-
081d50
-num_active=$(lvs $vg8 --noheading -o active | grep active | wc -l)
081d50
-
081d50
-test $num_active -eq $TEST_DEVS
081d50
-
081d50
-vgchange -an $vg8
081d50
-vgremove -y $vg8
081d50
-
081d50
-# 1 pv on an md dev, 1 vg
081d50
-
081d50
-wait_md_create() {
081d50
-	local md=$1
081d50
-
081d50
-	while :; do
081d50
-		if ! grep "$(basename $md)" /proc/mdstat; then
081d50
-			echo "$md not ready"
081d50
-			cat /proc/mdstat
081d50
-			sleep 2
081d50
-		else
081d50
-			break
081d50
-		fi
081d50
-	done
081d50
-	echo "$md" > WAIT_MD_DEV
081d50
-}
081d50
-
081d50
-test -f /proc/mdstat && grep -q raid1 /proc/mdstat || \
081d50
-       modprobe raid1 || skip
081d50
-
081d50
-mddev="/dev/md33"
081d50
-not grep $mddev /proc/mdstat || skip
081d50
-
081d50
-wipe_all
081d50
-rm $DF
081d50
-touch $DF
081d50
-
081d50
-mdadm --create --metadata=1.0 "$mddev" --level 1 --chunk=64 --raid-devices=2 "$dev1" "$dev2"
081d50
-wait_md_create "$mddev"
081d50
-vgcreate $vg9 "$mddev"
081d50
-
081d50
-PVIDMD=`pvs $mddev --noheading -o uuid | tr -d - | awk '{print $1}'`
081d50
-BDEVMD=$(basename "$mddev")
081d50
-
081d50
-lvcreate -l1 -an -n $lv1 $vg9
081d50
-lvcreate -l1 -an -n $lv2 $vg9
081d50
-
081d50
-_clear_online_files
081d50
-
081d50
-udevadm trigger --settle -c add /sys/block/$BDEVMD
081d50
-
081d50
-wait_lvm_activate $vg9
081d50
-
081d50
-ls "$RUNDIR/lvm/vgs_online/$vg9"
081d50
-journalctl -u lvm-activate-$vg9 | tee out || true
081d50
-grep "now active" out
081d50
-check lv_field $vg9/$lv1 lv_active "active"
081d50
-check lv_field $vg9/$lv2 lv_active "active"
081d50
-
081d50
-vgchange -an $vg9
081d50
-vgremove -y $vg9
081d50
-
081d50
-mdadm --stop "$mddev"
081d50
-aux udev_wait
081d50
-wipe_all
081d50
-
081d50
diff --git a/udev/69-dm-lvm.rules.in b/udev/69-dm-lvm.rules.in
081d50
deleted file mode 100644
081d50
index 39e5b9807..000000000
081d50
--- a/udev/69-dm-lvm.rules.in
081d50
+++ /dev/null
081d50
@@ -1,87 +0,0 @@
081d50
-# Copyright (C) 2012,2021 Red Hat, Inc. All rights reserved.
081d50
-#
081d50
-# This file is part of LVM.
081d50
-#
081d50
-# This rule requires blkid to be called on block devices before so only devices
081d50
-# used as LVM PVs are processed (ID_FS_TYPE="LVM2_member").
081d50
-
081d50
-SUBSYSTEM!="block", GOTO="lvm_end"
081d50
-(LVM_EXEC_RULE)
081d50
-
081d50
-ENV{DM_UDEV_DISABLE_OTHER_RULES_FLAG}=="1", GOTO="lvm_end"
081d50
-
081d50
-# Only process devices already marked as a PV - this requires blkid to be called before.
081d50
-ENV{ID_FS_TYPE}!="LVM2_member", GOTO="lvm_end"
081d50
-ENV{DM_MULTIPATH_DEVICE_PATH}=="1", GOTO="lvm_end"
081d50
-ACTION=="remove", GOTO="lvm_end"
081d50
-
081d50
-# Create /dev/disk/by-id/lvm-pv-uuid-<PV_UUID> symlink for each PV
081d50
-ENV{ID_FS_UUID_ENC}=="?*", SYMLINK+="disk/by-id/lvm-pv-uuid-$env{ID_FS_UUID_ENC}"
081d50
-
081d50
-# If the PV is a special device listed below, scan only if the device is
081d50
-# properly activated. These devices are not usable after an ADD event,
081d50
-# but they require an extra setup and they are ready after a CHANGE event.
081d50
-# Also support coldplugging with ADD event but only if the device is already
081d50
-# properly activated.
081d50
-# This logic should be eventually moved to rules where those particular
081d50
-# devices are processed primarily (MD and loop).
081d50
-
081d50
-# DM device:
081d50
-KERNEL!="dm-[0-9]*", GOTO="next"
081d50
-ENV{DM_UDEV_PRIMARY_SOURCE_FLAG}=="1", ENV{DM_ACTIVATION}=="1", GOTO="lvm_scan"
081d50
-GOTO="lvm_end"
081d50
-
081d50
-# MD device:
081d50
-LABEL="next"
081d50
-KERNEL!="md[0-9]*", GOTO="next"
081d50
-IMPORT{db}="LVM_MD_PV_ACTIVATED"
081d50
-ACTION=="add", ENV{LVM_MD_PV_ACTIVATED}=="1", GOTO="lvm_scan"
081d50
-ACTION=="change", ENV{LVM_MD_PV_ACTIVATED}!="1", TEST=="md/array_state", ENV{LVM_MD_PV_ACTIVATED}="1", GOTO="lvm_scan"
081d50
-ACTION=="add", KERNEL=="md[0-9]*p[0-9]*", GOTO="lvm_scan"
081d50
-ENV{LVM_MD_PV_ACTIVATED}!="1", ENV{SYSTEMD_READY}="0"
081d50
-GOTO="lvm_end"
081d50
-
081d50
-# Loop device:
081d50
-LABEL="next"
081d50
-KERNEL!="loop[0-9]*", GOTO="next"
081d50
-ACTION=="add", ENV{LVM_LOOP_PV_ACTIVATED}=="1", GOTO="lvm_scan"
081d50
-ACTION=="change", ENV{LVM_LOOP_PV_ACTIVATED}!="1", TEST=="loop/backing_file", ENV{LVM_LOOP_PV_ACTIVATED}="1", GOTO="lvm_scan"
081d50
-ENV{LVM_LOOP_PV_ACTIVATED}!="1", ENV{SYSTEMD_READY}="0"
081d50
-GOTO="lvm_end"
081d50
-
081d50
-LABEL="next"
081d50
-ACTION!="add", GOTO="lvm_end"
081d50
-
081d50
-LABEL="lvm_scan"
081d50
-
081d50
-ENV{SYSTEMD_READY}="1"
081d50
-
081d50
-# pvscan will check if this device completes a VG,
081d50
-# i.e. all PVs in the VG are now present with the
081d50
-# arrival of this PV.  If so, it prints to stdout:
081d50
-# LVM_VG_NAME_COMPLETE='foo'
081d50
-#
081d50
-# When the VG is complete it can be activated, so
081d50
-# vgchange -aay <vgname> is run.  It is run via
081d50
-# systemd since it can take longer to run than
081d50
-# udev wants to block when processing rules.
081d50
-# (if there are hundreds of LVs to activate,
081d50
-# the vgchange can take many seconds.)
081d50
-#
081d50
-# pvscan only reads the single device specified,
081d50
-# and uses temp files under /run/lvm to check if
081d50
-# other PVs in the VG are present.
081d50
-#
081d50
-# If event_activation=0 in lvm.conf, this pvscan
081d50
-# (using checkcomplete) will do nothing, so that
081d50
-# no event-based autoactivation will be happen.
081d50
-#
081d50
-# TODO: adjust the output of vgchange -aay so that
081d50
-# it's better suited to appearing in the journal.
081d50
-
081d50
-IMPORT{program}="(LVM_EXEC)/lvm pvscan --cache --listvg --checkcomplete --vgonline --udevoutput --journal=output $env{DEVNAME}"
081d50
-ENV{LVM_VG_NAME_COMPLETE}=="?*", RUN+="/usr/bin/systemd-run -r --no-block --property DefaultDependencies=no --unit lvm-activate-$env{LVM_VG_NAME_COMPLETE} lvm vgchange -aay --nohints $env{LVM_VG_NAME_COMPLETE}"
081d50
-GOTO="lvm_end"
081d50
-
081d50
-LABEL="lvm_end"
081d50
-
081d50
diff --git a/udev/Makefile.in b/udev/Makefile.in
081d50
index e777dda16..e32cba921 100644
081d50
--- a/udev/Makefile.in
081d50
+++ b/udev/Makefile.in
081d50
@@ -18,7 +18,7 @@ top_builddir = @top_builddir@
081d50
 include $(top_builddir)/make.tmpl
081d50
 
081d50
 DM_RULES=10-dm.rules 13-dm-disk.rules 95-dm-notify.rules
081d50
-LVM_RULES=11-dm-lvm.rules 69-dm-lvm.rules
081d50
+LVM_RULES=11-dm-lvm.rules 69-dm-lvm-metad.rules
081d50
 
081d50
 DM_DIR=$(shell $(GREP) "\#define DM_DIR" $(top_srcdir)/libdm/misc/dm-ioctl.h | $(AWK) '{print $$3}')
081d50
 
081d50
-- 
081d50
2.31.1
081d50