diff options
author | Andrea Arcangeli <andrea@cpushare.com> | 2012-07-02 05:34:17 +0200 |
---|---|---|
committer | Andrea Arcangeli <andrea@cpushare.com> | 2013-05-28 14:01:50 +0200 |
commit | f4156e2bef7098483448980ad6ea4b0164087e37 (patch) | |
tree | efb1f780c6ed7f81eee2d485a9d08ce1b7b490fa /drivers/usb | |
parent | 4377ebe6456b2cbadd7be9b3970e2412a2001654 (diff) | |
download | kernel_samsung_smdk4412-f4156e2bef7098483448980ad6ea4b0164087e37.zip kernel_samsung_smdk4412-f4156e2bef7098483448980ad6ea4b0164087e37.tar.gz kernel_samsung_smdk4412-f4156e2bef7098483448980ad6ea4b0164087e37.tar.bz2 |
ondemand: cpuidle detection
I found a problem with the ondemand governor while in earlysuspend
suspend mode (ondemand keeping the freq close to the max at all times
despite near 0% load). The problem is that the cpu starts to go in
long cpuidle cycles, a sampling_rate of 10000 (usec) is applied only
once in a while and the real sampling_rate becomes 1 second (or more).
So when a wakeup happens we return to the 10000usec sampling rate. The
ondemand sees lots of activity after the wakeup but those "loads" must
be adjusted down if the previous wall_time delta was huge and the
current one is tiny. We're too close to long cpuidle to worry about
the cpu freq anyway and it may be just a jitter load that if we take
into account without adjusting it down, will lead to the next long
cpuidle to be entered at the max freq again, and this repeats forever.
So my solution is to tweak the ondemand to scale down the "load"
according to the decrease in the wall_time delta ratio
(deep_sleep_ratio variable). This allows the CPU to stay at the lowest
freq during the deep sleeps even when the ondemand governor is enabled
and the sampling_rate is set to 10000. (setting the sampling_rate to
values >100000 would also tend to hide the problem but it'd screw the
interactive behavior by running at the lowest frequency for too long
during interactive usage)
During interactive usage with the screen on (not in earlysuspend
mode), or during playback or voip with screen off the deep_sleep_rate
is set to 1 practically all the time so it won't alter the behavior of
the ondemand governor unless the system is very idle (and in turn when
we want it to stay at low freq).
Change-Id: If0391e6d6c41c1c8c9fa590502e88e681a800b04
Signed-off-by: Andrea Arcangeli <andrea@cpushare.com>
Diffstat (limited to 'drivers/usb')
0 files changed, 0 insertions, 0 deletions