X-Git-Url: http://gitweb.hugovil.com/?a=blobdiff_plain;f=stage2%2Fmisc%2Facpi%2Fsuspend2ram.sh;h=a98df77be38cb9132574541ce7260000cd04f284;hb=1ad4e40910bd4db07722b4503cc682d9467d5f55;hp=f7db74c01535c11d7640e6580afe0a25cb3b0d2a;hpb=07ffca36a11350048d0e8f4a64b4ef86509df428;p=hvlinux.git diff --git a/stage2/misc/acpi/suspend2ram.sh b/stage2/misc/acpi/suspend2ram.sh index f7db74c..a98df77 100755 --- a/stage2/misc/acpi/suspend2ram.sh +++ b/stage2/misc/acpi/suspend2ram.sh @@ -1,10 +1,36 @@ #!/bin/sh -if [ -f /proc/acpi/button/lid/LID/state ]; then - if grep -q open /proc/acpi/button/lid/LID/state; then - # Do not act on lid opened event. Only on lid closed. - exit 0 - fi +case "$1" in + button-sleep) + logger "Sleep button pressed" + ;; + button-lid) + if [ -f /proc/acpi/button/lid/LID/state ]; then + if grep -q open /proc/acpi/button/lid/LID/state; then + logger "Lid opened detected, do nothing" + # Do not act on lid opened event. Only on lid closed. + exit 0 + fi + + logger "Lid closed detected" + fi + ;; + *) + logger "Unknown event: ${1}" + ;; +esac + +logger "Going to sleep" + +XSCREENSAVER_ACTIVE="$(pidof /usr/bin/xscreensaver)" + +# Check if xscreensaver is running. if not, just skip on. +if [ "x${XSCREENSAVER_ACTIVE}" != "x" ]; then + # Run the lock command as the user who owns xscreensaver process, + # and not as root, which won't work. + su "$(ps aux | grep xscreensaver | grep -v grep | grep ${XSCREENSAVER_ACTIVE} | awk '{print $1}' )" \ + -c "/usr/bin/xscreensaver-command -lock" & + sleep 1 fi # discover video card's ID @@ -22,7 +48,12 @@ sync cat /proc/bus/pci/$ID > $TMP_FILE # Stopping network. -/etc/rc.d/init.d/named stop + +# Check if NFS server functionality is desired +if [ -f /etc/rc.d/init.d/named ]; then + /etc/rc.d/init.d/named stop +fi + /etc/rc.d/init.d/network stop echo "Entering suspend mode" @@ -36,8 +67,11 @@ echo "Resuming" # on resume cat $TMP_FILE > /proc/bus/pci/$ID -/etc/rc.d/init.d/network start -/etc/rc.d/init.d/named start +/etc/rc.d/init.d/network start & + +if [ -f /etc/rc.d/init.d/named ]; then + /etc/rc.d/init.d/named start +fi # remove temporary file rm -f $TMP_FILE