ASoC: fsl-asoc-card: Support new property fsl, asrc-format
authorShengjiu Wang <shengjiu.wang@nxp.com>
Thu, 16 Apr 2020 12:25:33 +0000 (20:25 +0800)
committerMark Brown <broonie@kernel.org>
Tue, 21 Apr 2020 15:34:07 +0000 (16:34 +0100)
In order to align with new ESARC, we add new property fsl,asrc-format.
The fsl,asrc-format can replace the fsl,asrc-width, driver
can accept format from devicetree, don't need to convert it to
format through width.

Signed-off-by: Shengjiu Wang <shengjiu.wang@nxp.com>
Acked-by: Nicolin Chen <nicoleotsuka@gmail.com>
Link: https://lore.kernel.org/r/02f53d5512b9acd3492e2acdd5e0ba3113f18009.1587038908.git.shengjiu.wang@nxp.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/fsl/fsl-asoc-card.c

index bb33601..cf4feb8 100644 (file)
@@ -680,17 +680,23 @@ static int fsl_asoc_card_probe(struct platform_device *pdev)
                        goto asrc_fail;
                }
 
-               ret = of_property_read_u32(asrc_np, "fsl,asrc-width", &width);
+               ret = of_property_read_u32(asrc_np, "fsl,asrc-format",
+                                          &priv->asrc_format);
                if (ret) {
-                       dev_err(&pdev->dev, "failed to get output rate\n");
-                       ret = -EINVAL;
-                       goto asrc_fail;
+                       /* Fallback to old binding; translate to asrc_format */
+                       ret = of_property_read_u32(asrc_np, "fsl,asrc-width",
+                                                  &width);
+                       if (ret) {
+                               dev_err(&pdev->dev,
+                                       "failed to decide output format\n");
+                               goto asrc_fail;
+                       }
+
+                       if (width == 24)
+                               priv->asrc_format = SNDRV_PCM_FORMAT_S24_LE;
+                       else
+                               priv->asrc_format = SNDRV_PCM_FORMAT_S16_LE;
                }
-
-               if (width == 24)
-                       priv->asrc_format = SNDRV_PCM_FORMAT_S24_LE;
-               else
-                       priv->asrc_format = SNDRV_PCM_FORMAT_S16_LE;
        }
 
        /* Finish card registering */