ASoC: simple-card-utils: add asoc_simple_card_convert_fixup()
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Thu, 15 Jun 2017 00:24:09 +0000 (00:24 +0000)
committerMark Brown <broonie@kernel.org>
Thu, 15 Jun 2017 17:14:43 +0000 (18:14 +0100)
Current simple/audio scu card drivers are supporting same
convert-rate/convert-channels on DT, but doesn't use same function
for it.
Encapsulation is one of simple card util's purpose.
Let's add asoc_simple_card_parse_convert/asoc_simple_card_convert_fixup

Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
include/sound/simple_card_utils.h
sound/soc/generic/simple-card-utils.c

index 2679312228b3e6354c781493e031b7b60a806715..cc318ccd6a2d5304d6b1b5f725bf82e07fcb0581 100644 (file)
@@ -22,6 +22,11 @@ struct asoc_simple_dai {
        struct clk *clk;
 };
 
+struct asoc_simple_card_data {
+       u32 convert_rate;
+       u32 convert_channels;
+};
+
 int asoc_simple_card_parse_daifmt(struct device *dev,
                                  struct device_node *node,
                                  struct device_node *codec,
@@ -90,4 +95,9 @@ void asoc_simple_card_canonicalize_cpu(struct snd_soc_dai_link *dai_link,
 
 int asoc_simple_card_clean_reference(struct snd_soc_card *card);
 
+void asoc_simple_card_convert_fixup(struct asoc_simple_card_data *data,
+                                     struct snd_pcm_hw_params *params);
+void asoc_simple_card_parse_convert(struct device *dev, char *prefix,
+                                   struct asoc_simple_card_data *data);
+
 #endif /* __SIMPLE_CARD_UTILS_H */
index 2ad7633292bf95f4d4b752e2a94292c1b8358cee..948a18842e64b2452ddd8c0a22d8d12fa70d3ad8 100644 (file)
 #include <linux/of_graph.h>
 #include <sound/simple_card_utils.h>
 
+void asoc_simple_card_convert_fixup(struct asoc_simple_card_data *data,
+                                   struct snd_pcm_hw_params *params)
+{
+       struct snd_interval *rate = hw_param_interval(params,
+                                               SNDRV_PCM_HW_PARAM_RATE);
+       struct snd_interval *channels = hw_param_interval(params,
+                                               SNDRV_PCM_HW_PARAM_CHANNELS);
+
+       if (data->convert_rate)
+               rate->min =
+               rate->max = data->convert_rate;
+
+       if (data->convert_channels)
+               channels->min =
+               channels->max = data->convert_channels;
+}
+EXPORT_SYMBOL_GPL(asoc_simple_card_convert_fixup);
+
+void asoc_simple_card_parse_convert(struct device *dev, char *prefix,
+                                   struct asoc_simple_card_data *data)
+{
+       struct device_node *np = dev->of_node;
+       char prop[128];
+
+       if (!prefix)
+               prefix = "";
+
+       /* sampling rate convert */
+       snprintf(prop, sizeof(prop), "%s%s", prefix, "convert-rate");
+       of_property_read_u32(np, prop, &data->convert_rate);
+
+       /* channels transfer */
+       snprintf(prop, sizeof(prop), "%s%s", prefix, "convert-channels");
+       of_property_read_u32(np, prop, &data->convert_channels);
+
+       dev_dbg(dev, "convert_rate     %d\n", data->convert_rate);
+       dev_dbg(dev, "convert_channels %d\n", data->convert_channels);
+}
+EXPORT_SYMBOL_GPL(asoc_simple_card_parse_convert);
+
 int asoc_simple_card_parse_daifmt(struct device *dev,
                                  struct device_node *node,
                                  struct device_node *codec,