Skip to content

Commit

Permalink
Merge pull request #15631 from fritsch/androidextendedflush
Browse files Browse the repository at this point in the history
AESinkAudioTrack: Trace flush on deinitialize
  • Loading branch information
MartijnKaijser committed Feb 28, 2019
2 parents a1354ce + 9953c5b commit 94cb6ab
Showing 1 changed file with 10 additions and 1 deletion.
11 changes: 10 additions & 1 deletion xbmc/cores/AudioEngine/Sinks/AESinkAUDIOTRACK.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -290,7 +290,7 @@ bool CAESinkAUDIOTRACK::VerifySinkConfiguration(int sampleRate, int channelMask,
jniAt->release();
delete jniAt;
}

usleep(50 * 1000); // Enumeration only, reduce pressure while starting
return success;
}

Expand Down Expand Up @@ -575,6 +575,7 @@ void CAESinkAUDIOTRACK::Deinitialize()
if (!m_at_jni)
return;

uint64_t before = CurrentHostCounter();
if (IsInitialized())
{
m_at_jni->stop();
Expand All @@ -591,6 +592,14 @@ void CAESinkAUDIOTRACK::Deinitialize()

delete m_at_jni;
m_at_jni = NULL;
uint64_t gone = CurrentHostCounter() - before;
uint64_t delta_ms = 1000 * gone / CurrentHostFrequency();
int64_t diff = m_audiotrackbuffer_sec * 1000 - delta_ms;
if (diff > 0)
{
CLog::Log(LOGDEBUG, "Flushing might not be properly implemented, sleeping: %d ms", diff);
usleep(diff * 1000);
}
}

bool CAESinkAUDIOTRACK::IsInitialized()
Expand Down

0 comments on commit 94cb6ab

Please sign in to comment.