2
0
mirror of https://github.com/edk2-porting/linux-next.git synced 2025-01-15 17:14:00 +08:00

ASoC: rsnd: gen: rsnd_gen_ops cares .probe and .remove

Current rsnd_gen_ops didn't care about .probe and .remove
functions, but it was not good sense.
This patch tidyup it

Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: Mark Brown <broonie@linaro.org>
This commit is contained in:
Kuninori Morimoto 2013-09-01 20:31:16 -07:00 committed by Mark Brown
parent 272b98c645
commit 072188b61c

View File

@ -11,6 +11,11 @@
#include "rsnd.h" #include "rsnd.h"
struct rsnd_gen_ops { struct rsnd_gen_ops {
int (*probe)(struct platform_device *pdev,
struct rcar_snd_info *info,
struct rsnd_priv *priv);
void (*remove)(struct platform_device *pdev,
struct rsnd_priv *priv);
int (*path_init)(struct rsnd_priv *priv, int (*path_init)(struct rsnd_priv *priv,
struct rsnd_dai *rdai, struct rsnd_dai *rdai,
struct rsnd_dai_stream *io); struct rsnd_dai_stream *io);
@ -98,11 +103,6 @@ static int rsnd_gen1_path_exit(struct rsnd_priv *priv,
return ret; return ret;
} }
static struct rsnd_gen_ops rsnd_gen1_ops = {
.path_init = rsnd_gen1_path_init,
.path_exit = rsnd_gen1_path_exit,
};
#define RSND_GEN1_REG_MAP(g, s, i, oi, oa) \ #define RSND_GEN1_REG_MAP(g, s, i, oi, oa) \
do { \ do { \
(g)->reg_map[RSND_REG_##i].index = RSND_GEN1_##s; \ (g)->reg_map[RSND_REG_##i].index = RSND_GEN1_##s; \
@ -163,7 +163,6 @@ static int rsnd_gen1_probe(struct platform_device *pdev,
IS_ERR(gen->base[RSND_GEN1_SSI])) IS_ERR(gen->base[RSND_GEN1_SSI]))
return -ENODEV; return -ENODEV;
gen->ops = &rsnd_gen1_ops;
rsnd_gen1_reg_map_init(gen); rsnd_gen1_reg_map_init(gen);
dev_dbg(dev, "Gen1 device probed\n"); dev_dbg(dev, "Gen1 device probed\n");
@ -183,6 +182,13 @@ static void rsnd_gen1_remove(struct platform_device *pdev,
{ {
} }
static struct rsnd_gen_ops rsnd_gen1_ops = {
.probe = rsnd_gen1_probe,
.remove = rsnd_gen1_remove,
.path_init = rsnd_gen1_path_init,
.path_exit = rsnd_gen1_path_exit,
};
/* /*
* Gen * Gen
*/ */
@ -251,6 +257,14 @@ int rsnd_gen_probe(struct platform_device *pdev,
return -ENOMEM; return -ENOMEM;
} }
if (rsnd_is_gen1(priv))
gen->ops = &rsnd_gen1_ops;
if (!gen->ops) {
dev_err(dev, "unknown generation R-Car sound device\n");
return -ENODEV;
}
priv->gen = gen; priv->gen = gen;
/* /*
@ -261,20 +275,13 @@ int rsnd_gen_probe(struct platform_device *pdev,
for (i = 0; i < RSND_REG_MAX; i++) for (i = 0; i < RSND_REG_MAX; i++)
gen->reg_map[i].index = -1; gen->reg_map[i].index = -1;
/* return gen->ops->probe(pdev, info, priv);
* init each module
*/
if (rsnd_is_gen1(priv))
return rsnd_gen1_probe(pdev, info, priv);
dev_err(dev, "unknown generation R-Car sound device\n");
return -ENODEV;
} }
void rsnd_gen_remove(struct platform_device *pdev, void rsnd_gen_remove(struct platform_device *pdev,
struct rsnd_priv *priv) struct rsnd_priv *priv)
{ {
if (rsnd_is_gen1(priv)) struct rsnd_gen *gen = rsnd_priv_to_gen(priv);
rsnd_gen1_remove(pdev, priv);
gen->ops->remove(pdev, priv);
} }