It is possible that snd_pcm_writei() returns zero rather than -EAGAIN
in case nothing was written because the alsa buffer was already full.
Currently we try again, and eventually succeed. However, this is
ugly, burns CPU cycles and might even lead to an endless loop for
misconfigured alsa devices. So simply return from alsa_post_select()
if snd_pcm_writei() returned zero.
}
frames = bytes / pad->bytes_per_frame;
frames = snd_pcm_writei(pad->handle, data, frames);
- if (frames >= 0) {
+ if (frames == 0 || frames == -EAGAIN)
+ return;
+ if (frames > 0) {
btr_consume(btrn, frames * pad->bytes_per_frame);
goto again;
}
snd_pcm_prepare(pad->handle);
return;
}
- if (frames == -EAGAIN)
- return;
PARA_WARNING_LOG("%s\n", snd_strerror(-frames));
ret = -E_ALSA_WRITE;
err: