[alsa-devel] [PATCH] [v2] ASoC: support all possible sample rates in the WM8776 driver
Takashi Iwai
tiwai at suse.de
Fri Sep 16 17:37:35 CEST 2011
At Fri, 16 Sep 2011 09:16:54 -0500,
Timur Tabi wrote:
>
> The .set_sysclk() function in ASoC codec drivers can be used to tell the
> driver what the frequency of master clock (mclk) is. Some codecs use a
> divider on this clock to determine the sample rate. The WM8776 is one such
> codec.
>
> So instead of hard-coding a list of specific sample rates supported, these
> codec drivers can specify SNDRV_PCM_RATE_CONTINUOUS instead, clamping the
> range to the absolute limits of the hardware. Then the .hw_params() function
> can use the mclk rate to determine whether any requested rate is actually
> supported.
>
> Although the WM8776 driver includes a .set_sysclk function, it was also
> hard-coding the list of supported sample rates. We change the hard-coded
> list to a range within the capabilities of the WM8776 itself.
It's not optimal from some aspects. Basically this should be resolved
in hw_constraints, not in hw_params, so that the configurator can find
the possible rates. Otherwise you have no idea what rate would be
accepted.
Since a few other codecs need the similar constraint, it may make
sense to have a common helper hw_constraint for such a case.
thanks,
Takashi
>
> Signed-off-by: Timur Tabi <timur at freescale.com>
> ---
> sound/soc/codecs/wm8776.c | 13 ++++++-------
> 1 files changed, 6 insertions(+), 7 deletions(-)
>
> diff --git a/sound/soc/codecs/wm8776.c b/sound/soc/codecs/wm8776.c
> index ad6f0fa..ca8a593 100644
> --- a/sound/soc/codecs/wm8776.c
> +++ b/sound/soc/codecs/wm8776.c
> @@ -321,11 +321,6 @@ static int wm8776_set_bias_level(struct snd_soc_codec *codec,
> return 0;
> }
>
> -#define WM8776_RATES (SNDRV_PCM_RATE_32000 | SNDRV_PCM_RATE_44100 |\
> - SNDRV_PCM_RATE_48000 | SNDRV_PCM_RATE_88200 |\
> - SNDRV_PCM_RATE_96000)
> -
> -
> #define WM8776_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S20_3LE |\
> SNDRV_PCM_FMTBIT_S24_LE | SNDRV_PCM_FMTBIT_S32_LE)
>
> @@ -350,7 +345,9 @@ static struct snd_soc_dai_driver wm8776_dai[] = {
> .stream_name = "Playback",
> .channels_min = 2,
> .channels_max = 2,
> - .rates = WM8776_RATES,
> + .rates = SNDRV_PCM_RATE_CONTINUOUS,
> + .rate_min = 32000,
> + .rate_max = 192000,
> .formats = WM8776_FORMATS,
> },
> .ops = &wm8776_dac_ops,
> @@ -362,7 +359,9 @@ static struct snd_soc_dai_driver wm8776_dai[] = {
> .stream_name = "Capture",
> .channels_min = 2,
> .channels_max = 2,
> - .rates = WM8776_RATES,
> + .rates = SNDRV_PCM_RATE_CONTINUOUS,
> + .rate_min = 32000,
> + .rate_max = 96000,
> .formats = WM8776_FORMATS,
> },
> .ops = &wm8776_adc_ops,
> --
> 1.7.3.4
>
>
> _______________________________________________
> Alsa-devel mailing list
> Alsa-devel at alsa-project.org
> http://mailman.alsa-project.org/mailman/listinfo/alsa-devel
>
More information about the Alsa-devel
mailing list