summaryrefslogtreecommitdiffstats
path: root/media
diff options
context:
space:
mode:
authorEric Laurent <elaurent@google.com>2010-09-30 19:47:21 -0700
committerAndroid Git Automerger <android-git-automerger@android.com>2010-09-30 19:47:21 -0700
commit9ad6e8bd9fab860e639f6ce95479e4b2a9b03ff5 (patch)
tree73867627d0857a5bbbfbafeeacd2146d33ae585b /media
parent02d615bcb70a1bfe26dd5e3d719d621ee5c4ed87 (diff)
parentb3788b6d0f5a003d3d3e621ad605e2f3f4cb11e8 (diff)
downloadframeworks_av-9ad6e8bd9fab860e639f6ce95479e4b2a9b03ff5.zip
frameworks_av-9ad6e8bd9fab860e639f6ce95479e4b2a9b03ff5.tar.gz
frameworks_av-9ad6e8bd9fab860e639f6ce95479e4b2a9b03ff5.tar.bz2
am de12c3cf: am 220ab887: Merge "Issue 3032913: improve AudioTrack recovery time" into gingerbread
Merge commit 'de12c3cf56e3f27b2efc60eeae8b5e422747f2b9' * commit 'de12c3cf56e3f27b2efc60eeae8b5e422747f2b9': Issue 3032913: improve AudioTrack recovery time
Diffstat (limited to 'media')
-rw-r--r--media/libmedia/AudioTrack.cpp8
1 files changed, 8 insertions, 0 deletions
diff --git a/media/libmedia/AudioTrack.cpp b/media/libmedia/AudioTrack.cpp
index 890786e..587c8ff 100644
--- a/media/libmedia/AudioTrack.cpp
+++ b/media/libmedia/AudioTrack.cpp
@@ -316,6 +316,7 @@ void AudioTrack::start()
mNewPosition = mCblk->server + mUpdatePeriod;
mCblk->bufferTimeoutMs = MAX_STARTUP_TIMEOUT_MS;
mCblk->waitTimeMs = 0;
+ mCblk->flags &= ~CBLK_DISABLED_ON;
if (t != 0) {
t->run("AudioTrackThread", THREAD_PRIORITY_AUDIO_CLIENT);
} else {
@@ -842,6 +843,13 @@ create_new_track:
cblk->lock.unlock();
}
+ // restart track if it was disabled by audioflinger due to previous underrun
+ if (cblk->flags & CBLK_DISABLED_MSK) {
+ cblk->flags &= ~CBLK_DISABLED_ON;
+ LOGW("obtainBuffer() track %p disabled, restarting", this);
+ mAudioTrack->start();
+ }
+
cblk->waitTimeMs = 0;
if (framesReq > framesAvail) {