User:Magick777/Opportunistic Power Saving

(/usr/bin/set2g)
(Disable WiFi when not needed)
 
(29 intermediate revisions not shown)
Line 1: Line 1:
-
==/usr/bin/set2g==
+
= Opportunistic Power Saving =
-
<source lang="text">
+
-
#!/bin/sh
+
-
# This script is intended to be run indirectly from dbus-scripts and to be triggered on
+
This page aims to set forth a design for opportunistic power saving on the Nokia N900. Existing power-saver scripts and applets allow the user to toggle settings manually and much has been written about automation of certain events through DBUS. This page is an attempt to tie it all together.
-
# phone lock. It will then attempt to determine whether it makes sense to change the radio
+
-
# mode to GSM in order to save battery life.
+
-
# Test the current radio mode and abort if we're in GSM mode already
+
== CPU frequency scaling / underclocking ==
-
TEST=`dbus-send --system --type=method_call --print-reply --dest=com.nokia.phone.net /com/nokia/phone/net Phone.Net.get_selected_radio_access_technology | g$
+
This is already documented on the [[Overclocking]] page and is my starting point for building an opportunistic power saving script, based on phone lock / unlock. Credits and thanks to Fecn for getting us this far.
-
if [ ! -z "$TEST" ]
+
-
then
+
-
echo "Phone is already in 2G mode, aborting."
+
-
exit 1
+
-
fi
+
-
# If we're on charge, we don't need to save battery so don't downgrade.
+
== Maintain phone in GSM mode by default when on battery ==
-
TEST=`grep 1 /tmp/oncharge`
+
-
if [ ! -z "$TEST" ]
+
-
then
+
-
# it's a non-zero value so we're on charge, abort gracefully
+
-
echo "Phone is on charge, no need to set 2G mode, aborting."
+
-
exit 1
+
-
fi
+
-
# Test whether the phone is on a call, if it is don't mess with it
+
=== Status ===
-
TEST=`dbus-send --system --type=method_call --print-reply --dest=com.nokia.csd.Call /com/nokia/csd/call/1 com.nokia.csd.Call.Instance.GetStatus | grep "uint$
+
-
#if phone is on call, grep filters out any call status but 0/idle, so we get a zero length output
+
* Switch to 2G on lock done, works for me, needs review for more blockers
-
if [ -z "$TEST" ]
+
* Switch back to 3G works for browser but needs some work
-
then
+
** Move from detecting browser launch to a generic application launch handler
-
echo "Phone is making or receiving a call, aborting."
+
-
exit 1
+
-
fi
+
-
## Adding a 30 cooling off period means that if the device gets unlocked again within 30 seconds, we can
+
=== Function specification ===
-
## kill this script whilst it's sleeping and leave 3G intact.
+
-
echo "Scheduling switch to 2G in 30 seconds..."
+
* Switch to GSM mode opportunistically when all seems to be quiet
-
sleep 30
+
** trigger analysis on phone locked
 +
** first check for blockers, most common first
 +
*** don't change anything if we're in the desired radio mode
 +
*** don't change anything if we're on charge and not saving battery
 +
*** don't change anything if we're on a GSM call
 +
*** don't change anything if we have blocker applications or connections running
 +
**** but blockers don't apply if we're on WiFi
 +
**** if we're on 3G then check for following blockers
 +
***** location-daemon active (GPS in use) NOT DONE YET
 +
***** SIP / Skype / GTalk calls (VoIP in use) NOT DONE YET
 +
*** don't change anything if the user didn't want the phone to lock anyway
 +
**** cooling off period during which device unlock cancels radio switch
 +
** perform any final sanity checks
 +
*** recheck that we're still not on a call after our cooling off period
 +
** then make the switch to GSM mode
-
# Make the actual change to 2G radio mode
+
* Switch automatically to 3G or dual mode (which?) when something requires it
 +
** no sense in triggering on device unlock, wait until needed
 +
** check for blockers
 +
*** don't change anything if we're already in the target radio mode
 +
*** don't change anything if we're already using WiFi
 +
*** don't change anything if we're on a voice call
 +
** trigger on events that may require a data connection i.e.
 +
*** launch pplication (via hildon desktop) - which apps?
 +
**** browser
 +
**** SIP client
 +
**** maps
 +
*** set presence to Online
 +
*** open Modest e-mail account
 +
*** access Internet radio stream
-
run-standalone.sh dbus-send --system --type=method_call --dest=com.nokia.phone.net /com/nokia/phone/net Phone.Net.set_selected_radio_access_technology byte:1
+
== Disable WiFi when not needed ==
-
echo "Phone set to 2G mode."
+
-
exit 0
+
-
</source>
+
=== Take down WiFi when not needed ===
 +
 
 +
 
 +
 
 +
=== Restore WiFi ===
 +
 
 +
There are few circumstances in which I want the phone to decide for itself to reenable WiFi, however it would be helpful to do so when I arrive home and put it on charge.
 +
 
 +
So we need to
 +
 
 +
* trigger when the phone is placed on charge
 +
* enable WiFi interface
 +
* attempt autoconnect to home wireless network
 +
* consider whether to disable WiFi if not successful in reaching home network

Latest revision as of 00:57, 21 July 2010

Contents

[edit] Opportunistic Power Saving

This page aims to set forth a design for opportunistic power saving on the Nokia N900. Existing power-saver scripts and applets allow the user to toggle settings manually and much has been written about automation of certain events through DBUS. This page is an attempt to tie it all together.

[edit] CPU frequency scaling / underclocking

This is already documented on the Overclocking page and is my starting point for building an opportunistic power saving script, based on phone lock / unlock. Credits and thanks to Fecn for getting us this far.

[edit] Maintain phone in GSM mode by default when on battery

[edit] Status

  • Switch to 2G on lock done, works for me, needs review for more blockers
  • Switch back to 3G works for browser but needs some work
    • Move from detecting browser launch to a generic application launch handler

[edit] Function specification

  • Switch to GSM mode opportunistically when all seems to be quiet
    • trigger analysis on phone locked
    • first check for blockers, most common first
      • don't change anything if we're in the desired radio mode
      • don't change anything if we're on charge and not saving battery
      • don't change anything if we're on a GSM call
      • don't change anything if we have blocker applications or connections running
        • but blockers don't apply if we're on WiFi
        • if we're on 3G then check for following blockers
          • location-daemon active (GPS in use) NOT DONE YET
          • SIP / Skype / GTalk calls (VoIP in use) NOT DONE YET
      • don't change anything if the user didn't want the phone to lock anyway
        • cooling off period during which device unlock cancels radio switch
    • perform any final sanity checks
      • recheck that we're still not on a call after our cooling off period
    • then make the switch to GSM mode


  • Switch automatically to 3G or dual mode (which?) when something requires it
    • no sense in triggering on device unlock, wait until needed
    • check for blockers
      • don't change anything if we're already in the target radio mode
      • don't change anything if we're already using WiFi
      • don't change anything if we're on a voice call
    • trigger on events that may require a data connection i.e.
      • launch pplication (via hildon desktop) - which apps?
        • browser
        • SIP client
        • maps
      • set presence to Online
      • open Modest e-mail account
      • access Internet radio stream

[edit] Disable WiFi when not needed

[edit] Take down WiFi when not needed

[edit] Restore WiFi

There are few circumstances in which I want the phone to decide for itself to reenable WiFi, however it would be helpful to do so when I arrive home and put it on charge.

So we need to

  • trigger when the phone is placed on charge
  • enable WiFi interface
  • attempt autoconnect to home wireless network
  • consider whether to disable WiFi if not successful in reaching home network