ASoC: samsung: odroid: Fix 32000 sample rate handling
authorSylwester Nawrocki <s.nawrocki@samsung.com>
Wed, 14 Mar 2018 16:41:13 +0000 (17:41 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 25 May 2018 14:17:52 +0000 (16:17 +0200)
[ Upstream commit 1d22c337dc8f3a25638f7262e7bcb5729a34d140 ]

In case of sample rates lower than 44100 currently there is too low MCLK
frequency set for the CODEC. Playback fails with following errors:

$ speaker-test -c2 -t sine -f 1500 -l2 -r 32000

Sine wave rate is 1500.0000Hz
Rate set to 32000Hz (requested 32000Hz)
Buffer size range from 128 to 131072
Period size range from 64 to 65536
Using max buffer size 131072
Periods = 4
Unable to set hw params for playback: Invalid argument
Setting of hwparams failed: Invalid argument

[  497.883700] max98090 1-0010: Invalid master clock frequency

To fix this the I2S root clock's frequency is increased, depending
on sampling rate.

Signed-off-by: Sylwester Nawrocki <s.nawrocki@samsung.com>
Acked-by: Krzysztof Kozlowski <krzk@kernel.org>
Signed-off-by: Mark Brown <broonie@kernel.org>
Signed-off-by: Sasha Levin <alexander.levin@microsoft.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
sound/soc/samsung/odroid.c

index 44b6de5a331aeb0e9b21b4c67697baff3b0f31d7..06a31a9585a05afa8d605bde5afbfd7d5c86a384 100644 (file)
@@ -36,23 +36,26 @@ static int odroid_card_hw_params(struct snd_pcm_substream *substream,
 {
        struct snd_soc_pcm_runtime *rtd = substream->private_data;
        struct odroid_priv *priv = snd_soc_card_get_drvdata(rtd->card);
-       unsigned int pll_freq, rclk_freq;
+       unsigned int pll_freq, rclk_freq, rfs;
        int ret;
 
        switch (params_rate(params)) {
-       case 32000:
        case 64000:
-               pll_freq = 131072006U;
+               pll_freq = 196608001U;
+               rfs = 384;
                break;
        case 44100:
        case 88200:
        case 176400:
                pll_freq = 180633609U;
+               rfs = 512;
                break;
+       case 32000:
        case 48000:
        case 96000:
        case 192000:
                pll_freq = 196608001U;
+               rfs = 512;
                break;
        default:
                return -EINVAL;
@@ -67,7 +70,7 @@ static int odroid_card_hw_params(struct snd_pcm_substream *substream,
         *  frequency values due to the EPLL output frequency not being exact
         *  multiple of the audio sampling rate.
         */
-       rclk_freq = params_rate(params) * 256 + 1;
+       rclk_freq = params_rate(params) * rfs + 1;
 
        ret = clk_set_rate(priv->sclk_i2s, rclk_freq);
        if (ret < 0)