diff options
author | Chris Robinson <[email protected]> | 2019-04-26 18:04:22 -0700 |
---|---|---|
committer | Chris Robinson <[email protected]> | 2019-04-26 18:04:22 -0700 |
commit | 9e4ee500b61462c205ed588c31a045bd95215cdc (patch) | |
tree | 6ecded32c953d11aec4b5196f9f76f52b570e47c /Alc/backends/pulseaudio.cpp | |
parent | b29be3b39ea2d128f9b380fb8d079815ed707c7c (diff) |
Scale the update size with sample rate changes
Diffstat (limited to 'Alc/backends/pulseaudio.cpp')
-rw-r--r-- | Alc/backends/pulseaudio.cpp | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/Alc/backends/pulseaudio.cpp b/Alc/backends/pulseaudio.cpp index 29fd5ae9..9561407c 100644 --- a/Alc/backends/pulseaudio.cpp +++ b/Alc/backends/pulseaudio.cpp @@ -1026,15 +1026,18 @@ ALCboolean PulsePlayback::reset() if(mDevice->Frequency != mSpec.rate) { /* Server updated our playback rate, so modify the buffer attribs - * accordingly. */ - double newlen{clampd( - static_cast<double>(mSpec.rate)/mDevice->Frequency*mDevice->BufferSize + 0.5, - mDevice->UpdateSize*2, std::numeric_limits<int>::max()/mFrameSize)}; + * accordingly. + */ + const auto scale = static_cast<double>(mSpec.rate) / mDevice->Frequency; + const ALuint perlen{static_cast<ALuint>(clampd(scale*mDevice->UpdateSize + 0.5, 64.0, + 8192.0))}; + const ALuint buflen{static_cast<ALuint>(clampd(scale*mDevice->BufferSize + 0.5, perlen*2, + std::numeric_limits<int>::max()/mFrameSize))}; mAttr.maxlength = -1; - mAttr.tlength = static_cast<ALuint>(newlen) * mFrameSize; + mAttr.tlength = buflen * mFrameSize; mAttr.prebuf = 0; - mAttr.minreq = mDevice->UpdateSize * mFrameSize; + mAttr.minreq = perlen * mFrameSize; op = pa_stream_set_buffer_attr(mStream, &mAttr, stream_success_callback, mLoop); wait_for_operation(op, mLoop); |