|
@@ -168,7 +168,7 @@ static int rsnd_gen_regmap_init(struct rsnd_priv *priv,
|
|
* SSI : 0xec541000 / 0xec241008 / 0xec24100c
|
|
* SSI : 0xec541000 / 0xec241008 / 0xec24100c
|
|
* SSIU: 0xec541000 / 0xec100000 / 0xec100000 / 0xec400000 / 0xec400000
|
|
* SSIU: 0xec541000 / 0xec100000 / 0xec100000 / 0xec400000 / 0xec400000
|
|
* SCU : 0xec500000 / 0xec000000 / 0xec004000 / 0xec300000 / 0xec304000
|
|
* SCU : 0xec500000 / 0xec000000 / 0xec004000 / 0xec300000 / 0xec304000
|
|
- * CMD : 0xec500000 / 0xec008000 0xec308000
|
|
|
|
|
|
+ * CMD : 0xec500000 / / 0xec008000 0xec308000
|
|
*/
|
|
*/
|
|
#define RDMA_SSI_I_N(addr, i) (addr ##_reg - 0x00300000 + (0x40 * i) + 0x8)
|
|
#define RDMA_SSI_I_N(addr, i) (addr ##_reg - 0x00300000 + (0x40 * i) + 0x8)
|
|
#define RDMA_SSI_O_N(addr, i) (addr ##_reg - 0x00300000 + (0x40 * i) + 0xc)
|
|
#define RDMA_SSI_O_N(addr, i) (addr ##_reg - 0x00300000 + (0x40 * i) + 0xc)
|
|
@@ -188,14 +188,13 @@ 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))
|
|
|
|
|
|
-static void rsnd_gen2_dma_addr(struct rsnd_priv *priv,
|
|
|
|
- struct rsnd_dma *dma,
|
|
|
|
- struct dma_slave_config *cfg,
|
|
|
|
- int is_play, int slave_id)
|
|
|
|
|
|
+static dma_addr_t
|
|
|
|
+rsnd_gen2_dma_addr(struct rsnd_priv *priv,
|
|
|
|
+ struct rsnd_mod *mod,
|
|
|
|
+ int is_play, int is_from)
|
|
{
|
|
{
|
|
struct platform_device *pdev = rsnd_priv_to_pdev(priv);
|
|
struct platform_device *pdev = rsnd_priv_to_pdev(priv);
|
|
struct device *dev = rsnd_priv_to_dev(priv);
|
|
struct device *dev = rsnd_priv_to_dev(priv);
|
|
- struct rsnd_mod *mod = rsnd_dma_to_mod(dma);
|
|
|
|
struct rsnd_dai_stream *io = rsnd_mod_to_io(mod);
|
|
struct rsnd_dai_stream *io = rsnd_mod_to_io(mod);
|
|
dma_addr_t ssi_reg = platform_get_resource(pdev,
|
|
dma_addr_t ssi_reg = platform_get_resource(pdev,
|
|
IORESOURCE_MEM, RSND_GEN2_SSI)->start;
|
|
IORESOURCE_MEM, RSND_GEN2_SSI)->start;
|
|
@@ -206,76 +205,68 @@ static void rsnd_gen2_dma_addr(struct rsnd_priv *priv,
|
|
int use_dvc = !!rsnd_io_to_mod_dvc(io);
|
|
int use_dvc = !!rsnd_io_to_mod_dvc(io);
|
|
int id = rsnd_mod_id(mod);
|
|
int id = rsnd_mod_id(mod);
|
|
struct dma_addr {
|
|
struct dma_addr {
|
|
- dma_addr_t src_addr;
|
|
|
|
- dma_addr_t dst_addr;
|
|
|
|
|
|
+ dma_addr_t out_addr;
|
|
|
|
+ dma_addr_t in_addr;
|
|
} dma_addrs[3][2][3] = {
|
|
} dma_addrs[3][2][3] = {
|
|
/* SRC */
|
|
/* SRC */
|
|
{{{ 0, 0 },
|
|
{{{ 0, 0 },
|
|
/* Capture */
|
|
/* Capture */
|
|
- { RDMA_SRC_O_N(src, id), 0 },
|
|
|
|
- { RDMA_CMD_O_N(src, id), 0 } },
|
|
|
|
|
|
+ { RDMA_SRC_O_N(src, id), RDMA_SRC_I_P(src, id) },
|
|
|
|
+ { RDMA_CMD_O_N(src, id), RDMA_SRC_I_P(src, id) } },
|
|
/* Playback */
|
|
/* Playback */
|
|
{{ 0, 0, },
|
|
{{ 0, 0, },
|
|
- { 0, RDMA_SRC_I_N(src, id) },
|
|
|
|
- { 0, RDMA_SRC_I_N(src, id) } }
|
|
|
|
|
|
+ { RDMA_SRC_O_P(src, id), RDMA_SRC_I_N(src, id) },
|
|
|
|
+ { RDMA_CMD_O_P(src, id), RDMA_SRC_I_N(src, id) } }
|
|
},
|
|
},
|
|
/* SSI */
|
|
/* SSI */
|
|
/* Capture */
|
|
/* Capture */
|
|
{{{ RDMA_SSI_O_N(ssi, id), 0 },
|
|
{{{ RDMA_SSI_O_N(ssi, id), 0 },
|
|
- { 0, 0 },
|
|
|
|
- { 0, 0 } },
|
|
|
|
|
|
+ { RDMA_SSIU_O_P(ssi, id), 0 },
|
|
|
|
+ { RDMA_SSIU_O_P(ssi, id), 0 } },
|
|
/* Playback */
|
|
/* Playback */
|
|
{{ 0, RDMA_SSI_I_N(ssi, id) },
|
|
{{ 0, RDMA_SSI_I_N(ssi, id) },
|
|
- { 0, 0 },
|
|
|
|
- { 0, 0 } }
|
|
|
|
|
|
+ { 0, RDMA_SSIU_I_P(ssi, id) },
|
|
|
|
+ { 0, RDMA_SSIU_I_P(ssi, id) } }
|
|
},
|
|
},
|
|
/* SSIU */
|
|
/* SSIU */
|
|
/* Capture */
|
|
/* Capture */
|
|
{{{ RDMA_SSIU_O_N(ssi, id), 0 },
|
|
{{{ RDMA_SSIU_O_N(ssi, id), 0 },
|
|
- { RDMA_SSIU_O_P(ssi, id), RDMA_SRC_I_P(src, id) },
|
|
|
|
- { RDMA_SSIU_O_P(ssi, id), RDMA_SRC_I_P(src, id) } },
|
|
|
|
|
|
+ { RDMA_SSIU_O_P(ssi, id), 0 },
|
|
|
|
+ { RDMA_SSIU_O_P(ssi, id), 0 } },
|
|
/* Playback */
|
|
/* Playback */
|
|
{{ 0, RDMA_SSIU_I_N(ssi, id) },
|
|
{{ 0, RDMA_SSIU_I_N(ssi, id) },
|
|
- { RDMA_SRC_O_P(src, id), RDMA_SSIU_I_P(ssi, id) },
|
|
|
|
- { RDMA_CMD_O_P(src, id), RDMA_SSIU_I_P(ssi, id) } } },
|
|
|
|
|
|
+ { 0, RDMA_SSIU_I_P(ssi, id) },
|
|
|
|
+ { 0, RDMA_SSIU_I_P(ssi, id) } } },
|
|
};
|
|
};
|
|
|
|
|
|
/* 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");
|
|
- return;
|
|
|
|
- }
|
|
|
|
|
|
|
|
/* use SSIU or SSI ? */
|
|
/* use SSIU or SSI ? */
|
|
if (is_ssi && (0 == strcmp(rsnd_mod_dma_name(mod), "ssiu")))
|
|
if (is_ssi && (0 == strcmp(rsnd_mod_dma_name(mod), "ssiu")))
|
|
is_ssi++;
|
|
is_ssi++;
|
|
|
|
|
|
- cfg->src_addr = dma_addrs[is_ssi][is_play][use_src + use_dvc].src_addr;
|
|
|
|
- cfg->dst_addr = dma_addrs[is_ssi][is_play][use_src + use_dvc].dst_addr;
|
|
|
|
-
|
|
|
|
- dev_dbg(dev, "dma%d addr - src : %x / dst : %x\n",
|
|
|
|
- id, cfg->src_addr, cfg->dst_addr);
|
|
|
|
|
|
+ return (is_from) ?
|
|
|
|
+ dma_addrs[is_ssi][is_play][use_src + use_dvc].out_addr :
|
|
|
|
+ dma_addrs[is_ssi][is_play][use_src + use_dvc].in_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)
|
|
|
|
|
|
+dma_addr_t rsnd_gen_dma_addr(struct rsnd_priv *priv,
|
|
|
|
+ struct rsnd_mod *mod,
|
|
|
|
+ int is_play, int is_from)
|
|
{
|
|
{
|
|
- 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
|
|
* gen1 uses default DMA addr
|
|
*/
|
|
*/
|
|
if (rsnd_is_gen1(priv))
|
|
if (rsnd_is_gen1(priv))
|
|
- return;
|
|
|
|
|
|
+ return 0;
|
|
|
|
|
|
- rsnd_gen2_dma_addr(priv, dma, cfg, is_play, slave_id);
|
|
|
|
-}
|
|
|
|
|
|
+ if (!mod)
|
|
|
|
+ return 0;
|
|
|
|
|
|
|
|
+ return rsnd_gen2_dma_addr(priv, mod, is_play, is_from);
|
|
|
|
+}
|
|
|
|
|
|
/*
|
|
/*
|
|
* Gen2
|
|
* Gen2
|