Commit dd27d808 authored by Kuninori Morimoto's avatar Kuninori Morimoto Committed by Mark Brown

ASoC: rsnd: remove ssiu from ssi.c

Now, SSI_MODE0/1 are controlled under scu.c
ssiu is no longer needed on ssi.c
Signed-off-by: default avatarKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: default avatarMark Brown <broonie@linaro.org>
parent 7b5ce975
...@@ -280,7 +280,8 @@ struct rsnd_priv { ...@@ -280,7 +280,8 @@ struct rsnd_priv {
/* /*
* below value will be filled on rsnd_ssi_probe() * below value will be filled on rsnd_ssi_probe()
*/ */
void *ssiu; void *ssi;
int ssi_nr;
/* /*
* below value will be filled on rsnd_dai_probe() * below value will be filled on rsnd_dai_probe()
......
...@@ -74,18 +74,13 @@ struct rsnd_ssi { ...@@ -74,18 +74,13 @@ struct rsnd_ssi {
unsigned int rate; unsigned int rate;
}; };
struct rsnd_ssiu {
int ssi_nr;
struct rsnd_ssi *ssi;
};
#define for_each_rsnd_ssi(pos, priv, i) \ #define for_each_rsnd_ssi(pos, priv, i) \
for (i = 0; \ for (i = 0; \
(i < rsnd_ssi_nr(priv)) && \ (i < rsnd_ssi_nr(priv)) && \
((pos) = ((struct rsnd_ssiu *)((priv)->ssiu))->ssi + i); \ ((pos) = ((struct rsnd_ssi *)(priv)->ssi + i)); \
i++) i++)
#define rsnd_ssi_nr(priv) (((struct rsnd_ssiu *)((priv)->ssiu))->ssi_nr) #define rsnd_ssi_nr(priv) ((priv)->ssi_nr)
#define rsnd_mod_to_ssi(_mod) container_of((_mod), struct rsnd_ssi, mod) #define rsnd_mod_to_ssi(_mod) container_of((_mod), struct rsnd_ssi, mod)
#define rsnd_dma_to_ssi(dma) rsnd_mod_to_ssi(rsnd_dma_to_mod(dma)) #define rsnd_dma_to_ssi(dma) rsnd_mod_to_ssi(rsnd_dma_to_mod(dma))
#define rsnd_ssi_pio_available(ssi) ((ssi)->info->pio_irq > 0) #define rsnd_ssi_pio_available(ssi) ((ssi)->info->pio_irq > 0)
...@@ -94,8 +89,6 @@ struct rsnd_ssiu { ...@@ -94,8 +89,6 @@ struct rsnd_ssiu {
#define rsnd_ssi_clk_from_parent(ssi) ((ssi)->parent) #define rsnd_ssi_clk_from_parent(ssi) ((ssi)->parent)
#define rsnd_ssi_mode_flags(p) ((p)->info->flags) #define rsnd_ssi_mode_flags(p) ((p)->info->flags)
#define rsnd_ssi_dai_id(ssi) ((ssi)->info->dai_id) #define rsnd_ssi_dai_id(ssi) ((ssi)->info->dai_id)
#define rsnd_ssi_to_ssiu(ssi)\
(((struct rsnd_ssiu *)((ssi) - rsnd_mod_id(&(ssi)->mod))) - 1)
static void rsnd_ssi_status_check(struct rsnd_mod *mod, static void rsnd_ssi_status_check(struct rsnd_mod *mod,
u32 bit) u32 bit)
...@@ -515,7 +508,7 @@ struct rsnd_mod *rsnd_ssi_mod_get(struct rsnd_priv *priv, int id) ...@@ -515,7 +508,7 @@ struct rsnd_mod *rsnd_ssi_mod_get(struct rsnd_priv *priv, int id)
if (WARN_ON(id < 0 || id >= rsnd_ssi_nr(priv))) if (WARN_ON(id < 0 || id >= rsnd_ssi_nr(priv)))
id = 0; id = 0;
return &(((struct rsnd_ssiu *)(priv->ssiu))->ssi + id)->mod; return &((struct rsnd_ssi *)(priv->ssi) + id)->mod;
} }
int rsnd_ssi_is_pin_sharing(struct rsnd_mod *mod) int rsnd_ssi_is_pin_sharing(struct rsnd_mod *mod)
...@@ -552,7 +545,6 @@ int rsnd_ssi_probe(struct platform_device *pdev, ...@@ -552,7 +545,6 @@ int rsnd_ssi_probe(struct platform_device *pdev,
struct device *dev = rsnd_priv_to_dev(priv); struct device *dev = rsnd_priv_to_dev(priv);
struct rsnd_mod_ops *ops; struct rsnd_mod_ops *ops;
struct clk *clk; struct clk *clk;
struct rsnd_ssiu *ssiu;
struct rsnd_ssi *ssi; struct rsnd_ssi *ssi;
char name[RSND_SSI_NAME_SIZE]; char name[RSND_SSI_NAME_SIZE];
int i, nr, ret; int i, nr, ret;
...@@ -561,16 +553,14 @@ int rsnd_ssi_probe(struct platform_device *pdev, ...@@ -561,16 +553,14 @@ int rsnd_ssi_probe(struct platform_device *pdev,
* init SSI * init SSI
*/ */
nr = info->ssi_info_nr; nr = info->ssi_info_nr;
ssiu = devm_kzalloc(dev, sizeof(*ssiu) + (sizeof(*ssi) * nr), ssi = devm_kzalloc(dev, sizeof(*ssi) * nr, GFP_KERNEL);
GFP_KERNEL); if (!ssi) {
if (!ssiu) {
dev_err(dev, "SSI allocate failed\n"); dev_err(dev, "SSI allocate failed\n");
return -ENOMEM; return -ENOMEM;
} }
priv->ssiu = ssiu; priv->ssi = ssi;
ssiu->ssi = (struct rsnd_ssi *)(ssiu + 1); priv->ssi_nr = nr;
ssiu->ssi_nr = nr;
for_each_rsnd_ssi(ssi, priv, i) { for_each_rsnd_ssi(ssi, priv, i) {
pinfo = &info->ssi_info[i]; pinfo = &info->ssi_info[i];
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment