diff options
Diffstat (limited to 'udev')
-rw-r--r-- | udev/10-dm.rules.in | 31 | ||||
-rw-r--r-- | udev/11-lvm.rules | 6 | ||||
-rw-r--r-- | udev/12-dm-disk.rules | 4 | ||||
-rw-r--r-- | udev/12-dm-permissions.rules | 2 | ||||
-rw-r--r-- | udev/95-dm-notify.rules | 2 |
5 files changed, 37 insertions, 8 deletions
diff --git a/udev/10-dm.rules.in b/udev/10-dm.rules.in index bfcf461ce..1386b40a4 100644 --- a/udev/10-dm.rules.in +++ b/udev/10-dm.rules.in @@ -8,11 +8,18 @@ # DM_NAME - actual DM device's name # DM_UUID - UUID set for DM device (blank if not specified) # DM_SUSPENDED - suspended state of DM device (0 or 1) +# DM_UDEV_RULES_VSN - DM udev rules version KERNEL=="device-mapper", NAME="(DM_DIR)/control" SUBSYSTEM!="block", GOTO="dm_end" KERNEL!="dm-[0-9]*", GOTO="dm_end" + +# Set proper sbin path, /sbin has higher priority than /usr/sbin. +ENV{DM_SBIN_PATH}="/sbin" +TEST!="$env{DM_SBIN_PATH}/dmsetup", ENV{DM_SBIN_PATH}="/usr/sbin" +TEST!="$env{DM_SBIN_PATH}/dmsetup", GOTO="dm_end" + ACTION!="add|change", GOTO="dm_end" # Normally, we operate on "change" events only. But when @@ -30,8 +37,8 @@ ACTION=="add", ENV{STARTUP}!="1", NAME="", GOTO="dm_end" # so we also have to call dmsetup if the kernel version used # is in between these releases. TEST=="dm", ENV{DM_NAME}="$attr{dm/name}", ENV{DM_UUID}="$attr{dm/uuid}", ENV{DM_SUSPENDED}="$attr{dm/suspended}" -TEST!="dm", IMPORT{program}="/sbin/dmsetup info -j %M -m %m -c --nameprefixes --noheadings --rows -o name,uuid,suspended" -ENV{DM_SUSPENDED}!="?*", IMPORT{program}="/sbin/dmsetup info -j %M -m %m -c --nameprefixes --noheadings --rows -o suspended" +TEST!="dm", IMPORT{program}="$env{DM_SBIN_PATH}/dmsetup info -j %M -m %m -c --nameprefixes --noheadings --rows -o name,uuid,suspended" +ENV{DM_SUSPENDED}!="?*", IMPORT{program}="$env{DM_SBIN_PATH}/dmsetup info -j %M -m %m -c --nameprefixes --noheadings --rows -o suspended" # dmsetup tool provides suspended state information in textual # form with values "Suspended"/"Active". We translate it to @@ -39,6 +46,26 @@ ENV{DM_SUSPENDED}!="?*", IMPORT{program}="/sbin/dmsetup info -j %M -m %m -c --na ENV{DM_SUSPENDED}=="Active", ENV{DM_SUSPENDED}="0" ENV{DM_SUSPENDED}=="Suspended", ENV{DM_SUSPENDED}="1" +# This variable provides a reliable way to check that device-mapper +# rules were installed. It means that all needed variables are set +# by these rules directly so there's no need to acquire them again +# later. Other rules can alternate the functionality based on this +# fact (e.g. fallback to rules that behave correctly even without +# these rules installed). It also provides versioning for any +# possible future changes. +ENV{DM_UDEV_RULES_VSN}="1" + ENV{DM_NAME}=="?*", NAME="$kernel", SYMLINK+="(DM_DIR)/$env{DM_NAME}" +# We have to ignore further rule application for temporary +# cryptsetup devices. But don't forget to send the notification! +ENV{DM_UUID}=="CRYPT-TEMP-?*", GOTO="dm_last_rule" +ENV{DM_UUID}!="?*", ENV{DM_NAME}=="temporary-cryptsetup-?*", GOTO="dm_last_rule" + +GOTO="dm_end" + +LABEL="dm_last_rule" +ENV{DM_COOKIE}=="?*", RUN+="$env{DM_SBIN_PATH}/dmsetup udevcomplete $env{DM_COOKIE}" +OPTIONS+="last_rule" + LABEL="dm_end" diff --git a/udev/11-lvm.rules b/udev/11-lvm.rules index 9b6ff667e..8ac6525c3 100644 --- a/udev/11-lvm.rules +++ b/udev/11-lvm.rules @@ -11,6 +11,7 @@ SUBSYSTEM!="block", GOTO="lvm_end" KERNEL!="dm-[0-9]*", GOTO="lvm_end" ACTION!="add|change", GOTO="lvm_end" +ENV{DM_UDEV_RULES_VSN}!="?*", GOTO="lvm_end" ENV{DM_UUID}!="LVM-?*", GOTO="lvm_end" # Normally, we operate on "change" events only. But when @@ -20,11 +21,10 @@ ENV{DM_UUID}!="LVM-?*", GOTO="lvm_end" ACTION=="add", ENV{STARTUP}!="1", GOTO="lvm_end" # Use DM name and split it up into its VG/LV/layer constituents. -IMPORT{program}="/sbin/dmsetup splitname --nameprefixes --noheadings --rows $env{DM_NAME}" +IMPORT{program}="$env{DM_SBIN_PATH}/dmsetup splitname --nameprefixes --noheadings --rows $env{DM_NAME}" # Do not create symlinks for hidden subdevices. -ENV{DM_LV_NAME}=="?*_mlog", GOTO="lvm_end" -ENV{DM_LV_NAME}=="?*_mimage_[0-9]*", GOTO="lvm_end" +ENV{DM_LV_NAME}=="?*_mimage_[0-9]*|pvmove?*|?*_vorigin", GOTO="lvm_end" # Create symlinks for top-level devices only. ENV{DM_VG_NAME}=="?*", ENV{DM_LV_NAME}=="?*", ENV{DM_LV_LAYER}!="?*", SYMLINK+="$env{DM_VG_NAME}/$env{DM_LV_NAME}" diff --git a/udev/12-dm-disk.rules b/udev/12-dm-disk.rules index b1e6cd293..b11006415 100644 --- a/udev/12-dm-disk.rules +++ b/udev/12-dm-disk.rules @@ -8,7 +8,7 @@ SUBSYSTEM!="block", GOTO="dm_end" KERNEL!="dm-[0-9]*", GOTO="dm_end" ACTION!="add|change", GOTO="dm_end" -ENV{DM_NAME}!="?*", GOTO="dm_end" +ENV{DM_UDEV_RULES_VSN}!="?*", GOTO="dm_end" # Normally, we operate on "change" events only. But when # coldplugging, there's an "add" event present. We have to @@ -21,7 +21,7 @@ ENV{DM_UUID}=="?*", SYMLINK+="disk/by-id/dm-uuid-$env{DM_UUID}" ENV{DM_SUSPENDED}=="1", GOTO="dm_end" -IMPORT{program}="/sbin/blkid -o udev -p $tempnode" +IMPORT{program}="$env{DM_SBIN_PATH}/blkid -o udev -p $tempnode" OPTIONS="link_priority=-100" ENV{DM_LV_LAYER}=="?*", OPTIONS="link_priority=-90" ENV{ID_FS_USAGE}=="filesystem|other|crypto", ENV{ID_FS_UUID_ENC}=="?*", SYMLINK+="disk/by-uuid/$env{ID_FS_UUID_ENC}" diff --git a/udev/12-dm-permissions.rules b/udev/12-dm-permissions.rules index 1e9cdfdbc..19525381c 100644 --- a/udev/12-dm-permissions.rules +++ b/udev/12-dm-permissions.rules @@ -2,6 +2,7 @@ # # These rules set permissions for DM devices. There are some environment # variables set that can be used: +# DM_UDEV_RULES_VSN - DM udev rules version # DM_NAME - actual DM device's name # DM_UUID - UUID set for DM device (blank if not specified) # DM_SUSPENDED - suspended state of DM device (0 or 1) @@ -12,6 +13,7 @@ SUBSYSTEM!="block", GOTO="dm_end" KERNEL!="dm-[0-9]*", GOTO="dm_end" ACTION!="change", GOTO="dm_end" +ENV{DM_UDEV_RULES_VSN}!="?*", GOTO="dm_end" #ENV{DM_NAME}=="my_device", OWNER:="peter", GROUP:="peter", MODE:="644" diff --git a/udev/95-dm-notify.rules b/udev/95-dm-notify.rules index 236878f79..5834239a0 100644 --- a/udev/95-dm-notify.rules +++ b/udev/95-dm-notify.rules @@ -11,6 +11,6 @@ KERNEL!="dm-[0-9]*", GOTO="dm_end" ACTION!="change|remove", GOTO="dm_end" ACTION=="change", OWNER:="root", GROUP:="root", MODE:="600" -ENV{DM_COOKIE}=="?*", RUN+="/sbin/dmsetup udevcomplete $env{DM_COOKIE}" +ENV{DM_COOKIE}=="?*", RUN+="$env{DM_SBIN_PATH}/dmsetup udevcomplete $env{DM_COOKIE}" LABEL="dm_end" |