chiark / gitweb /
update Fedora rules
[elogind.git] / etc / udev / redhat / udev.rules
index 5bed78228091bcf4086fd8e1d16376d84133a0f3..115abc3ae4b6ce93b2c5758736a4c4599c84256c 100644 (file)
@@ -1,36 +1,39 @@
 # There are a number of modifiers that are allowed to be used in some of the
 # fields.  See the udev man page for a full description of them.
 #
-# default is OWNER="root" GROUP="root", MODE="0660"
+# default is OWNER="root" GROUP="root", MODE="0600"
 #
+KERNEL="*", OWNER="root" GROUP="root", MODE="0600"
 
 # all block devices
 SUBSYSTEM=="block",            GROUP="disk", MODE="0640"
+KERNEL=="root",                        GROUP="disk", MODE="0640"
 
 # console devices
-KERNEL=="tty",                 MODE="0666"
-KERNEL=="tty[0-9]",            GROUP="tty", MODE="0660"
-KERNEL=="tty[0-9][0-9]*",      GROUP="tty", MODE="0660"
-KERNEL=="vc/[0-9]*",           GROUP="tty", MODE="0660"
+KERNEL=="tty",                 MODE="0666", OPTIONS="last_rule"
+KERNEL=="tty[0-9]",            GROUP="tty", MODE="0660", OPTIONS="last_rule"
+KERNEL=="tty[0-9][0-9]*",      GROUP="tty", MODE="0660", OPTIONS="last_rule"
+KERNEL=="vc/[0-9]*",           GROUP="tty", MODE="0660", OPTIONS="last_rule"
 
 # pty devices
 #  Set this to 0660 if you only want users belonging to tty group
 #  to be able to allocate PTYs
-KERNEL=="ptmx",                        GROUP="tty", MODE="0666"
-KERNEL=="pty[p-za-e][0-9a-f]*",        GROUP="tty", MODE="0660"
-KERNEL=="tty[p-za-e][0-9a-f]*",        GROUP="tty", MODE="0660"
-KERNEL=="pty/m*",              GROUP="tty", MODE="0660"
-KERNEL=="vc/s*",               GROUP="tty", MODE="0660"
+KERNEL=="ptmx",                        GROUP="tty", MODE="0666", OPTIONS="last_rule"
+KERNEL=="pty[p-za-e][0-9a-f]*",        GROUP="tty", MODE="0660", OPTIONS="last_rule"
+KERNEL=="tty[p-za-e][0-9a-f]*",        GROUP="tty", MODE="0660", OPTIONS="last_rule"
+KERNEL=="pty/m*",              GROUP="tty", MODE="0660", OPTIONS="last_rule"
+KERNEL=="vc/s*",               GROUP="tty", MODE="0660", OPTIONS="last_rule"
 
 # serial+dialup devices
-KERNEL=="ttyS*",               GROUP="uucp", MODE="0660"
+KERNEL=="ttyS*",               GROUP="uucp", MODE="0660", OPTIONS="last_rule"
+KERNEL=="ttyACM*",             GROUP="uucp", MODE="0660", OPTIONS="last_rule"
+KERNEL=="ttyUSB*",             GROUP="uucp", MODE="0660", OPTIONS="last_rule"
 KERNEL=="ippp*",               MODE="0660"
 KERNEL=="isdn*",               MODE="0660"
 KERNEL=="isdnctrl*",           MODE="0660"
 KERNEL=="capi*",               MODE="0660"
 KERNEL=="dcbri*",              MODE="0660"
 KERNEL=="ircomm*",             GROUP="uucp", MODE="0660"
-KERNEL=="ttyUSB*",             GROUP="uucp", MODE="0660"
 KERNEL=="tts/[0-9]*",          GROUP="uucp", MODE="0660"
 KERNEL=="tts/USB[0-9]*",       GROUP="uucp", MODE="0660"
 
@@ -86,14 +89,14 @@ KERNEL=="usblp*",           GROUP="lp", MODE="0660"
 KERNEL=="usb/lp*",             GROUP="lp", MODE="0660"
 
 # tape devices
-KERNEL=="ht*",                 GROUP="disk", MODE="0640"
-KERNEL=="nht*",                        GROUP="disk", MODE="0640"
-KERNEL=="pt[0-9]*",            GROUP="disk", MODE="0640"
-KERNEL=="npt*",                        GROUP="disk", MODE="0640"
-KERNEL=="st*",                 GROUP="disk", MODE="0640"
-KERNEL=="nst*",                        GROUP="disk", MODE="0640"
-KERNEL=="osst*",               GROUP="disk", MODE="0640"
-KERNEL=="nosst*",              GROUP="disk", MODE="0640"
+KERNEL=="ht*",                 GROUP="disk", MODE="0660"
+KERNEL=="nht*",                        GROUP="disk", MODE="0660"
+KERNEL=="pt[0-9]*",            GROUP="disk", MODE="0660"
+KERNEL=="npt*",                        GROUP="disk", MODE="0660"
+KERNEL=="st*",                 GROUP="disk", MODE="0660"
+KERNEL=="nst*",                        GROUP="disk", MODE="0660"
+KERNEL=="osst*",               GROUP="disk", MODE="0660"
+KERNEL=="nosst*",              GROUP="disk", MODE="0660"
 
 # diskonkey devices
 KERNEL=="diskonkey*",          GROUP="disk", MODE="0640"
@@ -144,7 +147,7 @@ KERNEL=="dvb/adapter*",             MODE="0660"
 
 # create a symlink named after the device map name
 # note devmap_name comes with extras/multipath
-#KERNEL=="dm-[0-9]*", PROGRAM="/sbin/devmap_name %M %m", NAME="%k", SYMLINK="%c"
+#KERNEL=="dm-[0-9]*", PROGRAM="/sbin/devmap_name %M %m", NAME="%k", SYMLINK+="%c"
 
 # DRI devices always go into a subdirectory (as per the LSB spec)
 KERNEL=="card*",               NAME="dri/card%n"
@@ -166,37 +169,41 @@ KERNEL=="ts*",                    NAME="input/%k"
 
 KERNEL=="raw[0-9]*",           NAME="raw/%k"
 
-KERNEL=="lp[0-9]*",            SYMLINK="par%n"
+KERNEL=="lp[0-9]*",            SYMLINK+="par%n"
 BUS=="usb", KERNEL=="lp[0-9]*",        NAME="usb/%k"
 
 KERNEL=="microcode",           NAME="cpu/%k"
-KERNEL=="ram1",                        SYMLINK="ram"
-KERNEL=="video0",              SYMLINK="video"
-KERNEL=="radio0",              SYMLINK="radio"
-KERNEL=="audio0",              SYMLINK="audio"
-KERNEL=="dsp0",                        SYMLINK="dsp"
-KERNEL=="fb0",                 SYMLINK="fb"
-KERNEL=="qft0",                        SYMLINK="ftape"
-KERNEL=="isdnctrl0",           SYMLINK="isdnctrl"
-KERNEL=="mixer0",              SYMLINK="mixer"
-KERNEL=="ram0",                        SYMLINK="ramdisk"
-KERNEL=="sbpcd0",              SYMLINK="sbpcd"
-KERNEL=="radio0",              SYMLINK="radio"
-KERNEL=="tty0",                        SYMLINK="systty"
-KERNEL=="vbi0",                        SYMLINK="vbi"
-KERNEL=="null",                        SYMLINK="XOR"
+KERNEL="msr[0-9]*",            NAME="cpu/%n/msr"
+KERNEL="cpu[0-9]*",            NAME="cpu/%n/cpu"
+
+KERNEL=="ram1",                        SYMLINK+="ram"
+KERNEL=="video0",              SYMLINK+="video"
+KERNEL=="radio0",              SYMLINK+="radio"
+KERNEL=="audio0",              SYMLINK+="audio"
+KERNEL=="dsp0",                        SYMLINK+="dsp"
+KERNEL=="fb0",                 SYMLINK+="fb"
+KERNEL=="qft0",                        SYMLINK+="ftape"
+KERNEL=="isdnctrl0",           SYMLINK+="isdnctrl"
+KERNEL=="mixer0",              SYMLINK+="mixer"
+KERNEL=="ram0",                        SYMLINK+="ramdisk"
+KERNEL=="sbpcd0",              SYMLINK+="sbpcd"
+KERNEL=="radio0",              SYMLINK+="radio"
+KERNEL=="tty0",                        SYMLINK+="systty"
+KERNEL=="vbi0",                        SYMLINK+="vbi"
+KERNEL=="null",                        SYMLINK+="XOR"
 
 KERNEL=="tun",                 NAME="net/%k"
 
 KERNEL=="device-mapper",       NAME="mapper/control"
 
 # old compat symlinks with enumeration
-KERNEL=="sr[0-9]*",            SYMLINK="cdrom%e"
-KERNEL=="scd[0-9]*",           SYMLINK="cdrom%e"
-KERNEL=="pcd[0-9]*",           SYMLINK="cdrom%e"
-KERNEL=="fd[0-9]*",            SYMLINK="floppy%e"
-KERNEL=="nst[0-9]", BUS=="scsi",       SYMLINK="tape%e"
-KERNEL=="nosst[0-9]", BUS=="scsi",     SYMLINK="tape%e"
+KERNEL=="sr[0-9]*",            SYMLINK+="cdrom%e"
+KERNEL=="scd[0-9]*",           SYMLINK+="cdrom%e"
+KERNEL=="pcd[0-9]*",           SYMLINK+="cdrom%e"
+KERNEL=="fd[0-9]*",            SYMLINK+="floppy%e"
+KERNEL=="nst[0-9]", BUS=="scsi",       SYMLINK+="tape%e", MODE="0660"
+KERNEL=="nosst[0-9]", BUS=="scsi",     SYMLINK+="tape%e", MODE="0660"
+KERNEL=="sg[0-9]*", BUS="scsi", SYSFS{type}=="6", SYMLINK+="scanner%e", MODE="0660"
 
 KERNEL=="umad*",               NAME="infiniband/%k"
 KERNEL=="issm*",               NAME="infiniband/%k"
@@ -208,22 +215,106 @@ KERNEL=="zapchannel",            NAME="zap/channel"
 KERNEL=="zappseudo",           NAME="zap/pseudo"
 KERNEL=="zap[0-9]*",           NAME="zap/%n"
 
+BUS=="scsi", KERNEL=="sg[0-9]*", SYSFS{type}=="6", NAME="%k", SYMLINK="scanner%e", MODE="0660"
+
 # do not seperate the next 2 lines!!
-KERNEL=="hd[a-z]", BUS=="ide", SYSFS{removable}=="1", PROGRAM=="/etc/udev/scripts/ide-media.sh %k", RESULT=="floppy", SYMLINK="floppy%e", NAME{ignore_remove, all_partitions}="%k"
+KERNEL=="hd[a-z]", BUS=="ide", SYSFS{removable}=="1", PROGRAM=="/etc/udev/scripts/ide-media.sh %k", RESULT=="floppy", SYMLINK+="floppy%e", NAME{ignore_remove, all_partitions}="%k"
 
-KERNEL=="hd[a-z]", BUS=="ide", SYSFS{removable}=="1", RESULT=="cdrom", SYMLINK="cdrom%e"
+KERNEL=="hd[a-z]", BUS=="ide", SYSFS{removable}=="1", RESULT=="cdrom", SYMLINK+="cdrom%e"
 
-KERNEL=="hd[a-z]", BUS=="ide", SYSFS{removable}=="1", PROGRAM=="/etc/udev/scripts/check-cdrom.sh %k DVD", SYMLINK="dvd%e"
-KERNEL=="sr[0-9]*", BUS=="scsi", PROGRAM=="/etc/udev/scripts/check-cdrom.sh %k DVD", SYMLINK="dvd%e"
+KERNEL=="hd[a-z]", BUS=="ide", SYSFS{removable}=="1", PROGRAM=="/etc/udev/scripts/check-cdrom.sh %k DVD", SYMLINK+="dvd%e"
+KERNEL=="sr[0-9]*", BUS=="scsi", PROGRAM=="/etc/udev/scripts/check-cdrom.sh %k DVD", SYMLINK+="dvd%e"
 
-KERNEL=="hd[a-z]", BUS=="ide", SYSFS{removable}=="1", PROGRAM=="/etc/udev/scripts/check-cdrom.sh %k CD-R", SYMLINK="cdwriter%e"
-KERNEL=="sr[0-9]*", BUS=="scsi", PROGRAM=="/etc/udev/scripts/check-cdrom.sh %k CD-R", SYMLINK="cdwriter%e"
+KERNEL=="hd[a-z]", BUS=="ide", SYSFS{removable}=="1", PROGRAM=="/etc/udev/scripts/check-cdrom.sh %k CD-R", SYMLINK+="cdwriter%e"
+KERNEL=="sr[0-9]*", BUS=="scsi", PROGRAM=="/etc/udev/scripts/check-cdrom.sh %k CD-R", SYMLINK+="cdwriter%e"
 
-KERNEL=="hd[a-z]", BUS=="ide", SYSFS{removable}=="1", PROGRAM="/etc/udev/scripts/check-cdrom.sh %k DVD-R", SYMLINK="dvdwriter%e"
-KERNEL=="sr[0-9]*", BUS=="scsi", PROGRAM=="/etc/udev/scripts/check-cdrom.sh %k DVD-R", SYMLINK="dvdwriter%e"
+KERNEL=="hd[a-z]", BUS=="ide", SYSFS{removable}=="1", PROGRAM="/etc/udev/scripts/check-cdrom.sh %k DVD-R", SYMLINK+="dvdwriter%e"
+KERNEL=="sr[0-9]*", BUS=="scsi", PROGRAM=="/etc/udev/scripts/check-cdrom.sh %k DVD-R", SYMLINK+="dvdwriter%e"
 
 # rename sr* to scd*
 KERNEL=="sr[0-9]*", BUS=="scsi", NAME="scd%n"
 KERNEL=="hd[a-z]*", BUS=="ide", SYSFS{removable}=="1", NAME{ignore_remove}="%k"
 
 KERNEL=="dvb*", PROGRAM=="/etc/udev/scripts/dvb.sh %k", NAME="%c"
+
+#######################################
+# Persistant block device stuff - begin
+#######################################
+
+# Skip all of this if we are not adding a block device
+ACTION!="add",          GOTO="persistent_end"
+SUBSYSTEM!="block",     GOTO="persistent_end"
+
+# skip accessing removable ide devices, cause the ide drivers are horrible broken
+BUS=="ide", SYSFS{removable}="1", GOTO="no_volume_id"
+BUS=="ide", SYSFS{../removable}="1", GOTO="no_volume_id"
+
+# persistent disk device links /dev/disk/
+KERNEL=="hd*[!0-9]", IMPORT="/sbin/ata_id --export $tempnode"
+KERNEL=="hd*[!0-9]", ENV{ID_SERIAL}=="?*", SYMLINK+="disk/by-id/ata-$env{ID_MODEL}_$env{ID_SERIAL}"
+KERNEL=="hd*[0-9]", IMPORT{parent}=="ID_*", SYMLINK+="disk/by-id/ata-$env{ID_MODEL}_$env{ID_SERIAL}-part%n"
+
+KERNEL=="sd*[!0-9]", SYSFS{ieee1394_id}=="*", IMPORT="/bin/echo -e 'ID_SERIAL=$sysfs{ieee1394_id}\nID_BUS=ieee1394'"
+KERNEL=="sd*[!0-9]", ENV{ID_SERIAL}=="", IMPORT="/sbin/usb_id -x"
+KERNEL=="sd*[!0-9]", ENV{ID_SERIAL}=="", IMPORT="/sbin/scsi_id -g -x -s %p"
+KERNEL=="sd*[!0-9]", ENV{ID_SERIAL}=="", IMPORT="/sbin/scsi_id -g -x -a -s %p"
+KERNEL=="sd*[!0-9]", ENV{ID_SERIAL}=="?*", SYMLINK+="disk/by-id/$env{ID_BUS}-$env{ID_SERIAL}"
+KERNEL=="sd*[0-9]", IMPORT{parent}=="ID_*"
+KERNEL=="sd*[0-9]", ENV{ID_SERIAL}=="?*", SYMLINK+="disk/by-id/$env{ID_BUS}-$env{ID_SERIAL}-part%n"
+
+# Skip id for ram / loop / fd
+KERNEL=="ram*", GOTO="no_volume_id"
+KERNEL=="loop*", GOTO="no_volume_id"
+KERNEL=="fd*", GOTO="no_volume_id"
+
+KERNEL=="*[!0-9]", ENV{ID_TYPE}=="?*", IMPORT="/sbin/path_id %p", SYMLINK+="disk/by-path/$env{ID_PATH}"
+KERNEL=="*[0-9]", IMPORT{parent}=="ID_*"
+KERNEL=="*[0-9]", ENV{ID_PATH}=="?*", SYMLINK+="disk/by-path/$env{ID_PATH}-part%n"
+
+# volume-label/uuid
+KERNEL=="*[!0-9]", SYSFS{removable}=="1", GOTO="no_volume_id"
+KERNEL=="sr*", GOTO="no_volume_id"
+KERNEL=="*[0-9]", IMPORT="/sbin/vol_id --export $tempnode"
+KERNEL=="*[0-9]", ENV{ID_FS_UUID}=="?*", SYMLINK+="disk/by-uuid/$env{ID_FS_UUID}"
+KERNEL=="*[0-9]", ENV{ID_FS_LABEL_SAFE}=="?*", SYMLINK+="disk/by-label/$env{ID_FS_LABEL_SAFE}"
+LABEL="no_volume_id"
+
+LABEL="persistent_end"
+
+#####################################
+# Persistant block device stuff - end
+#####################################
+
+
+
+# Perhaps this should just be for all subsystems?
+
+ACTION=="add", SUBSYSTEM=="pci", MODALIAS=="*", \
+       RUN+="/sbin/modprobe $modalias"
+ACTION=="add", SUBSYSTEM=="usb", MODALIAS=="*", \
+       RUN+="/sbin/modprobe $modalias"
+ACTION=="add", SUBSYSTEM=="pcmcia", MODALIAS=="*", \
+       RUN+="/sbin/modprobe $modalias"
+ACTION=="add", SUBSYSTEM=="pcmcia", MODALIAS=="*", \
+        RUN+="/bin/sh -c 'echo 1 > /sys/$DEVPATH/allow_func_id_match'"
+
+ACTION=="add", SUBSYSTEM=="ieee1394", MODALIAS=="*", \
+       RUN+="/sbin/modprobe $modalias"
+
+ACTION=="add", SUBSYSTEM=="scsi", SYSFS{type}=="[07]", \
+       RUN+="/sbin/modprobe sd_mod"
+ACTION=="add", SUBSYSTEM=="scsi", SYSFS{type}=="14", \
+       RUN+="/sbin/modprobe sd_mod"
+ACTION=="add", SUBSYSTEM=="scsi", SYSFS{type}=="[45]", \
+       RUN+="/sbin/modprobe sr_mod"
+ACTION=="add", SUBSYSTEM=="scsi", SYSFS{type}=="1", SYSFS{vendor}=="Onstream", \
+       SYSFS{model}!="ADR*", RUN+="/sbin/modprobe osst"
+ACTION=="add", SUBSYSTEM=="scsi", SYSFS{type}=="1", SYSFS{vendor}=="Onstream", \
+       SYSFS{model}=="ADR*", RUN+="/sbin/modprobe st"
+ACTION=="add", SUBSYSTEM=="scsi", SYSFS{type}=="1", SYSFS{vendor}!="Onstream", \
+       RUN+="/sbin/modprobe st"
+ACTION=="add", SUBSYSTEM=="scsi", SYSFS{type}=="[23689]", \
+       RUN+="/sbin/modprobe sg"
+
+ACTION=="add", SUBSYSTEM=="firmware", ENV{FIRMWARE}=="*", \
+        RUN+="/sbin/firmware_helper"