summaryrefslogtreecommitdiff
path: root/rules/gentoo/30-kernel-compat.rules
diff options
context:
space:
mode:
Diffstat (limited to 'rules/gentoo/30-kernel-compat.rules')
-rw-r--r--rules/gentoo/30-kernel-compat.rules32
1 files changed, 30 insertions, 2 deletions
diff --git a/rules/gentoo/30-kernel-compat.rules b/rules/gentoo/30-kernel-compat.rules
index 1f767df8d8..d07e7fa1c3 100644
--- a/rules/gentoo/30-kernel-compat.rules
+++ b/rules/gentoo/30-kernel-compat.rules
@@ -1,9 +1,17 @@
# do not edit this file, it will be overwritten on update
-ACTION!="add", GOTO="kernel_compat_end"
+ACTION!="add|change", GOTO="kernel_compat_end"
+
+#
+# rules to workaround bad sysfs timing
+#
+
+ACTION!="add", GOTO="kernel_compat_wait_end"
# workarounds needed to synchronize with sysfs
+# needed for kernels < v2.6.18-rc1
DEVPATH=="/devices/*", ENV{PHYSDEVBUS}=="?*", WAIT_FOR_SYSFS="bus"
+SUBSYSTEM=="scsi", KERNEL=="[0-9]*:[0-9]*", WAIT_FOR_SYSFS="ioerr_cnt"
# needed for kernels <2.6.16
SUBSYSTEM=="net", WAIT_FOR_SYSFS="address"
@@ -11,13 +19,29 @@ SUBSYSTEM=="net", WAIT_FOR_SYSFS="address"
# needed for kernels <2.6.17
SUBSYSTEM=="net", ENV{PHYSDEVDRIVER}=="?*", WAIT_FOR_SYSFS="device/driver"
+LABEL="kernel_compat_wait_end"
+#
+# naming device rules
+#
+# old style usb sysfs devices
# needed for kernels <2.6.22
SUBSYSTEM=="usb_device", PROGRAM="/bin/sh -c 'K=%k; K=$${K#usbdev}; printf bus/usb/%%03i/%%03i $${K%%%%.*} $${K#*.}'", NAME="%c", GROUP="usb", MODE="0664"
+# /sys/class/block will export this
+# needed for kernels <2.6.25-rc1
+SUBSYSTEM!="block", GOTO="block_devtype_end"
+ENV{DEVTYPE}!="?*", ATTR{range}=="?*", ENV{DEVTYPE}="disk"
+ENV{DEVTYPE}!="?*", ATTR{start}=="?*", ENV{DEVTYPE}="partition"
+LABEL="block_devtype_end"
+#
+# module loading rules
+#
+ACTION!="add", GOTO="kernel_compat_end"
+
# this driver is broken and should not be loaded automatically
# http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=398962
# needed for kernels <2.6.21
@@ -26,6 +50,11 @@ SUBSYSTEM=="platform", ENV{MODALIAS}=="i82365", ENV{MODALIAS}=""
# No need for more code, as MODALIAS is present
ENV{MODALIAS}=="?*", GOTO="kernel_compat_end"
+# needed for kernel <2.6.27-rc5
+# acpi will do on newer kernels
+SUBSYSTEM=="pnp", DRIVER!="?*", \
+ RUN{ignore_error}+="/bin/sh -c '/sbin/modprobe -a $$(while read id; do echo pnp:d$$id; done < /sys$devpath/id)'"
+
# needed for kernels <2.6.22
SUBSYSTEM!="scsi_device", GOTO="kernel_compat_end"
@@ -44,4 +73,3 @@ SUBSYSTEM!="scsi_device", GOTO="kernel_compat_end"
LABEL="kernel_compat_end"
-