ASoC: rsnd: fixup rsnd_gen_dma_addr() for Gen1
ad32d0c7b0
(ASoC: rsnd: add rsnd_gen_dma_addr() for DMAC addr)
added rsnd_gen_dma_addr() to calculate DMA addr,
but, it is necessary only for Gen2.
This patch ignores Gen1 case.
Kernel will be panic without this patch.
Special thanks to Simon
Reported-by: Simon Horman <horms@verge.net.au>
Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Tested-by: Simon Horman <horms+renesas@verge.net.au>
Signed-off-by: Mark Brown <broonie@linaro.org>
This commit is contained in:
parent
4cf612780c
commit
64eae986fc
|
@ -184,7 +184,7 @@ static int rsnd_gen_regmap_init(struct rsnd_priv *priv,
|
||||||
#define RDMA_CMD_O_N(addr, i) (addr ##_reg - 0x004f8000 + (0x400 * i))
|
#define RDMA_CMD_O_N(addr, i) (addr ##_reg - 0x004f8000 + (0x400 * i))
|
||||||
#define RDMA_CMD_O_P(addr, i) (addr ##_reg - 0x001f8000 + (0x400 * i))
|
#define RDMA_CMD_O_P(addr, i) (addr ##_reg - 0x001f8000 + (0x400 * i))
|
||||||
|
|
||||||
void rsnd_gen_dma_addr(struct rsnd_priv *priv,
|
static void rsnd_gen2_dma_addr(struct rsnd_priv *priv,
|
||||||
struct rsnd_dma *dma,
|
struct rsnd_dma *dma,
|
||||||
struct dma_slave_config *cfg,
|
struct dma_slave_config *cfg,
|
||||||
int is_play, int slave_id)
|
int is_play, int slave_id)
|
||||||
|
@ -226,17 +226,6 @@ void rsnd_gen_dma_addr(struct rsnd_priv *priv,
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
cfg->slave_id = slave_id;
|
|
||||||
cfg->src_addr = 0;
|
|
||||||
cfg->dst_addr = 0;
|
|
||||||
cfg->direction = is_play ? DMA_MEM_TO_DEV : DMA_DEV_TO_MEM;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* gen1 uses default DMA addr
|
|
||||||
*/
|
|
||||||
if (rsnd_is_gen1(priv))
|
|
||||||
return;
|
|
||||||
|
|
||||||
/* it shouldn't happen */
|
/* it shouldn't happen */
|
||||||
if (use_dvc & !use_src) {
|
if (use_dvc & !use_src) {
|
||||||
dev_err(dev, "DVC is selected without SRC\n");
|
dev_err(dev, "DVC is selected without SRC\n");
|
||||||
|
@ -250,6 +239,26 @@ void rsnd_gen_dma_addr(struct rsnd_priv *priv,
|
||||||
id, cfg->src_addr, cfg->dst_addr);
|
id, cfg->src_addr, cfg->dst_addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void rsnd_gen_dma_addr(struct rsnd_priv *priv,
|
||||||
|
struct rsnd_dma *dma,
|
||||||
|
struct dma_slave_config *cfg,
|
||||||
|
int is_play, int slave_id)
|
||||||
|
{
|
||||||
|
cfg->slave_id = slave_id;
|
||||||
|
cfg->src_addr = 0;
|
||||||
|
cfg->dst_addr = 0;
|
||||||
|
cfg->direction = is_play ? DMA_MEM_TO_DEV : DMA_DEV_TO_MEM;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* gen1 uses default DMA addr
|
||||||
|
*/
|
||||||
|
if (rsnd_is_gen1(priv))
|
||||||
|
return;
|
||||||
|
|
||||||
|
rsnd_gen2_dma_addr(priv, dma, cfg, is_play, slave_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Gen2
|
* Gen2
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Reference in New Issue