diff options
author | Deepthi Dharwar <deepthi@linux.vnet.ibm.com> | 2011-10-28 06:50:09 -0400 |
---|---|---|
committer | Len Brown <len.brown@intel.com> | 2011-11-06 21:13:30 -0500 |
commit | e978aa7d7d57d04eb5f88a7507c4fb98577def77 (patch) | |
tree | d6d6dfe1dba4d4749c7eafe348351aa499c3c5eb /arch/arm/mach-kirkwood/cpuidle.c | |
parent | c3b92c8787367a8bb53d57d9789b558f1295cc96 (diff) |
cpuidle: Move dev->last_residency update to driver enter routine; remove dev->last_state
Cpuidle governor only suggests the state to enter using the
governor->select() interface, but allows the low level driver to
override the recommended state. The actual entered state
may be different because of software or hardware demotion. Software
demotion is done by the back-end cpuidle driver and can be accounted
correctly. Current cpuidle code uses last_state field to capture the
actual state entered and based on that updates the statistics for the
state entered.
Ideally the driver enter routine should update the counters,
and it should return the state actually entered rather than the time
spent there. The generic cpuidle code should simply handle where
the counters live in the sysfs namespace, not updating the counters.
Reference:
https://lkml.org/lkml/2011/3/25/52
Signed-off-by: Deepthi Dharwar <deepthi@linux.vnet.ibm.com>
Signed-off-by: Trinabh Gupta <g.trinabh@gmail.com>
Tested-by: Jean Pihet <j-pihet@ti.com>
Reviewed-by: Kevin Hilman <khilman@ti.com>
Acked-by: Arjan van de Ven <arjan@linux.intel.com>
Acked-by: Kevin Hilman <khilman@ti.com>
Signed-off-by: Len Brown <len.brown@intel.com>
Diffstat (limited to 'arch/arm/mach-kirkwood/cpuidle.c')
-rw-r--r-- | arch/arm/mach-kirkwood/cpuidle.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/arch/arm/mach-kirkwood/cpuidle.c b/arch/arm/mach-kirkwood/cpuidle.c index f68d33f1f396..358dd80b3a07 100644 --- a/arch/arm/mach-kirkwood/cpuidle.c +++ b/arch/arm/mach-kirkwood/cpuidle.c | |||
@@ -32,17 +32,17 @@ static DEFINE_PER_CPU(struct cpuidle_device, kirkwood_cpuidle_device); | |||
32 | 32 | ||
33 | /* Actual code that puts the SoC in different idle states */ | 33 | /* Actual code that puts the SoC in different idle states */ |
34 | static int kirkwood_enter_idle(struct cpuidle_device *dev, | 34 | static int kirkwood_enter_idle(struct cpuidle_device *dev, |
35 | struct cpuidle_state *state) | 35 | int index) |
36 | { | 36 | { |
37 | struct timeval before, after; | 37 | struct timeval before, after; |
38 | int idle_time; | 38 | int idle_time; |
39 | 39 | ||
40 | local_irq_disable(); | 40 | local_irq_disable(); |
41 | do_gettimeofday(&before); | 41 | do_gettimeofday(&before); |
42 | if (state == &dev->states[0]) | 42 | if (index == 0) |
43 | /* Wait for interrupt state */ | 43 | /* Wait for interrupt state */ |
44 | cpu_do_idle(); | 44 | cpu_do_idle(); |
45 | else if (state == &dev->states[1]) { | 45 | else if (index == 1) { |
46 | /* | 46 | /* |
47 | * Following write will put DDR in self refresh. | 47 | * Following write will put DDR in self refresh. |
48 | * Note that we have 256 cycles before DDR puts it | 48 | * Note that we have 256 cycles before DDR puts it |
@@ -57,7 +57,11 @@ static int kirkwood_enter_idle(struct cpuidle_device *dev, | |||
57 | local_irq_enable(); | 57 | local_irq_enable(); |
58 | idle_time = (after.tv_sec - before.tv_sec) * USEC_PER_SEC + | 58 | idle_time = (after.tv_sec - before.tv_sec) * USEC_PER_SEC + |
59 | (after.tv_usec - before.tv_usec); | 59 | (after.tv_usec - before.tv_usec); |
60 | return idle_time; | 60 | |
61 | /* Update last residency */ | ||
62 | dev->last_residency = idle_time; | ||
63 | |||
64 | return index; | ||
61 | } | 65 | } |
62 | 66 | ||
63 | /* Initialize CPU idle by registering the idle states */ | 67 | /* Initialize CPU idle by registering the idle states */ |