From da1fcd49fc2069095f140c021f7455241cdef7ed Mon Sep 17 00:00:00 2001 From: Cameron Gutman Date: Sat, 9 Sep 2023 12:56:05 -0500 Subject: [PATCH] Increase audio buffer size to reduce the chance of underruns --- app/streaming/audio/renderers/sdlaud.cpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/app/streaming/audio/renderers/sdlaud.cpp b/app/streaming/audio/renderers/sdlaud.cpp index c21edfa8..aa574c95 100644 --- a/app/streaming/audio/renderers/sdlaud.cpp +++ b/app/streaming/audio/renderers/sdlaud.cpp @@ -28,8 +28,10 @@ bool SdlAudioRenderer::prepareForPlayback(const OPUS_MULTISTREAM_CONFIGURATION* // On PulseAudio systems, setting a value too small can cause underruns for other // applications sharing this output device. We impose a floor of 480 samples (10 ms) - // to mitigate this issue. - want.samples = SDL_max(480, opusConfig->samplesPerFrame); + // to mitigate this issue. Otherwise, we will buffer up to 3 frames of audio which + // is 15 ms at regular 5 ms frames and 30 ms at 10 ms frames for slow connections. + // The buffering helps avoid audio underruns due to network jitter. + want.samples = SDL_max(480, opusConfig->samplesPerFrame * 3); m_FrameSize = opusConfig->samplesPerFrame * sizeof(short) * opusConfig->channelCount;