[asterisk-bugs] [JIRA] (ASTERISK-27426) chan_console: cannot read and write at the same time with alsa backend
Tzafrir Cohen (JIRA)
noreply at issues.asterisk.org
Thu Nov 16 10:53:40 CST 2017
[ https://issues.asterisk.org/jira/browse/ASTERISK-27426?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Tzafrir Cohen updated ASTERISK-27426:
-------------------------------------
Description:
Trying to use chan_console on current master (9eacd55c7191a460fe8704f81b9e5e3beaf014b9). Ran into several issues.
Configured the device. Got error -9997 (paInvalidSampleRate).
So device does not support 16000Hz. OK, it supports 8000Hz. Easy enough to fix in the code. At least for now.
Now I connect the device and tried: 'channel originate Console/con1 application Playback demo-instruct'. "Nothing happens".
Added some tracing to chan_console.c:console_write(). I see that the function gets called. The result of Pa_WriteStream() there is not checked. When I checked the result I noticed that I keep getting the error -9974 (paCanNotWriteToAnInputOnlyStream).
Looking at the code of portaudio, I noticed that src/hostapi/alsa/pa_linux_alsa.c:ReadStream() temporarily disables writing for the time of the call to the function and likewise WriteStream temporarily disables reading.
Thus I temporarily replaced the call to Pa_ReadStream() with a sleep(), and suddenly I have audio.
Note that this applies to the ALSA backend. This does not happen when the OSS backend of portaudio is used (device /dev/dsp1 and such).
was:
Trying to use chan_console on current master (9eacd55c7191a460fe8704f81b9e5e3beaf014b9). Ran into several issues.
Configured the device. Got error -9997 (paInvalidSampleRate).
So device does not support 16000Hz. OK, it supports 8000Hz. Easy enough to fix in the code. At least for now.
Now I connect the device and tried: 'channel originate Console/con1 application Playback demo-instruct'. "Nothing happens".
Added some tracing to chan_console.c:console_write(). I see that the function gets called. The result of Pa_WriteStream() there is not checked. When I checked the result I noticed that I keep getting the error -9974 (paCanNotWriteToAnInputOnlyStream).
Looking at the code of portaudio, I noticed that src/hostapi/alsa/pa_linux_alsa.c:ReadStream() temporarily disables writing for the time of the call to the function and likewise WriteStream temporarily disables reading.
Thus I temporarily replaced the call to Pa_ReadStream() with a sleep(), and suddenly I have audio.
Summary: chan_console: cannot read and write at the same time with alsa backend (was: chan_console: cannot read and write at the same time)
> chan_console: cannot read and write at the same time with alsa backend
> ----------------------------------------------------------------------
>
> Key: ASTERISK-27426
> URL: https://issues.asterisk.org/jira/browse/ASTERISK-27426
> Project: Asterisk
> Issue Type: Bug
> Security Level: None
> Components: Channels/General
> Affects Versions: GIT
> Reporter: Tzafrir Cohen
>
> Trying to use chan_console on current master (9eacd55c7191a460fe8704f81b9e5e3beaf014b9). Ran into several issues.
> Configured the device. Got error -9997 (paInvalidSampleRate).
> So device does not support 16000Hz. OK, it supports 8000Hz. Easy enough to fix in the code. At least for now.
> Now I connect the device and tried: 'channel originate Console/con1 application Playback demo-instruct'. "Nothing happens".
> Added some tracing to chan_console.c:console_write(). I see that the function gets called. The result of Pa_WriteStream() there is not checked. When I checked the result I noticed that I keep getting the error -9974 (paCanNotWriteToAnInputOnlyStream).
> Looking at the code of portaudio, I noticed that src/hostapi/alsa/pa_linux_alsa.c:ReadStream() temporarily disables writing for the time of the call to the function and likewise WriteStream temporarily disables reading.
> Thus I temporarily replaced the call to Pa_ReadStream() with a sleep(), and suddenly I have audio.
> Note that this applies to the ALSA backend. This does not happen when the OSS backend of portaudio is used (device /dev/dsp1 and such).
--
This message was sent by Atlassian JIRA
(v6.2#6252)
More information about the asterisk-bugs
mailing list