Symbian3/PDK/Source/GUID-29B84A67-9DB7-5F4C-A4D1-A3BDC69015A8.dita
changeset 1 25a17d01db0c
child 3 46218c8b8afa
equal deleted inserted replaced
0:89d6a7a84779 1:25a17d01db0c
       
     1 <?xml version="1.0" encoding="utf-8"?>
       
     2 <!-- Copyright (c) 2007-2010 Nokia Corporation and/or its subsidiary(-ies) All rights reserved. -->
       
     3 <!-- This component and the accompanying materials are made available under the terms of the License 
       
     4 "Eclipse Public License v1.0" which accompanies this distribution, 
       
     5 and is available at the URL "http://www.eclipse.org/legal/epl-v10.html". -->
       
     6 <!-- Initial Contributors:
       
     7     Nokia Corporation - initial contribution.
       
     8 Contributors: 
       
     9 -->
       
    10 <!DOCTYPE concept
       
    11   PUBLIC "-//OASIS//DTD DITA Concept//EN" "concept.dtd">
       
    12 <concept id="GUID-29B84A67-9DB7-5F4C-A4D1-A3BDC69015A8" xml:lang="en"><title>Additional
       
    13 System Wide Power States</title><shortdesc>A base port can add new power states to improve power management
       
    14 for phone hardware. </shortdesc><prolog><metadata><keywords/></metadata></prolog><conbody>
       
    15 <p>The Kernel defines three system wide power states. A base port can add
       
    16 new power states to improve power management for phone hardware. </p>
       
    17 <p>The generic system wide power states that are defined are <i>Active</i>, <i>Standby</i> and <i>Off</i>.
       
    18 Any additional sub-states of the <i>Active</i> power state must be wholly
       
    19 managed by the base port. These states may not need to be declared explicitly
       
    20 and may result from peripherals, or groups of peripherals, having moved to
       
    21 their low power state (see also <xref href="GUID-1D3E61BD-C09D-51FD-A10B-22392FDAEFEC.dita#GUID-1D3E61BD-C09D-51FD-A10B-22392FDAEFEC/GUID-DCB8EA90-9B5F-5BA1-8D22-124980AC6B34">moving
       
    22 to their low power state</xref>). The device will then “trickle“ into one
       
    23 of these sub-states instead of transitioning into them as a result of a user
       
    24 action or system policy decision. </p>
       
    25 <p>Usually, the transition of the system into one of the additional low power
       
    26 states happens when the CPU enters the idle mode. The transition may be automatic
       
    27 and wholly managed by the ASSP hardware or may result from an action taken
       
    28 by the software routine that prepares the CPU to go to idle mode. </p>
       
    29 <section id="GUID-22A20CBB-6BF2-495F-B32C-63834DD4624C"><title>Sleeping in idle mode</title> <p>An example of this is when
       
    30 the base port uses the idle mode to put the CPU and the device into hardware
       
    31 “Sleep” mode similar to that which can be achieved with a transition to <i>Standby</i> mode
       
    32 as described in the implementation issues for <xref href="GUID-34D1D0BF-20DE-5677-A067-8FF9DD72E703.dita#GUID-34D1D0BF-20DE-5677-A067-8FF9DD72E703/GUID-1F77C71C-D226-58BB-ABAE-43F958CC0C61">implementing
       
    33 DPowerController::PowerDown()</xref>  </p> <p>When called, the power controller’s <xref href="GUID-34D1D0BF-20DE-5677-A067-8FF9DD72E703.dita#GUID-34D1D0BF-20DE-5677-A067-8FF9DD72E703/GUID-E2A072D0-A67F-5E6D-81ED-CFD77B6ED4F1">DPowerController::CpuIdle() </xref> implementation
       
    34 could take the necessary steps to prepare the CPU and the platform to go to
       
    35 “Sleep”. </p> <p>There is a balance between the power savings obtained from
       
    36 moving the CPU and platform into “Sleep” mode in Idle and the performance
       
    37 hit resulting from spending time restoring the status after coming out of
       
    38 “Sleep” mode. Usually the <codeph>CpuIdle()</codeph> routine investigates
       
    39 the timer queue (using <xref href="GUID-C54D99AA-FF6E-3023-8260-8F5A88FBFBE0.dita#GUID-C54D99AA-FF6E-3023-8260-8F5A88FBFBE0/GUID-69103F26-2C21-3ECA-9DB5-C31A41F6C238"><apiname>NTimerQ::IdleTime()</apiname></xref>) for the next
       
    40 timer expiration and decides to move or not to move the CPU and platform into
       
    41 “Sleep” mode based on how much time there is before the next timer expiration.
       
    42 The threshold above which it is considered productive to move into “Sleep”
       
    43 is dependent on the base port. </p> <p>The decision to move into “Sleep” mode
       
    44 may also be based on the current level of activity, or collected metrics on
       
    45 the length of time spent in Idle, or other historical information. This can
       
    46 be implemented entirely by the base port, or it may require the services of
       
    47 an external component (such as, for example, Speed Management). </p> <p>The
       
    48 transition to a hardware “Sleep” mode may also depend on shared peripherals
       
    49 being in a particular state, for example, no pending requests from other peripherals.
       
    50 This means that the power controller may need to check with the peripheral
       
    51 driver before initiating the change. The power controller could use the ASSP/Variant
       
    52 method to access the resource manager and check the usage of a shared peripheral
       
    53 using its <codeph>GetCount()</codeph> API. </p> <p>The decision to move into
       
    54 “Sleep” mode could be dependent on a number of peripherals (shared and not
       
    55 shared) being in Standby and a number of controllable power resources being
       
    56 turned off. Therefore the power controller may also need to check with the
       
    57 resource manager (through the Variant or ASSP) for the state of a specific
       
    58 set of controllable power resources (using the <codeph>ResourceManager::GetResourceState()</codeph> API). </p> <p>On
       
    59 going to “Sleep”, an action or set of actions might need to be taken that
       
    60 would affect the whole platform. An example of this is when DRAM is put into
       
    61 self-refresh mode on entering the CPU Idle mode after all peripherals that
       
    62 might access it (including the LCD controller and DSP) are in low power state.
       
    63 Unused DRAM banks may also be powered down. </p> <p>The following diagram
       
    64 exemplifies how the evolution of system power would look like on a system
       
    65 when the most power saving “Sleep” mode can only be reached – from Idle -
       
    66 when Peripherals A, B and C are already in their low power mode. On going
       
    67 to the most power saving “Sleep” mode, additional actions can be taken to
       
    68 lower the system power level: </p> <fig id="GUID-05ED7A51-E1A1-5D2E-AF81-A11A9EC80D7F">
       
    69 <title>System power use over time</title>
       
    70 <image href="GUID-BF157EE2-B680-554A-AE32-69C652B61FA6_d0e380108_href.png" placement="inline"/>
       
    71 </fig> <ul>
       
    72 <li id="GUID-FD4E14B6-9471-5A91-B215-E42595645A94"><p>The system is active
       
    73 when a request for service is made on peripheral A; the peripheral driver
       
    74 for peripheral A requests its transition to operational state increasing the
       
    75 system power requirement (a). </p> </li>
       
    76 <li id="GUID-FB7914E6-13BC-57C7-BA02-A7DAA3A4F968"><p>After a period of activity
       
    77 related to servicing the request, the system enters the idle thread; in <codeph>CpuIdle()</codeph> the
       
    78 time for the next timer expiration is investigated and is found to be long
       
    79 enough to send the system to sleep, powering down peripherals A, B and C to
       
    80 their low power state and other system resources (b). </p> </li>
       
    81 <li id="GUID-44F96E35-4DA5-5A34-8D12-6E99D4B96856"><p>The timer expires and
       
    82 the system wakes up to the same power level as before (c). </p> </li>
       
    83 <li id="GUID-61124A91-05C6-589D-884B-F4CE5FF9A970"><p>The inactivity timer
       
    84 implemented in the peripheral driver for peripheral A expires: the peripheral
       
    85 is transitioned to the low power state (d). </p> </li>
       
    86 <li id="GUID-1A1BF422-6C3A-5F90-BB8E-E84A31478723"><p>At (e) the system enters
       
    87 the idle thread again: the timer queue is investigated and then enters sleep
       
    88 mode, waking up again when an interrupt occurs (f). </p> </li>
       
    89 <li id="GUID-14C0126F-4333-5A96-93CE-7BBA17A422EF"><p>The inactivity timer
       
    90 associated with the peripheral drive for peripheral B expires and the peripheral
       
    91 is transitioned to its low power state (g). </p> </li>
       
    92 <li id="GUID-3CC1A70B-832A-53EC-BD04-9FA58F58F97D"><p>On the next call to <codeph>CpuIdle()</codeph> the
       
    93 time for the next timer expiration is not long enough to power off peripherals
       
    94 and other system resources: only limited power savings can be made (h) until
       
    95 the system wakes up again (i). </p> </li>
       
    96 <li id="GUID-FC9FE747-CF6D-501A-B36F-4776F53E5317"><p>Finally, the inactivity
       
    97 timer for peripheral C expires and the peripheral is transitioned to low power
       
    98 state (j). On reaching another period of system idle all conditions are met
       
    99 to send the system to the deepest sleep mode available accompanied by the
       
   100 switching off other power resources (k). </p> </li>
       
   101 <li id="GUID-6E283027-9516-50AA-94A7-BEA5C1A1E115"><p>On waking up (l) the
       
   102 system resources are restored to the same power level as before. </p> </li>
       
   103 </ul> <p>Any transition to and from these low power states must be transparent
       
   104 to the rest of the system. A transparent transition is one that can be instantly
       
   105 reversed, perhaps automatically in hardware, and has no noticeable impact
       
   106 on system performance. In other words, it should be possible to wake the processor
       
   107 up and move the entire device to Active Mode as if coming from a “normal”
       
   108 Idle Mode. </p> <p>To perform a system wide power change which is not transparent,
       
   109 peripherals that may be affected by the transition would need to be examined,
       
   110 and interfaces would have to be provided so that the users of these peripherals
       
   111 could query the peripheral and allow or disallow the system transition into
       
   112 that state. </p> </section>
       
   113 </conbody></concept>