summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric Laurent <elaurent@google.com>2012-01-24 11:51:50 -0800
committerAndroid Git Automerger <android-git-automerger@android.com>2012-01-24 11:51:50 -0800
commit535b0264a4cfa790e549bd9cd09980788f1375f4 (patch)
treea04b81cdcd0917f4131a15eae7df11cf1cd649c9
parentdd347d515d4a4e42b2aba89a8e471392026b7824 (diff)
parent7eeaf3f07aa6fb10639d9f96c1367eb98c3e8839 (diff)
downloadframeworks_base-535b0264a4cfa790e549bd9cd09980788f1375f4.zip
frameworks_base-535b0264a4cfa790e549bd9cd09980788f1375f4.tar.gz
frameworks_base-535b0264a4cfa790e549bd9cd09980788f1375f4.tar.bz2
am 7eeaf3f0: Merge "AudioFlinger: refine mixer sleep time logic" into ics-mr1
* commit '7eeaf3f07aa6fb10639d9f96c1367eb98c3e8839': AudioFlinger: refine mixer sleep time logic
-rw-r--r--services/audioflinger/AudioFlinger.cpp9
1 files changed, 6 insertions, 3 deletions
diff --git a/services/audioflinger/AudioFlinger.cpp b/services/audioflinger/AudioFlinger.cpp
index 697bcdf..5a46e44 100644
--- a/services/audioflinger/AudioFlinger.cpp
+++ b/services/audioflinger/AudioFlinger.cpp
@@ -1973,11 +1973,14 @@ bool AudioFlinger::MixerThread::threadLoop()
if (LIKELY(mixerStatus == MIXER_TRACKS_READY)) {
// mix buffers...
mAudioMixer->process();
- sleepTime = 0;
- // increase sleep time progressively when application underrun condition clears
- if (sleepTimeShift > 0) {
+ // increase sleep time progressively when application underrun condition clears.
+ // Only increase sleep time if the mixer is ready for two consecutive times to avoid
+ // that a steady state of alternating ready/not ready conditions keeps the sleep time
+ // such that we would underrun the audio HAL.
+ if ((sleepTime == 0) && (sleepTimeShift > 0)) {
sleepTimeShift--;
}
+ sleepTime = 0;
standbyTime = systemTime() + kStandbyTimeInNsecs;
//TODO: delay standby when effects have a tail
} else {