User:Magick777/Opportunistic Power Saving

(Disable WiFi when not needed)
 
(28 intermediate revisions not shown)
Line 1: Line 1:
-
<source lang="text">
+
= Opportunistic Power Saving =
-
#!/bin/sh
+
-
# Test the current radio mode and abort if in 3G or dual mode already
+
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.
-
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 | grep "byte [02]"`
+
-
if [ ! -z "$TEST" ]
+
-
then
+
-
echo "Phone is already in either 3G or dual mode, aborting."
+
-
exit 1
+
-
fi
+
-
# Test whether the phone is on a call, if it is then don't mess with it
+
== CPU frequency scaling / underclocking ==
-
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 "uint32 0"`
+
-
#if phone is on call, grep filters out any call status but 0/idle, so we get a zero length output
+
-
if [ -z "$TEST" ]
+
-
then
+
-
echo "Phone is making or receiving a call, aborting."
+
-
exit 1
+
-
fi
+
-
#Before we change the radio mode, check that we're not on WiFi
+
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.
-
TEST=`grep 1 /tmp/onwifi`
+
-
if [ ! -z "$TEST" ]
+
== Maintain phone in GSM mode by default when on battery ==
-
then
+
-
echo "Phone is connected via WiFi, no point autoswitching to dual mode."
+
-
exit 1
+
-
fi
+
 +
=== Status ===
-
# Make the change to 3G
+
* Switch to 2G on lock done, works for me, needs review for more blockers
-
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:0
+
* Switch back to 3G works for browser but needs some work
-
</source>
+
** Move from detecting browser launch to a generic application launch handler
-
==/usr/bin/set2g==
+
=== Function specification ===
-
<source lang="text">
+
-
#!/bin/sh
+
-
# This script is intended to be run indirectly from dbus-scripts and to be triggered on
+
* Switch to GSM mode opportunistically when all seems to be quiet
-
# phone lock. It will then attempt to determine whether it makes sense to change the radio
+
** trigger analysis on phone locked
-
# mode to GSM in order to save battery life.
+
** 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
-
# Test the current radio mode and abort if we're in GSM mode already
 
-
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$
+
* Switch automatically to 3G or dual mode (which?) when something requires it
-
if [ ! -z "$TEST" ]
+
** no sense in triggering on device unlock, wait until needed
-
then
+
** check for blockers
-
echo "Phone is already in 2G mode, aborting."
+
*** don't change anything if we're already in the target radio mode
-
exit 1
+
*** don't change anything if we're already using WiFi
-
fi
+
*** 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
-
# If we're on charge, we don't need to save battery so don't downgrade.
+
== Disable WiFi when not needed ==
-
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
+
=== Take down WiFi when not needed ===
-
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
 
-
if [ -z "$TEST" ]
 
-
then
 
-
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
 
-
## kill this script whilst it's sleeping and leave 3G intact.
 
-
echo "Scheduling switch to 2G in 30 seconds..."
+
=== Restore WiFi ===
-
sleep 30
+
 +
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.
-
# Make the actual change to 2G radio mode
+
So we need to
-
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
+
* trigger when the phone is placed on charge
-
echo "Phone set to 2G mode."
+
* enable WiFi interface
-
exit 0
+
* attempt autoconnect to home wireless network
-
 
+
* consider whether to disable WiFi if not successful in reaching home network
-
</source>
+

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