[alsa-devel] snd_pcm_set_params faild on set_buffer_time_near and set_period_time_near

Takashi Iwai tiwai at suse.de
Thu Jul 23 10:11:48 CEST 2015


On Tue, 21 Jul 2015 10:52:01 +0200,
Martin Geier wrote:
> 
> Hallo,
> 
> I tried to configure alsa device with snd_pcm_set_params function, 
> requested
> parameters was:
> channel 2, rate: 22050, soft_resample: 1, latency: 50000
> 
> Function snd_pcm_hw_params_set_buffer_time_near and 
> snd_pcm_hw_param_set_near
> is called with:
> min: 50000, max: 50000, mindir: 0, maxdir: -1
> 
> and input params was:
> 
> ACCESS:  RW_INTERLEAVED
> FORMAT:  S16_LE
> SUBFORMAT:  STD
> SAMPLE_BITS: 16
> FRAME_BITS: 32
> CHANNELS: 2
> RATE: 22050
> PERIOD_TIME: (362 743039)
> PERIOD_SIZE: [8 16384]
> PERIOD_BYTES: [32 65536]
> PERIODS: [2 19]
> BUFFER_TIME: (725 1486078)
> BUFFER_SIZE: [16 32768]
> BUFFER_BYTES: [64 131072]
> TICK_TIME: ALL
> 
> unfortunately, this function fails, on function snd_pcm_hw_param_set_first:
> 
> ALSA ERROR hw_params: set_near (BUFFER_TIME)
>             value = 50000 : Invalid argument
> ACCESS:  RW_INTERLEAVED
> FORMAT:  S16_LE
> SUBFORMAT:  STD
> SAMPLE_BITS: 16
> FRAME_BITS: 32
> CHANNELS: 2
> RATE: 22050
> PERIOD_TIME: (4580 5533)
> PERIOD_SIZE: NONE
> PERIOD_BYTES: [404 488]
> PERIODS: 10
> BUFFER_TIME: (50022 50023)
> BUFFER_SIZE: 1103
> BUFFER_BYTES: 4412
> TICK_TIME: ALL
> 
> This shouldn't be problem because in snd_pcm_set_params is
> snd_pcm_hw_params_set_period_time_near called.
> This function should be called with same params as 
> snd_pcm_hw_params_set_buffer_time_near
> but the input params are:
> 
> snd_pcm_hw_param_set_near: min: 12500, max: 12500, mindir: 0, maxdir: -1
> hw_params: snd_pcm_hw_param_set_near (PERIOD_TIME)
> ACCESS:  RW_INTERLEAVED
> FORMAT:  S16_LE
> SUBFORMAT:  STD
> SAMPLE_BITS: 16
> FRAME_BITS: 32
> CHANNELS: 2
> RATE: 22050
> PERIOD_TIME: (4580 5533)
> PERIOD_SIZE: NONE
> PERIOD_BYTES: [404 488]
> PERIODS: 10
> BUFFER_TIME: (50022 50023)
> BUFFER_SIZE: 1103
> BUFFER_BYTES: 4412
> TICK_TIME: ALL
> 
> because in snd_pcm_hw_param_set_near is
> 
> if (last)
>      err = snd_pcm_hw_param_set_last(pcm, params, var, val, dir);
> else
>      err = snd_pcm_hw_param_set_first(pcm, params, var, val, dir);
> if (err < 0)
>      dump_hw_params(params, "set_near", var, *val, err);
> return err;
> 
> and in error part is only debug output and not restore original parameters.
> 
> Environment:
> alsa-lib 1.0.27.1
> TI AM335x soc
> 
> Simple fix is attached, but I am not sure if it is correct.

Thanks for analysis and patch.  It's however rather a bug in
snd_pcm_set_params().  There is no guarantee to keep the old value in
snd_pcm_set_*(), thus the caller needs to take care of it instead.


Takashi


More information about the Alsa-devel mailing list