Merge "Limit notification period when a fast track denied" am: 89a1e53856 am: 66446e6135

am: 53a82d0a1a

Change-Id: Idf2b0e981ddbae38aeb4838595e303d0b8b1da2f
gugelfrei
Glenn Kasten 7 years ago committed by android-build-merger
commit bdfaf7e608

@ -1393,14 +1393,14 @@ status_t AudioTrack::createTrack_l()
bool useCaseAllowed = sharedBuffer || transferAllowed;
if (!useCaseAllowed) {
ALOGW("AUDIO_OUTPUT_FLAG_FAST denied, not shared buffer and transfer = %s",
ALOGW("AUDIO_OUTPUT_FLAG_FAST denied by client, not shared buffer and transfer = %s",
convertTransferToText(mTransfer));
}
// sample rates must also match
bool sampleRateAllowed = mSampleRate == mAfSampleRate;
if (!sampleRateAllowed) {
ALOGW("AUDIO_OUTPUT_FLAG_FAST denied, rates do not match %u Hz, require %u Hz",
ALOGW("AUDIO_OUTPUT_FLAG_FAST denied by client, sample rate %u Hz but HAL needs %u Hz",
mSampleRate, mAfSampleRate);
}
@ -1578,6 +1578,15 @@ status_t AudioTrack::createTrack_l()
// or at least triple-buffering if there is sample rate conversion
const int nBuffering = mOriginalSampleRate == mAfSampleRate ? 2 : 3;
maxNotificationFrames = frameCount / nBuffering;
// If client requested a fast track but this was denied, then use the smaller maximum.
// FMS_20 is the minimum task wakeup period in ms for which CFS operates reliably.
#define FMS_20 20 // FIXME share a common declaration with the same symbol in Threads.cpp
if (mOrigFlags & AUDIO_OUTPUT_FLAG_FAST) {
size_t maxNotificationFramesFastDenied = FMS_20 * mSampleRate / 1000;
if (maxNotificationFrames > maxNotificationFramesFastDenied) {
maxNotificationFrames = maxNotificationFramesFastDenied;
}
}
}
if (mNotificationFramesAct == 0 || mNotificationFramesAct > maxNotificationFrames) {
if (mNotificationFramesAct == 0) {

Loading…
Cancel
Save