From: Martin Wilck <mwilck@xxxxxxxx> Some of the methods to determine the SCSI device ID are known to be unreliable and, and possibly cause dm-multipath to falsely detect a multipath setup and cause data corruption. These methods will only be used if the known reliable device IDs (like NAA registered) are unavailable. Don't apply these methods by default. Make the methods to use configurable instead. Configuration is done by setting the udev property ".SCSI_ID_SERIAL_SRC" to any combination of the letters T, L, V, S: T: T10 vendor ID ("1...") L: NAA local ("33...") V: vendor-specific ("0...") S: vendor/model/serial number ("S...") The ordering of the letters in .SCSI_ID_SERIAL_SRC doesn't matter, the precedence is always T, L, V, S. Regardless of using these properties for ID_SERIAL, we can infer that if any of these properties is set, it's correct to set ID_BUS="scsi". Signed-off-by: Martin Wilck <mwilck@xxxxxxxx> --- scripts/55-scsi-sg3_id.rules | 53 +++++++++++++++++++++++++++++++++--- 1 file changed, 49 insertions(+), 4 deletions(-) diff --git a/scripts/55-scsi-sg3_id.rules b/scripts/55-scsi-sg3_id.rules index 453210b..33b2ad3 100644 --- a/scripts/55-scsi-sg3_id.rules +++ b/scripts/55-scsi-sg3_id.rules @@ -99,11 +99,56 @@ ENV{ID_SERIAL}!="?*", ENV{SCSI_IDENT_LUN_NAA_REG}=="?*", ENV{ID_BUS}="scsi", ENV ENV{ID_SERIAL}!="?*", ENV{SCSI_IDENT_LUN_NAA_EXT}=="?*", ENV{ID_BUS}="scsi", ENV{ID_SERIAL}="3$env{SCSI_IDENT_LUN_NAA_EXT}", ENV{ID_SERIAL_SHORT}="$env{SCSI_IDENT_LUN_NAA_EXT}" ENV{ID_SERIAL}!="?*", ENV{SCSI_IDENT_LUN_EUI64}=="?*", ENV{ID_BUS}="scsi", ENV{ID_SERIAL}="2$env{SCSI_IDENT_LUN_EUI64}", ENV{ID_SERIAL_SHORT}="$env{SCSI_IDENT_LUN_EUI64}" ENV{ID_SERIAL}!="?*", ENV{SCSI_IDENT_LUN_NAME}=="?*", ENV{ID_BUS}="scsi", ENV{ID_SERIAL}="8$env{SCSI_IDENT_LUN_NAME}", ENV{ID_SERIAL_SHORT}="$env{SCSI_IDENT_LUN_NAME}" -ENV{ID_SERIAL}!="?*", ENV{SCSI_IDENT_LUN_T10}=="?*", ENV{ID_BUS}="scsi", ENV{ID_SERIAL}="1$env{SCSI_IDENT_LUN_T10}", ENV{ID_SERIAL_SHORT}="$env{SCSI_IDENT_LUN_T10}" -ENV{ID_SERIAL}!="?*", ENV{SCSI_IDENT_LUN_NAA_LOCAL}=="?*", ENV{ID_BUS}="scsi", ENV{ID_SERIAL}="3$env{SCSI_IDENT_LUN_NAA_LOCAL}", ENV{ID_SERIAL_SHORT}="$env{SCSI_IDENT_LUN_NAA_LOCAL}" -ENV{ID_SERIAL}!="?*", ENV{SCSI_IDENT_LUN_VENDOR}=="?*", ENV{ID_BUS}="scsi", ENV{ID_SERIAL}="0$env{SCSI_VENDOR}_$env{SCSI_MODEL}_$env{SCSI_IDENT_LUN_VENDOR}", ENV{ID_SERIAL_SHORT}="$env{SCSI_IDENT_LUN_VENDOR}" -ENV{ID_SERIAL}!="?*", ENV{SCSI_IDENT_SERIAL}=="?*", ENV{ID_BUS}="scsi", ENV{ID_SERIAL}="S$env{SCSI_VENDOR}_$env{SCSI_MODEL}_$env{SCSI_IDENT_SERIAL}", ENV{ID_SERIAL_SHORT}="$env{SCSI_IDENT_SERIAL}" # Compat ID_SCSI_SERIAL setting ENV{ID_SCSI_SERIAL}!="?*", ENV{SCSI_IDENT_SERIAL}=="?*", ENV{ID_SCSI_SERIAL}="$env{SCSI_IDENT_SERIAL}" + +# Enable or disable possibly ambiguous SCSI device ID sources for setting ID_SERIAL +# +# .SCSI_ID_SERIAL_SRC can be any combination of the characters "TLVS": +# T: T10 vendor ID ("1...") from VPD 0x83 +# L: NAA local ("33...") from VPD 0x83 +# V: vendor-specific ("0...") from VPD 0x83 +# S: vendor/model/serial number ("S...") from VPD 0x80 +# The ordering of the letters doesn't matter, the precedence is always T, L, V, S +# NAA (except "local") and EUI-64 IDs (see below), as well as ATA IDs, always take precedence over +# the sources configured here. +# +# This only needs to be changed if there are legacy SCSI devices that don't provide any reliable +# device identifiers, and some subsystem like multipath requires that ID_SERIAL is set. +# Be aware that multipath actually needs unique identifiers, though. +# Using ambiguous identifiers for ID_SERIAL can cause data corruption with multipath. +# +# To configure this, add an early rule (e.g. /etc/udev/rules.d/00-scsi-serial.rules) e.g. like this: +# ACTION!="remove", KERNEL=="sd*|sr*|st*|nst*|cciss*", ENV{.SCSI_ID_SERIAL_SRC}="TLVS" +# +# By default, only T10 vendor ID is allowed. +ENV{.SCSI_ID_SERIAL_SRC}!="?*", ENV{.SCSI_ID_SERIAL_SRC}="T" + +ENV{ID_SERIAL}=="?*", GOTO="sg3_utils_id_end" +ENV{SCSI_IDENT_LUN_T10}=="?*", ENV{ID_BUS}="scsi" +ENV{SCSI_IDENT_LUN_T10}=="?*", ENV{.SCSI_ID_SERIAL_SRC}=="*T*", \ + ENV{ID_SERIAL}="1$env{SCSI_IDENT_LUN_T10}", \ + ENV{ID_SERIAL_SHORT}="$env{SCSI_IDENT_LUN_T10}" + +ENV{ID_SERIAL}=="?*", GOTO="sg3_utils_id_end" +ENV{SCSI_IDENT_LUN_NAA_LOCAL}=="?*", ENV{ID_BUS}="scsi" +ENV{SCSI_IDENT_LUN_NAA_LOCAL}=="?*", ENV{.SCSI_ID_SERIAL_SRC}=="*L*", \ + ENV{ID_SERIAL}="3$env{SCSI_IDENT_LUN_NAA_LOCAL}", \ + ENV{ID_SERIAL_SHORT}="$env{SCSI_IDENT_LUN_NAA_LOCAL}" + +ENV{ID_SERIAL}=="?*", GOTO="sg3_utils_id_end" +ENV{SCSI_IDENT_LUN_VENDOR}=="?*", ENV{ID_BUS}="scsi" +ENV{SCSI_IDENT_LUN_VENDOR}=="?*", ENV{.SCSI_ID_SERIAL_SRC}=="*V*", \ + ENV{ID_SERIAL}="0$env{SCSI_VENDOR}_$env{SCSI_MODEL}_$env{SCSI_IDENT_LUN_VENDOR}", \ + ENV{ID_SERIAL_SHORT}="$env{SCSI_IDENT_LUN_VENDOR}" + +ENV{ID_SERIAL}=="?*", GOTO="sg3_utils_id_end" +ENV{SCSI_IDENT_SERIAL}=="?*", ENV{ID_BUS}="scsi" +ENV{SCSI_IDENT_SERIAL}=="?*", ENV{.SCSI_ID_SERIAL_SRC}=="*S*", \ + ENV{ID_SERIAL}="S$env{SCSI_VENDOR}_$env{SCSI_MODEL}_$env{SCSI_IDENT_SERIAL}", \ + ENV{ID_SERIAL_SHORT}="$env{SCSI_IDENT_SERIAL}" + LABEL="sg3_utils_id_end" +ENV{ID_SERIAL}!="?*", ENV{DEVTYPE}=="disk", \ + PROGRAM="/bin/logger -t 55-scsi-sg3_id.rules -p daemon.warning \"WARNING: SCSI device %k has no device ID, consider changing .SCSI_ID_SERIAL_SRC in 00-scsi-sg3_config.rules\"" -- 2.39.2