Commit d790c342 authored by Emil Renner Berthing's avatar Emil Renner Berthing Committed by Mark Brown

spi: rockchip: remove master pointer from dev data

In almost all cases we already have a pointer to the
spi master structure where we have the driver data.

The only exceptions are the dma callbacks which are
easily fixed by passing them the master and using
spi_master_get_devdata to retrieve the driver data.
Signed-off-by: default avatarEmil Renner Berthing <kernel@esmil.dk>
Tested-by: default avatarHeiko Stuebner <heiko@sntech.de>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent eee06a9e
...@@ -159,7 +159,6 @@ ...@@ -159,7 +159,6 @@
struct rockchip_spi { struct rockchip_spi {
struct device *dev; struct device *dev;
struct spi_master *master;
struct clk *spiclk; struct clk *spiclk;
struct clk *apb_pclk; struct clk *apb_pclk;
...@@ -350,19 +349,21 @@ static int rockchip_spi_pio_transfer(struct rockchip_spi *rs) ...@@ -350,19 +349,21 @@ static int rockchip_spi_pio_transfer(struct rockchip_spi *rs)
static void rockchip_spi_dma_rxcb(void *data) static void rockchip_spi_dma_rxcb(void *data)
{ {
struct rockchip_spi *rs = data; struct spi_master *master = data;
struct rockchip_spi *rs = spi_master_get_devdata(master);
int state = atomic_fetch_andnot(RXDMA, &rs->state); int state = atomic_fetch_andnot(RXDMA, &rs->state);
if (state & TXDMA) if (state & TXDMA)
return; return;
spi_enable_chip(rs, false); spi_enable_chip(rs, false);
spi_finalize_current_transfer(rs->master); spi_finalize_current_transfer(master);
} }
static void rockchip_spi_dma_txcb(void *data) static void rockchip_spi_dma_txcb(void *data)
{ {
struct rockchip_spi *rs = data; struct spi_master *master = data;
struct rockchip_spi *rs = spi_master_get_devdata(master);
int state = atomic_fetch_andnot(TXDMA, &rs->state); int state = atomic_fetch_andnot(TXDMA, &rs->state);
if (state & RXDMA) if (state & RXDMA)
...@@ -372,7 +373,7 @@ static void rockchip_spi_dma_txcb(void *data) ...@@ -372,7 +373,7 @@ static void rockchip_spi_dma_txcb(void *data)
wait_for_idle(rs); wait_for_idle(rs);
spi_enable_chip(rs, false); spi_enable_chip(rs, false);
spi_finalize_current_transfer(rs->master); spi_finalize_current_transfer(master);
} }
static int rockchip_spi_prepare_dma(struct rockchip_spi *rs, static int rockchip_spi_prepare_dma(struct rockchip_spi *rs,
...@@ -401,7 +402,7 @@ static int rockchip_spi_prepare_dma(struct rockchip_spi *rs, ...@@ -401,7 +402,7 @@ static int rockchip_spi_prepare_dma(struct rockchip_spi *rs,
return -EINVAL; return -EINVAL;
rxdesc->callback = rockchip_spi_dma_rxcb; rxdesc->callback = rockchip_spi_dma_rxcb;
rxdesc->callback_param = rs; rxdesc->callback_param = master;
} }
txdesc = NULL; txdesc = NULL;
...@@ -426,7 +427,7 @@ static int rockchip_spi_prepare_dma(struct rockchip_spi *rs, ...@@ -426,7 +427,7 @@ static int rockchip_spi_prepare_dma(struct rockchip_spi *rs,
} }
txdesc->callback = rockchip_spi_dma_txcb; txdesc->callback = rockchip_spi_dma_txcb;
txdesc->callback_param = rs; txdesc->callback_param = master;
} }
/* rx must be started before tx due to spi instinct */ /* rx must be started before tx due to spi instinct */
...@@ -633,7 +634,6 @@ static int rockchip_spi_probe(struct platform_device *pdev) ...@@ -633,7 +634,6 @@ static int rockchip_spi_probe(struct platform_device *pdev)
spi_enable_chip(rs, false); spi_enable_chip(rs, false);
rs->master = master;
rs->dev = &pdev->dev; rs->dev = &pdev->dev;
rs->max_freq = clk_get_rate(rs->spiclk); rs->max_freq = clk_get_rate(rs->spiclk);
...@@ -746,9 +746,8 @@ static int rockchip_spi_suspend(struct device *dev) ...@@ -746,9 +746,8 @@ static int rockchip_spi_suspend(struct device *dev)
{ {
int ret; int ret;
struct spi_master *master = dev_get_drvdata(dev); struct spi_master *master = dev_get_drvdata(dev);
struct rockchip_spi *rs = spi_master_get_devdata(master);
ret = spi_master_suspend(rs->master); ret = spi_master_suspend(master);
if (ret < 0) if (ret < 0)
return ret; return ret;
...@@ -773,7 +772,7 @@ static int rockchip_spi_resume(struct device *dev) ...@@ -773,7 +772,7 @@ static int rockchip_spi_resume(struct device *dev)
if (ret < 0) if (ret < 0)
return ret; return ret;
ret = spi_master_resume(rs->master); ret = spi_master_resume(master);
if (ret < 0) { if (ret < 0) {
clk_disable_unprepare(rs->spiclk); clk_disable_unprepare(rs->spiclk);
clk_disable_unprepare(rs->apb_pclk); clk_disable_unprepare(rs->apb_pclk);
......
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