I have installed Linux Mint 22 in a DELL laptop with a buggy ACPI implementation (the kernel complains about it during boot). The laptop hangs if it goes to sleep (I tried various Linux distros/kernel-versions, the result is the same).

Because of that, I have disabled SLEEP in the firmware (latest version for that laptop btw). So basically, when you close the lid, nothing happens (it just locks the screen).

However, sometimes you might be in a hurry and you close the lid to do something else, and then you forget about it. The result would be for the battery to run dry, which eventually destroys the battery.

My question is: what would be the best way to setup an audible alarm if the battery reaches 20%?

  • Eugenia@lemmy.mlOP
    link
    fedilink
    English
    arrow-up
    6
    ·
    edit-2
    1 month ago

    Ok, I managed it by myself after a bit of tinkering. This is the bash script:

    #!/bin/bash
    while true
        do 
            battery_level=`cat /sys/class/power_supply/BAT0/capacity`
            battery_status=`cat /sys/class/power_supply/BAT0/status`
            if [ $battery_status = "Discharging" ] && [ $battery_level -lt 21 ];
            then
                /usr/bin/aplay  /home/eugenia/Music/alarm.wav
            fi
           sleep 120
        done
    

    Obviously change the path the .wav audio file to suit yours (I downloaded mine from the internet). Then, save the file (in my case, I named it battery.sh), make the script file executable ( chmod +x battery.sh via the terminal, or via the file manager).

    Then add it to the Startup Applications settings panel on your distro (usually gnome and cinnamon have one). The alarm will sound if the battery reaches below 21%.

    • nous@programming.dev
      link
      fedilink
      English
      arrow-up
      6
      ·
      1 month ago

      Worth running shell scripts though https://www.shellcheck.net/ (has a cli as well). Finds lots of common issues that can blow up scripts when input is not what you expect. With links to why they make the suggestions they do.

      Line 4:
              battery_level=`cat /sys/class/power_supply/BAT0/capacity`
                            ^-- SC2006 (style): Use $(...) notation instead of legacy backticks `...`.
      
      Did you mean: (apply this, apply all SC2006)
              battery_level=$(cat /sys/class/power_supply/BAT0/capacity)
       
      Line 5:
              battery_status=`cat /sys/class/power_supply/BAT0/status`
                             ^-- SC2006 (style): Use $(...) notation instead of legacy backticks `...`.
      
      Did you mean: (apply this, apply all SC2006)
              battery_status=$(cat /sys/class/power_supply/BAT0/status)
       
      Line 6:
              if [ $battery_status = "Discharging" ] && [ $battery_level -lt 21 ];
                   ^-- SC2086 (info): Double quote to prevent globbing and word splitting.
                                                          ^-- SC2086 (info): Double quote to prevent globbing and word splitting.
      
      Did you mean: (apply this, apply all SC2086)
              if [ "$battery_status" = "Discharging" ] && [ "$battery_level" -lt 21 ];
      
        • nous@programming.dev
          link
          fedilink
          English
          arrow-up
          6
          arrow-down
          1
          ·
          1 month ago

          The problem with bash scripts is they tend to explode in unexpected ways when thing don’t go as intended. This could be one of the command you run returning some expected or not output which might work now but might not in the future. Best to program bash defensively.

    • Deckweiss@lemmy.world
      link
      fedilink
      arrow-up
      2
      ·
      edit-2
      1 month ago

      Since you say

      change the path the .wav audio file

      fyi, the sys BAT paths are also different per laptop. Just in case it doesn’t work for somebody else or for you on a different laptop.

  • IanTwenty@lemmy.world
    link
    fedilink
    arrow-up
    2
    ·
    1 month ago

    I seem to get pop-up notifications for free in GNOME/Fedora by setting these levels in /etc/UPower/UPower.conf:

    UsePercentageForPolicy=true
    PercentageLow=50
    PercentageCritical=20
    PercentageAction=10
    

    I think you can also configure the system to take action when it reaches the lowest level with e.g.

    # The action to take when "TimeAction" or "PercentageAction" above has been
    # reached for the batteries (UPS or laptop batteries) supplying the computer
    CriticalPowerAction=PowerOff
    

    However I don’t know how to get these GNOME “Power” notifications to play an audible sound (without turning on notification sounds for ALL notifications). The best I could find is this: David Bazile / gaudible · GitLab

    There’s talk of better control of sound notifications in GNOME 47+, but looks like nothing much has landed yet: Notifications in 46 and beyond – GNOME Shell & Mutter

  • IHave69XiBucks@lemmygrad.ml
    link
    fedilink
    arrow-up
    2
    arrow-down
    1
    ·
    1 month ago

    I would first attempt to fix the problem by flashing the bios with the newest version. What you are describing sounds a lot like a common issue with how deep sleep works. Its on the manufacturer to fix it which Dell is typically pretty good about.

    If that doesnt work for some reason you can get an applet that will shut down your pc when the battery gets too low for you. Theres a few that work just right click the panel and search for battery applets.