| # Refer to devd.conf(5) and devd(8) man pages for the details on how to |
| # run and configure devd. |
| # |
| |
| # NB: All regular expressions have an implicit ^$ around them. |
| # NB: device-name is shorthand for 'match device-name' |
| |
| options { |
| # Each directory directive adds a directory the list of directories |
| # that we scan for files. Files are read-in in the order that they |
| # are returned from readdir(3). The rule-sets are combined to |
| # create a DFA that's used to match events to actions. |
| directory "/etc/devd"; |
| directory "/usr/local/etc/devd"; |
| pid-file "/var/run/devd.pid"; |
| |
| # Setup some shorthand for regex that we use later in the file. |
| #XXX Yes, these are gross -- imp |
| set scsi-controller-regex |
| "(aac|adv|adw|aha|ahb|ahc|ahd|aic|amd|amr|asr|bt|ciss|ct|dpt|\ |
| esp|ida|iir|ips|isp|mlx|mly|mpt|ncr|ncv|nsp|stg|sym|trm|wds)\ |
| [0-9]+"; |
| }; |
| |
| # Note that the attach/detach with the highest value wins, so that one can |
| # override these general rules. |
| |
| # |
| # For ethernet like devices start configuring the interface. Due to |
| # a historical accident, this script is called pccard_ether. |
| # |
| attach 0 { |
| media-type "ethernet"; |
| action "/etc/devd_queue add env IN_HOTPLUG=1 /etc/init.d/net.$device-name start"; |
| }; |
| |
| detach 0 { |
| media-type "ethernet"; |
| action "/etc/devd_queue add env IN_HOTPLUG=1 /etc/init.d/net.$device-name stop"; |
| }; |
| |
| # |
| # Try to start dhclient on Ethernet like interfaces when the link comes |
| # up. Only devices that are configured to support DHCP will actually |
| # run it. No link down rule exists because dhclient automaticly exits |
| # when the link goes down. |
| # |
| notify 0 { |
| match "system" "IFNET"; |
| match "type" "LINK_UP"; |
| media-type "ethernet"; |
| action "/etc/devd_queue add /etc/init.d/net.$subsystem start"; |
| }; |
| notify 0 { |
| match "system" "IFNET"; |
| match "type" "LINK_DOWN"; |
| media-type "ethernet"; |
| action "/etc/devd_queue add /etc/init.d/net.$subsystem stop"; |
| }; |
| |
| # |
| # Like Ethernet devices, but separate because |
| # they have a different media type. We may want |
| # to exploit this later. |
| # |
| #detach 0 { |
| # media-type "802.11"; |
| # action "env IN_HOTPLUG=1 /etc/init.d/net.$device-name stop"; |
| #}; |
| #attach 0 { |
| # media-type "802.11"; |
| # action "env IN_HOTPLUG=1 /etc/init.d/net.$device-name start"; |
| #}; |
| |
| # Not sure how to handle this in Gentoo yet |
| # When a USB Bluetooth dongle appears activate it |
| #attach 100 { |
| # device-name "ubt[0-9]+"; |
| # action "/etc/rc.d/bluetooth start $device-name"; |
| #}; |
| #detach 100 { |
| # device-name "ubt[0-9]+"; |
| # action "/etc/rc.d/bluetooth stop $device-name"; |
| #}; |
| |
| # When a USB keyboard arrives, attach it as the console keyboard. |
| attach 100 { |
| device-name "ukbd0"; |
| action "kbdcontrol -k /dev/ukbd0 < /dev/console"; |
| }; |
| detach 100 { |
| device-name "ukbd0"; |
| action "kbdcontrol -k /dev/kbd0 < /dev/console"; |
| }; |
| |
| # The entry below starts and stops moused when a mouse is plugged in. |
| attach 100 { |
| device-name "psm[0-9]+"; |
| action "/etc/devd_queue add env IN_HOTPLUG=1 /etc/init.d/moused.$device-name start"; |
| }; |
| detach 100 { |
| device-name "psm[0-9]+"; |
| action "/etc/devd_queue add env IN_HOTPLUG=1 /etc/init.d/moused.$device-name stop"; |
| }; |
| attach 100 { |
| device-name "ums[0-9]+"; |
| action "/etc/devd_queue add env IN_HOTPLUG=1 /etc/init.d/moused.$device-name start"; |
| }; |
| detach 100 { |
| device-name "ums[0-9]+"; |
| action "/etc/devd_queue add env IN_HOTPLUG=1 /etc/init.d/moused.$device-name stop"; |
| }; |
| |
| # Notify all users before beginning emergency shutdown when we get |
| # a _CRT or _HOT thermal event and we're going to power down the system |
| # very soon. |
| notify 10 { |
| match "system" "ACPI"; |
| match "subsystem" "Thermal"; |
| match "notify" "0xcc"; |
| action "logger -p kern.emerg 'WARNING: system temperature too high, shutting down soon!'"; |
| }; |
| |
| /* EXAMPLES TO END OF FILE |
| |
| |
| # Examples of notify hooks. A notify is a generic way for a kernel |
| # subsystem to send event notification to userland. |
| # |
| # Here are some examples of ACPI notify handlers. ACPI subsystems that |
| # generate notifies include the AC adapter, power/sleep buttons, |
| # control method batteries, lid switch, and thermal zones. |
| # |
| # Information returned is not always the same as the ACPI notify |
| # events. See the ACPI specification for more information about |
| # notifies. Here is the information returned for each subsystem: |
| # |
| # ACAD: AC line state (0 is offline, 1 is online) |
| # Button: Button pressed (0 for power, 1 for sleep) |
| # CMBAT: ACPI battery events |
| # Lid: Lid state (0 is closed, 1 is open) |
| # Thermal: ACPI thermal zone events |
| # |
| # This example calls a script when the AC state changes, passing the |
| # notify value as the first argument. If the state is 0x00, it might |
| # call some sysctls to implement economy mode. If 0x01, it might set |
| # the mode to performance. |
| notify 10 { |
| match "system" "ACPI"; |
| match "subsystem" "ACAD"; |
| action "/etc/acpi_ac $notify"; |
| }; |
| */ |