Test more hibernation fixes
This commit is contained in:
parent
3a6b8c9b92
commit
8588887c16
2 changed files with 47 additions and 0 deletions
|
@ -3,6 +3,7 @@
|
||||||
inputs.nixos-hardware.nixosModules.framework-13-7040-amd
|
inputs.nixos-hardware.nixosModules.framework-13-7040-amd
|
||||||
(modulesPath + "/installer/scan/not-detected.nix")
|
(modulesPath + "/installer/scan/not-detected.nix")
|
||||||
./disks.nix
|
./disks.nix
|
||||||
|
./hibernate.nix
|
||||||
../../common/services/tailscale-autoconnect.nix
|
../../common/services/tailscale-autoconnect.nix
|
||||||
../../common/modules/secureboot.nix
|
../../common/modules/secureboot.nix
|
||||||
../../common/modules/udev-rules.nix
|
../../common/modules/udev-rules.nix
|
||||||
|
|
46
nixos/hosts/nixos-framework/hibernate.nix
Normal file
46
nixos/hosts/nixos-framework/hibernate.nix
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
{ config, pkgs, ... }:
|
||||||
|
|
||||||
|
let
|
||||||
|
hibernateEnvironment = {
|
||||||
|
HIBERNATE_SECONDS = "10";
|
||||||
|
HIBERNATE_LOCK = "/var/run/autohibernate.lock";
|
||||||
|
};
|
||||||
|
in {
|
||||||
|
|
||||||
|
systemd.services."awake-after-suspend-for-a-time" = {
|
||||||
|
description = "Sets up the suspend so that it'll wake for hibernation only if not on AC power";
|
||||||
|
wantedBy = [ "suspend.target" ];
|
||||||
|
before = [ "systemd-suspend.service" ];
|
||||||
|
environment = hibernateEnvironment;
|
||||||
|
script = ''
|
||||||
|
if [ $(cat /sys/class/power_supply/ACAD/online) -eq 0 ]; then
|
||||||
|
curtime=$(date +%s)
|
||||||
|
echo "$curtime $1" >> /tmp/autohibernate.log
|
||||||
|
echo "$curtime" > $HIBERNATE_LOCK
|
||||||
|
${pkgs.utillinux}/bin/rtcwake -m no -s $HIBERNATE_SECONDS
|
||||||
|
else
|
||||||
|
echo "System is on AC power, skipping wake-up scheduling for hibernation." >> /tmp/autohibernate.log
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
serviceConfig.Type = "simple";
|
||||||
|
};
|
||||||
|
|
||||||
|
systemd.services."hibernate-after-recovery" = {
|
||||||
|
description = "Hibernates after a suspend recovery due to timeout";
|
||||||
|
wantedBy = [ "suspend.target" ];
|
||||||
|
after = [ "systemd-suspend.service" ];
|
||||||
|
environment = hibernateEnvironment;
|
||||||
|
script = ''
|
||||||
|
curtime=$(date +%s)
|
||||||
|
sustime=$(cat $HIBERNATE_LOCK)
|
||||||
|
rm $HIBERNATE_LOCK
|
||||||
|
if [ $(($curtime - $sustime)) -ge $HIBERNATE_SECONDS ] ; then
|
||||||
|
systemctl hibernate
|
||||||
|
else
|
||||||
|
${pkgs.utillinux}/bin/rtcwake -m no -s 1
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
serviceConfig.Type = "simple";
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in a new issue