Commit 2df4a02a authored by Yoshihiro Shimoda's avatar Yoshihiro Shimoda Committed by Vinod Koul

dmaengine: rcar-dmac: Use of_data values instead of a macro

Since we will have changed memory mapping of the DMAC in the future,
this patch uses of_data values instead of a macro to calculate
each channel's base offset.
Signed-off-by: default avatarYoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com>
Reviewed-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
Reviewed-by: default avatarSimon Horman <horms+renesas@verge.net.au>
Link: https://lore.kernel.org/r/1568010892-17606-3-git-send-email-yoshihiro.shimoda.uh@renesas.comSigned-off-by: default avatarVinod Koul <vkoul@kernel.org>
parent 6735ab50
...@@ -210,12 +210,20 @@ struct rcar_dmac { ...@@ -210,12 +210,20 @@ struct rcar_dmac {
#define to_rcar_dmac(d) container_of(d, struct rcar_dmac, engine) #define to_rcar_dmac(d) container_of(d, struct rcar_dmac, engine)
/*
* struct rcar_dmac_of_data - This driver's OF data
* @chan_offset_base: DMAC channels base offset
* @chan_offset_stride: DMAC channels offset stride
*/
struct rcar_dmac_of_data {
u32 chan_offset_base;
u32 chan_offset_stride;
};
/* ----------------------------------------------------------------------------- /* -----------------------------------------------------------------------------
* Registers * Registers
*/ */
#define RCAR_DMAC_CHAN_OFFSET(i) (0x8000 + 0x80 * (i))
#define RCAR_DMAISTA 0x0020 #define RCAR_DMAISTA 0x0020
#define RCAR_DMASEC 0x0030 #define RCAR_DMASEC 0x0030
#define RCAR_DMAOR 0x0060 #define RCAR_DMAOR 0x0060
...@@ -1726,6 +1734,7 @@ static const struct dev_pm_ops rcar_dmac_pm = { ...@@ -1726,6 +1734,7 @@ static const struct dev_pm_ops rcar_dmac_pm = {
static int rcar_dmac_chan_probe(struct rcar_dmac *dmac, static int rcar_dmac_chan_probe(struct rcar_dmac *dmac,
struct rcar_dmac_chan *rchan, struct rcar_dmac_chan *rchan,
const struct rcar_dmac_of_data *data,
unsigned int index) unsigned int index)
{ {
struct platform_device *pdev = to_platform_device(dmac->dev); struct platform_device *pdev = to_platform_device(dmac->dev);
...@@ -1735,7 +1744,8 @@ static int rcar_dmac_chan_probe(struct rcar_dmac *dmac, ...@@ -1735,7 +1744,8 @@ static int rcar_dmac_chan_probe(struct rcar_dmac *dmac,
int ret; int ret;
rchan->index = index; rchan->index = index;
rchan->iomem = dmac->iomem + RCAR_DMAC_CHAN_OFFSET(index); rchan->iomem = dmac->iomem + data->chan_offset_base +
data->chan_offset_stride * index;
rchan->mid_rid = -EINVAL; rchan->mid_rid = -EINVAL;
spin_lock_init(&rchan->lock); spin_lock_init(&rchan->lock);
...@@ -1813,10 +1823,15 @@ static int rcar_dmac_probe(struct platform_device *pdev) ...@@ -1813,10 +1823,15 @@ static int rcar_dmac_probe(struct platform_device *pdev)
DMA_SLAVE_BUSWIDTH_32_BYTES | DMA_SLAVE_BUSWIDTH_64_BYTES; DMA_SLAVE_BUSWIDTH_32_BYTES | DMA_SLAVE_BUSWIDTH_64_BYTES;
struct dma_device *engine; struct dma_device *engine;
struct rcar_dmac *dmac; struct rcar_dmac *dmac;
const struct rcar_dmac_of_data *data;
struct resource *mem; struct resource *mem;
unsigned int i; unsigned int i;
int ret; int ret;
data = of_device_get_match_data(&pdev->dev);
if (!data)
return -EINVAL;
dmac = devm_kzalloc(&pdev->dev, sizeof(*dmac), GFP_KERNEL); dmac = devm_kzalloc(&pdev->dev, sizeof(*dmac), GFP_KERNEL);
if (!dmac) if (!dmac)
return -ENOMEM; return -ENOMEM;
...@@ -1901,7 +1916,7 @@ static int rcar_dmac_probe(struct platform_device *pdev) ...@@ -1901,7 +1916,7 @@ static int rcar_dmac_probe(struct platform_device *pdev)
if (!(dmac->channels_mask & BIT(i))) if (!(dmac->channels_mask & BIT(i)))
continue; continue;
ret = rcar_dmac_chan_probe(dmac, &dmac->channels[i], i); ret = rcar_dmac_chan_probe(dmac, &dmac->channels[i], data, i);
if (ret < 0) if (ret < 0)
goto error; goto error;
} }
...@@ -1948,8 +1963,16 @@ static void rcar_dmac_shutdown(struct platform_device *pdev) ...@@ -1948,8 +1963,16 @@ static void rcar_dmac_shutdown(struct platform_device *pdev)
rcar_dmac_stop_all_chan(dmac); rcar_dmac_stop_all_chan(dmac);
} }
static const struct rcar_dmac_of_data rcar_dmac_data = {
.chan_offset_base = 0x8000,
.chan_offset_stride = 0x80,
};
static const struct of_device_id rcar_dmac_of_ids[] = { static const struct of_device_id rcar_dmac_of_ids[] = {
{ .compatible = "renesas,rcar-dmac", }, {
.compatible = "renesas,rcar-dmac",
.data = &rcar_dmac_data,
},
{ /* Sentinel */ } { /* Sentinel */ }
}; };
MODULE_DEVICE_TABLE(of, rcar_dmac_of_ids); MODULE_DEVICE_TABLE(of, rcar_dmac_of_ids);
......
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