PlayerThread: reduce the number of DecoderThread wakeups

After the number of decoded chunks has fallen below the threshold, the
PlayerThread woke up the DecoderThread over and over.  This commit
adds a boolean flag that avoids these duplicate wakeups, and thus
reduces the number of system calls.
This commit is contained in:
Max Kellermann 2013-11-06 23:30:29 +01:00
parent 0be5a6ab2b
commit 77c63511d8

View File

@ -68,6 +68,12 @@ class Player {
*/
bool decoder_starting;
/**
* Did we wake up the DecoderThread recently? This avoids
* duplicate wakeup calls.
*/
bool decoder_woken;
/**
* is the player paused?
*/
@ -133,6 +139,7 @@ public:
:pc(_pc), dc(_dc), buffer(_buffer),
buffering(true),
decoder_starting(false),
decoder_woken(false),
paused(false),
queued(true),
output_open(false),
@ -861,8 +868,13 @@ Player::PlayNextChunk()
pc.Lock();
if (!dc.IsIdle() &&
dc.pipe->GetSize() <= (pc.buffered_before_play +
buffer.GetSize() * 3) / 4)
buffer.GetSize() * 3) / 4) {
if (!decoder_woken) {
decoder_woken = true;
dc.Signal();
}
} else
decoder_woken = false;
pc.Unlock();
return true;