Re: alsalib and snd_pcm_hw_params_set_rate_minmax

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, 15 Mar 2018 13:20:14 +0100,
Oleksandr Andrushchenko wrote:
> 
> On 03/15/2018 01:59 PM, Takashi Sakamoto wrote:
> > Hi,
> >
> > On Mar 15 2018 19:45, Oleksandr Andrushchenko wrote:
> >> Is it possible for user-space to reduce configuration space
> >> with snd_pcm_hw_params_set_rate_minmax and then change it
> >> with another snd_pcm_hw_params_set_rate_minmax with values
> >> out of the reduced config?
> >>
> >> For example, the initial min/max is 44100/48000 and I set 44100
> >> first, e.g.
> >>
> >> snd_pcm_hw_params_set_rate_minmax(handle, hw_params, 44100, 0, 44100, 0)
> >>
> >> and then want
> >>
> >> snd_pcm_hw_params_set_rate_minmax(handle, hw_params, 48000, 0, 48000, 0)
> >>
> >> Obviously, the last call fails as we have already a reduced
> >> space of [44100; 44100].
> >>
> >> Is there a way I can still set the range to [48000; 48000]?
> >>
> >> Thank you,
> >> Oleksandr
> >>
> >> P.S. This is in context of work done for [1]
> >>
> >> [1] https://www.spinics.net/lists/alsa-devel/msg75382.html
> >
> > We can't. Once shrinking available interval of a parameter, we cannot
> > expand it again without initializing the parameter on memory object for
> > 'struct snd_pcm_hw_params_t', in which actual layout is never disclosed
> > to user applications.
> So, this effectively means that this is a one way road, if you need to
> change
> some parameter you'll need to start all over, so the whole configuration
> space remains consistent :(

Yes, that's the design.  The only way to expand is to reset the whole,
space and reduce again to the given size.


> > If you can initialize whole the parameters, snd_pcm_hw_params_any() is
> > available for your purpose, then set min/max rate again. 
> This is what I do now but...
> > But just for
> > one of the parameters, in my opinion, we need to open an internal
> > API; snd_pcm_hw_param_any()[1].
> IMO, this will lead to the false assumption that configuration is possible.
> For example, I set 4 channels and 44100, but then, after
> snd_pcm_hw_params_any,
> set 48000 and might assume that the configuration is still
> possible. But this may not
> be true: it is true for the configuration returned by snd_pcm_hw_param_any
> as we don't know about 4 channels yet. But might not be allowed if we
> want 4 channels
> and 48000 at the same time.

Right.  At the point where snd_pcm_hw_params_any() is called, the
whole configuration gets reset.  That's the reason I thought we may
need to pass all 5 parameters in the query protocol.

IOW, the query stuff won't be modal, it just tries to reduce the given
configuration space to the acceptable ranges.


Takashi
_______________________________________________
Alsa-devel mailing list
Alsa-devel@xxxxxxxxxxxxxxxx
http://mailman.alsa-project.org/mailman/listinfo/alsa-devel



[Index of Archives]     [ALSA User]     [Linux Audio Users]     [Kernel Archive]     [Asterisk PBX]     [Photo Sharing]     [Linux Sound]     [Video 4 Linux]     [Gimp]     [Yosemite News]

  Powered by Linux