X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=rules%2Fgentoo%2F30-kernel-compat.rules;h=d07e7fa1c32d1ff34b4297dba18e3dac987206d9;hp=1f767df8d8613e7380b30732f18fe15e092bd856;hb=2c7b88c4a55426087955a12aad33c1935e639876;hpb=282988c4f8a85c28468e6442e86efe51dc71cc93 diff --git a/rules/gentoo/30-kernel-compat.rules b/rules/gentoo/30-kernel-compat.rules index 1f767df8d..d07e7fa1c 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" -