[alsa-devel] [BUG] aplay doesn't honor `-t raw` when WAVE header is detected on input
Nutchanon Wetchasit
Nutchanon.Wetchasit at gmail.com
Sun Oct 15 17:41:52 CEST 2017
Hello,
I ran into a problem on how alsa-utils's aplay command handles `-t` option
when I was trying to play a PCM WAVE file in loop, using following command:
( while true; do cat audio.wav; done ) | aplay -t raw -f S16_LE -r 44100 -c 2
An "audio.wav" can be any 44100 Hz 16-bit stereo PCM WAVE file, and `-t raw`
was specially specified to make aplay reject length information in the header.
However, once the command is run, first line of the output would read:
Playing WAVE 'stdin' : Signed 16 bit Little Endian, Rate 44100 Hz, Stereo
Which shows that aplay still read the input as WAVE format, despite the
`-t raw` option being explicitly specified. And you would notice that the audio
*does not loop*. Instead, it will play just once, followed by silence.
However, if WAVE header was stripped out (or corrupted), aplay would now
treat the input as raw audio stream, and play a continuously repeated sound
as expected:
( while true; do dd if=audio.wav of=/dev/stdout ibs=44 skip=1; done ) | \
aplay -t raw -f S16_LE -r 44100 -c 2
The first line of output would also show the stream as "raw data" too:
Playing raw data 'stdin' : Signed 16 bit Little Endian, Rate 44100 Hz, Stereo
This problem exists on the latest alsa-utils 1.1.4, as well as the older
1.0.25 which came with my GNU/Linux distribution; though I'm not certain
whether this is also applicable to other file format (like Sun .AU) or not.
Please investigate.
Regards,
Nutchanon Wetchasit
alsa-utils: 1.1.4 (source distribution)
libasound: 1.1.4 (source distribution)
System: Debian GNU/Linux 7.0 "Wheezy" i386
P.S. The "audio.wav" I used in my testing is a siren sound generated by Sox:
sox -b 16 -c 2 -e signed-integer -r 44100 -n audio.wav \
synth 0.5 sine 800 gain -6 : synth 0.5 sine 600 gain -6
More information about the Alsa-devel
mailing list