[alsa-devel] Alsa-OSS Duplex bug (revisited)
Alan Horstmann
gineera at aspect135.co.uk
Mon Jun 4 13:53:06 CEST 2007
On Monday 04 June 2007 09:50, you wrote:
> At Sun, 3 Jun 2007 20:55:27 +0100,
>
> Alan Horstmann wrote:
> > On Friday 01 June 2007 10:56, you wrote:
> > > At Thu, 31 May 2007 22:00:25 +0100,
> > >
> > > Alan Horstmann wrote:
> > > > On Wednesday 30 May 2007 07:47, you wrote:
> > > > > Alan Horstmann wrote:
> >
> > << Edited snippets >>
> >
> > > > > fd_playback = open("/dev/dsp", O_WRONLY);
> > > > > fd_capture = open("/dev/dsp", O_RDONLY);
> > > > >
> > > > > > > - change portaudio to open each direction separately, O_RDONLY
> > > > > > > and O_WRONLY at first, then use O_RDWR as fallback
> > > > >
> > > > > This would be the preferred way. After all, this is the only way
> > > > > that is possible with the existing OSS API when you want to use
> > > > > different sample formats, and it is recommended in all cases (see
> > > > > <http://manuals.opensound.com/developer/full_duplex.html>).
> > > >
> > > > My reading of the 4Front info is different. I read that they
> > > > recommend best opening SEPARATE devices, one O_RDONLY and the other
> > > > O_WRONLY, in their scheme called 'twodevice'. It also states in
> > > > fulldup.c:-
> > > >
> > > > "... The one device full duplex scheme requires that the device file
> > > > is opened with O_RDWR."
> > >
> > > Well, I'd say that the current ALSA-OSS implementation _is_ compatible
> > > to OSS API. What they do is also a pure hack, as you know, just a
> > > workaround because the API doesn't provide the functionality
> > > properly for full-duplex with multi-channels. The solution might be
> > > different, but it's not the question about "compatibility".
> > >
> > >
> > > Following this thread, I come to believe that the problem with
> > > audacity is actually the application problem. It tries to open a
> > > full-duplex device with different number of channels for both
> > > directions. It cannot work because it's not defined in API. OTOH, if
> > > the number of channels are same for both directions, it should work
> > > with O_RDWR.
> >
> > Thanks for sticking with it so far -hopefully we are moving towards a
> > conclusion so that the result is a definitive recommendation for how to
> > solve the problem of the OSS API limitation.
> >
> > So that there is no misunderstanding, are you willing to confirm that, as
> > far as Alsa-OSS goes, opening both
> > input_handle = open("/dev/dsp", O_RDONLY)
> > and
> > output_handle = open("/dev/dsp", O_WRONLY)
> > at the same time is a reliable way to open the device bi-directional,
> > enabling different sample formats and/or numbers of channels to be set?
> > (Actually, I am curious whether different sample rates would also work?)
>
> Yes, although I didn't confirm it. If it doesn't work, we should
> really fix it. The dirrerent sample rates should work, too, because
> they are different streams.
>
> > Provided this is so, the recommendation then for duplex as I understand
> > it is:-
> > a) where the format and no.channels is the same in each direction,
> > use
> > input_handle = output_handle = open("device", O_RDWR)
> >
> > b) where the 2 directions have different format or no.channels use
> > input_handle = open("device", O_RDONLY)
> > output_handle = open("device", O_WRONLY)
> >
> > since a) may improve compatibility with other OSS's but b) is necessary
> > due to the limitations of the OSS API, whether or not it works with other
> > OSS's.
>
> Exactly. But, remember that the solution for this kind of problems
> must be practical - if the theory above isn't true for the practice,
> it's of course useless :)
>
Confirm it is working on my system apparently OK.
I will now take this up with portaudio/audacity, and provide substitute
patches on the known postings that relate to this, so there is some
consistency.
Might it be worth adding a paragraph to 'OSS-Emulation.txt' (or.html), eg as
below? Apart from that I will close off on this issue now!
Thanks again
Alan
Duplex Streams
============
When attempting to use a single device file for playback and capture, the OSS
API provides no way to set the format, sample rate or number of channels
different in each direction. Thus
io_handle = open("device", O_RDWR)
will only function correctly if the values are the same in each direction.
To use different values in the two directions, use both
input_handle = open("device", O_RDONLY)
output_handle = open("device", O_WRONLY)
and set the values for the corresponding handle.
More information about the Alsa-devel
mailing list