mirror of
https://github.com/badaix/snapcast.git
synced 2025-07-18 17:07:49 +02:00
buffering
git-svn-id: svn://elaine/murooma/trunk@35 d8a302eb-03bc-478d-80e4-98257eca68ef
This commit is contained in:
parent
07d2ef5794
commit
4d99cfd70c
2 changed files with 37 additions and 6 deletions
20
client.cpp
20
client.cpp
|
@ -21,7 +21,7 @@
|
|||
#include "doubleBuffer.h"
|
||||
|
||||
|
||||
DoubleBuffer<int> buffer(5000 / MS);
|
||||
DoubleBuffer<int> buffer(60000 / MS);
|
||||
std::deque<Chunk*> chunks;
|
||||
std::deque<int> timeDiffs;
|
||||
std::mutex mtx;
|
||||
|
@ -187,7 +187,7 @@ static int patestCallback( const void *inputBuffer, void *outputBuffer,
|
|||
mutex.unlock();
|
||||
age = getAge(*chunk) + timeInfo->outputBufferDacTime*1000;
|
||||
int median = buffer.median();
|
||||
std::cerr << "age: " << getAge(*chunk) << "\t" << age << "\t" << median << "\t" << timeInfo->outputBufferDacTime*1000 << "\n";
|
||||
std::cerr << "age: " << getAge(*chunk) << "\t" << age << "\t" << median << "\t" << buffer.size() << "\t" << timeInfo->outputBufferDacTime*1000 << "\n";
|
||||
|
||||
if (age > bufferMs + 2*MS)
|
||||
{
|
||||
|
@ -204,6 +204,22 @@ static int patestCallback( const void *inputBuffer, void *outputBuffer,
|
|||
usleep(10 * 1000);
|
||||
break;
|
||||
}
|
||||
else if (buffer.full() && (median > bufferMs + MS))
|
||||
{
|
||||
std::cerr << "median > bufferMs + MS (" << median << " > " << bufferMs + MS << "), dropping chunk\n";
|
||||
buffer.clear();
|
||||
chunks->pop_front();
|
||||
delete chunk;
|
||||
}
|
||||
else if (buffer.full() && (median + MS < bufferMs))
|
||||
{
|
||||
std::cerr << "median + MS < bufferMs (" << median + MS << " < " << bufferMs << "), playing silence\n";
|
||||
buffer.clear();
|
||||
chunk = new Chunk();
|
||||
memset(&(chunk->payload[0]), 0, SIZE);
|
||||
usleep(10 * 1000);
|
||||
break;
|
||||
}
|
||||
else
|
||||
{
|
||||
buffer.add(age);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue