[alsa-devel] [Pkg-alsa-devel] Bug#438118: alsa-utils: aplay non-blocking mode isn't working
Anders Boström
anders at netinsight.se
Thu Sep 27 14:16:29 CEST 2007
>>>>> "TI" == Takashi Iwai <tiwai at suse.de> writes:
TI> At Tue, 18 Sep 2007 09:41:48 +0200 (CEST),
TI> Anders Boström wrote:
>>
>> >>>>> "TI" == Takashi Iwai <tiwai at suse.de> writes:
>>
>> >> can one please have a lokk at this? aplay -N isn't working for the
>> >> OP.
>>
TI> Cannot reproduce here. Could you _post_ more details?
>>
>> OK, I've tested more, and discovered that the problem seems to be that
>> the end of the sound is cut in non-blocking mode. And if I play a very
>> short sound-file, I can't hear anything. Blocking mode works fine.
>>
>> When using non-blocking mode, an strace contains "ioctl(4, 0x4144,
>> 0x2b9f785d8000) = -1 EAGAIN (Resource temporarily
>> unavailable)". Blocking mode never contains the EAGAIN response.
>>
>> I attach two files. When playing halt.au, I can only hear the start,
>> about as much as "ha". When playing metal.au, I can't hear anything.
TI> OK, thanks, I see the problem now.
TI> I don't remember whether it's a feature or a bug. The drain ioctl
TI> rejects the non-block mode.
I can understand the idea here, that in non-blocking mode, no call
should block, ever. But on the other hand, if you call the drain
ioctl, you probably expect it to work, even in non-blocking mode. Why
would you otherwise call it?
TI> Anyway, a simple patch is below. Let me know if it works.
It works fine! Thanks!
/ Anders
TI> diff -r 0028e39ead78 core/pcm_native.c
TI> --- a/core/pcm_native.c Tue Sep 18 00:52:38 2007 +0200
TI> +++ b/core/pcm_native.c Tue Sep 18 17:44:31 2007 +0200
TI> @@ -1368,8 +1368,6 @@ static int snd_pcm_prepare(struct snd_pc
TI> static int snd_pcm_pre_drain_init(struct snd_pcm_substream *substream, int state)
TI> {
TI> - if (substream->f_flags & O_NONBLOCK)
TI> - return -EAGAIN;
substream-> runtime->trigger_master = substream;
TI> return 0;
TI> }
More information about the Alsa-devel
mailing list