output/alsa: call snd_pcm_prepare() if draining is requested early

This fixes a corner case which has probably never occurred and
probably never will: if Cancel() is called, and then Play() followed
by Drain(), the plugin should really play that data.  However
currently, this never happens, because snd_pcm_prepare() is never
called.
This commit is contained in:
Max Kellermann 2018-11-14 09:43:14 +01:00
parent 57e34823d8
commit 4247a757b3

View File

@ -891,6 +891,15 @@ AlsaOutput::DispatchSockets() noexcept
try { try {
non_block.DispatchSockets(*this, pcm); non_block.DispatchSockets(*this, pcm);
if (must_prepare) {
must_prepare = false;
int err = snd_pcm_prepare(pcm);
if (err < 0)
throw FormatRuntimeError("snd_pcm_prepare() failed: %s",
snd_strerror(-err));
}
{ {
const std::lock_guard<Mutex> lock(mutex); const std::lock_guard<Mutex> lock(mutex);
@ -911,15 +920,6 @@ try {
} }
} }
if (must_prepare) {
must_prepare = false;
int err = snd_pcm_prepare(pcm);
if (err < 0)
throw FormatRuntimeError("snd_pcm_prepare() failed: %s",
snd_strerror(-err));
}
CopyRingToPeriodBuffer(); CopyRingToPeriodBuffer();
if (period_buffer.IsEmpty()) { if (period_buffer.IsEmpty()) {