Difference between revisions of "How to configure acpid"
(→Example: go to sleep on lid close) |
|||
Line 61: | Line 61: | ||
The console switching code in this script is a special solution for | The console switching code in this script is a special solution for | ||
[[Problem with LCD backlight remaining on during ACPI sleep|a problem where the backlight doesn't switch off]] | [[Problem with LCD backlight remaining on during ACPI sleep|a problem where the backlight doesn't switch off]] | ||
− | on the T30 and some other models. Before going to sleep, these models switch to console mode which causes the | + | on the {{T30}} and some other models. Before going to sleep, these models switch to console mode which causes the |
backlight to come back on. So we preemptively switch to console mode and turn off the backlight using [[radeontool]] | backlight to come back on. So we preemptively switch to console mode and turn off the backlight using [[radeontool]] | ||
before going to sleep. | before going to sleep. |
Revision as of 11:46, 14 May 2005
Basically, acpid just executes scripts residing in /etc/acpi/actions. Which script to launch at which event is configured in several files in /etc/acpi/events. {{{2}}} man acpid
holds detailed information on how to configure acpid.
The ibm-acpi packages includes example scripts in the config folder inside the tarball. They are a good starting point to adjust them to your needs. You also might want to have a look at the ACPI section of the Configs page and you can find information about the event strings ibm-acpi generates for certain keys at the Special Keys HOWTO.
Example: go to sleep on lid close
To make the ThinkPad go to sleep when you close the lid, you need to add an event handler for the lid event and an action script that takes care of going to sleep and resuming.
The event script needs to be created within /etc/acpi/events and can have any name you like.
In this case we call it lid because it will trigger the lid event. Do # vi /etc/acpi/events/lid
and make it look like this:
event=button/lid action=/etc/acpi/actions/sleep.sh %e
The "event" line is a regular expression specifying the events we're interested in. You can determine what the event strings are from looking at /var/log/acpid after trying to suspend, close the lid, etc. . You can find information about the event strings ibm-acpi generates for certain keys at the Special Keys HOWTO.
The "action" line is the command to be executed when these events are dispatched. In this example we call the sleep.sh script residing in /etc/acpi/actions and pass the event description text using the %e placeholder.
.
Our example /etc/acpi/actions/sleep.sh script looks as follows:
#!/bin/sh # if launched through a lid event and lid is open, do nothing echo "$1" | grep "button/lid" && grep -q open /proc/acpi/button/lid/LID/state && exit 0 # sync filesystem and clock sync /sbin/hwclock --systohc # switch to console FGCONSOLE=`fgconsole` chvt 6 /usr/sbin/radeontool light off # go to sleep echo -n "mem" > /sys/power/state # readjust the clock (it might be off a bit after suspend) /sbin/hwclock --adjust /sbin/hwclock --hctosys # turn on the backlight and switch back to X radeontool light on chvt $FGCONSOLE
The lid generates an event for both opening and closing thus requiring that we check it's state and only act if it's closed.
Note that the echo -n "mem" > /sys/power/state
line does not return until we are revived. So there is
only one event generated and there is no need to check the state of
anything.
The console switching code in this script is a special solution for a problem where the backlight doesn't switch off on the T30 and some other models. Before going to sleep, these models switch to console mode which causes the backlight to come back on. So we preemptively switch to console mode and turn off the backlight using radeontool before going to sleep.