summaryrefslogtreecommitdiffstats
path: root/sound
diff options
context:
space:
mode:
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>2015-06-15 06:22:30 +0000
committerMark Brown <broonie@kernel.org>2015-06-16 12:34:01 +0100
commit3433bf0798356abf2e8b6145ac5633a610c0a8ec (patch)
tree865700be310d9d5fea119dd9f988dae64cd0cf41 /sound
parent3c7e64dd89886af007cb0abbf4523253204c9079 (diff)
downloadlinux-3433bf0798356abf2e8b6145ac5633a610c0a8ec.tar.gz
linux-3433bf0798356abf2e8b6145ac5633a610c0a8ec.tar.bz2
linux-3433bf0798356abf2e8b6145ac5633a610c0a8ec.zip
ASoC: rsrc-card: enable multi cpu/codec for DPCM
Current rsrc-card is assuming 1 FE (= CPU), 1 BE (= codec) on card. But, it will support multi FE/BE card. This is prepare for it. Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com> Tested-by: Keita Kobayashi <keita.kobayashi.ym@renesas.com> Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to 'sound')
-rw-r--r--sound/soc/sh/rcar/rsrc-card.c25
1 files changed, 19 insertions, 6 deletions
diff --git a/sound/soc/sh/rcar/rsrc-card.c b/sound/soc/sh/rcar/rsrc-card.c
index cdd005b82660..ae99b3612039 100644
--- a/sound/soc/sh/rcar/rsrc-card.c
+++ b/sound/soc/sh/rcar/rsrc-card.c
@@ -52,7 +52,6 @@ struct rsrc_card_dai {
struct clk *clk;
};
-#define RSRC_FB_NUM 2 /* FE/BE */
#define IDX_CPU 0
#define IDX_CODEC 1
#define DAI_NAME_NUM 32
@@ -62,9 +61,10 @@ struct rsrc_card_priv {
struct rsrc_card_dai cpu_dai;
struct rsrc_card_dai codec_dai;
char dai_name[DAI_NAME_NUM];
- } dai_props[RSRC_FB_NUM];
+ } *dai_props;
struct snd_soc_codec_conf codec_conf;
- struct snd_soc_dai_link dai_link[RSRC_FB_NUM];
+ struct snd_soc_dai_link *dai_link;
+ int dai_num;
u32 convert_rate;
};
@@ -395,12 +395,25 @@ static int rsrc_card_parse_of(struct device_node *node,
struct device *dev)
{
const struct rsrc_card_of_data *of_data = rsrc_dev_to_of_data(dev);
+ struct rsrc_card_dai_props *props;
+ struct snd_soc_dai_link *links;
+
int ret;
- int i;
+ int i, num;
if (!node)
return -EINVAL;
+ num = of_get_child_count(node);
+ props = devm_kzalloc(dev, sizeof(*props) * num, GFP_KERNEL);
+ links = devm_kzalloc(dev, sizeof(*links) * num, GFP_KERNEL);
+ if (!props || !links)
+ return -ENOMEM;
+
+ priv->dai_props = props;
+ priv->dai_link = links;
+ priv->dai_num = num;
+
/* Parse the card name from DT */
snd_soc_of_parse_card_name(&priv->snd_card, "card-name");
@@ -408,7 +421,7 @@ static int rsrc_card_parse_of(struct device_node *node,
priv->snd_card.owner = THIS_MODULE;
priv->snd_card.dev = dev;
priv->snd_card.dai_link = priv->dai_link;
- priv->snd_card.num_links = RSRC_FB_NUM;
+ priv->snd_card.num_links = num;
priv->snd_card.codec_conf = &priv->codec_conf;
priv->snd_card.num_configs = 1;
priv->snd_card.of_dapm_routes = of_data->routes;
@@ -422,7 +435,7 @@ static int rsrc_card_parse_of(struct device_node *node,
priv->convert_rate);
/* FE/BE */
- for (i = 0; i < RSRC_FB_NUM; i++) {
+ for (i = 0; i < num; i++) {
ret = rsrc_card_dai_link_of(node, priv, i);
if (ret < 0)
return ret;