aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndres Salomon <dilinger@queued.net>2011-02-17 22:07:13 -0500
committerSamuel Ortiz <sameo@linux.intel.com>2011-03-23 05:41:51 -0400
commitd24f36d352bb9fb72b6611bdca41adbb41cb13ba (patch)
tree74a1e36f65d48048866d80f65ae856a6e73c6642
parent5528e40f973ac427c857593ea0f636b6f65058b0 (diff)
mfd: mfd_cell is now implicitly available to asic3 drivers
No need to explicitly set the cell's platform_data/data_size. Modify clients to use mfd_get_cell helper function instead of accessing platform_data directly. Signed-off-by: Andres Salomon <dilinger@queued.net> Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
-rw-r--r--drivers/mfd/asic3.c6
-rw-r--r--drivers/mmc/host/tmio_mmc.c24
-rw-r--r--drivers/w1/masters/ds1wm.c2
3 files changed, 13 insertions, 19 deletions
diff --git a/drivers/mfd/asic3.c b/drivers/mfd/asic3.c
index c45e6305b26..bd97639cd83 100644
--- a/drivers/mfd/asic3.c
+++ b/drivers/mfd/asic3.c
@@ -810,9 +810,6 @@ static int __init asic3_mfd_probe(struct platform_device *pdev,
810 ds1wm_resources[0].start >>= asic->bus_shift; 810 ds1wm_resources[0].start >>= asic->bus_shift;
811 ds1wm_resources[0].end >>= asic->bus_shift; 811 ds1wm_resources[0].end >>= asic->bus_shift;
812 812
813 asic3_cell_ds1wm.platform_data = &asic3_cell_ds1wm;
814 asic3_cell_ds1wm.data_size = sizeof(asic3_cell_ds1wm);
815
816 /* MMC */ 813 /* MMC */
817 asic->tmio_cnf = ioremap((ASIC3_SD_CONFIG_BASE >> asic->bus_shift) + 814 asic->tmio_cnf = ioremap((ASIC3_SD_CONFIG_BASE >> asic->bus_shift) +
818 mem_sdio->start, 0x400 >> asic->bus_shift); 815 mem_sdio->start, 0x400 >> asic->bus_shift);
@@ -824,9 +821,6 @@ static int __init asic3_mfd_probe(struct platform_device *pdev,
824 asic3_mmc_resources[0].start >>= asic->bus_shift; 821 asic3_mmc_resources[0].start >>= asic->bus_shift;
825 asic3_mmc_resources[0].end >>= asic->bus_shift; 822 asic3_mmc_resources[0].end >>= asic->bus_shift;
826 823
827 asic3_cell_mmc.platform_data = &asic3_cell_mmc;
828 asic3_cell_mmc.data_size = sizeof(asic3_cell_mmc);
829
830 ret = mfd_add_devices(&pdev->dev, pdev->id, 824 ret = mfd_add_devices(&pdev->dev, pdev->id,
831 &asic3_cell_ds1wm, 1, mem, asic->irq_base); 825 &asic3_cell_ds1wm, 1, mem, asic->irq_base);
832 if (ret < 0) 826 if (ret < 0)
diff --git a/drivers/mmc/host/tmio_mmc.c b/drivers/mmc/host/tmio_mmc.c
index ac52eb65395..67c9d0f595e 100644
--- a/drivers/mmc/host/tmio_mmc.c
+++ b/drivers/mmc/host/tmio_mmc.c
@@ -303,7 +303,7 @@ static void tmio_mmc_set_clock(struct tmio_mmc_host *host, int new_clock)
303 303
304static void tmio_mmc_clk_stop(struct tmio_mmc_host *host) 304static void tmio_mmc_clk_stop(struct tmio_mmc_host *host)
305{ 305{
306 struct mfd_cell *cell = host->pdev->dev.platform_data; 306 struct mfd_cell *cell = mfd_get_cell(host->pdev);
307 struct tmio_mmc_data *pdata = cell->driver_data; 307 struct tmio_mmc_data *pdata = cell->driver_data;
308 308
309 /* 309 /*
@@ -327,7 +327,7 @@ static void tmio_mmc_clk_stop(struct tmio_mmc_host *host)
327 327
328static void tmio_mmc_clk_start(struct tmio_mmc_host *host) 328static void tmio_mmc_clk_start(struct tmio_mmc_host *host)
329{ 329{
330 struct mfd_cell *cell = host->pdev->dev.platform_data; 330 struct mfd_cell *cell = mfd_get_cell(host->pdev);
331 struct tmio_mmc_data *pdata = cell->driver_data; 331 struct tmio_mmc_data *pdata = cell->driver_data;
332 332
333 sd_ctrl_write16(host, CTL_SD_CARD_CLK_CTL, 0x0100 | 333 sd_ctrl_write16(host, CTL_SD_CARD_CLK_CTL, 0x0100 |
@@ -669,7 +669,7 @@ out:
669static irqreturn_t tmio_mmc_irq(int irq, void *devid) 669static irqreturn_t tmio_mmc_irq(int irq, void *devid)
670{ 670{
671 struct tmio_mmc_host *host = devid; 671 struct tmio_mmc_host *host = devid;
672 struct mfd_cell *cell = host->pdev->dev.platform_data; 672 struct mfd_cell *cell = mfd_get_cell(host->pdev);
673 struct tmio_mmc_data *pdata = cell->driver_data; 673 struct tmio_mmc_data *pdata = cell->driver_data;
674 unsigned int ireg, irq_mask, status; 674 unsigned int ireg, irq_mask, status;
675 unsigned int sdio_ireg, sdio_irq_mask, sdio_status; 675 unsigned int sdio_ireg, sdio_irq_mask, sdio_status;
@@ -799,7 +799,7 @@ static void tmio_mmc_start_dma_rx(struct tmio_mmc_host *host)
799 struct scatterlist *sg = host->sg_ptr, *sg_tmp; 799 struct scatterlist *sg = host->sg_ptr, *sg_tmp;
800 struct dma_async_tx_descriptor *desc = NULL; 800 struct dma_async_tx_descriptor *desc = NULL;
801 struct dma_chan *chan = host->chan_rx; 801 struct dma_chan *chan = host->chan_rx;
802 struct mfd_cell *cell = host->pdev->dev.platform_data; 802 struct mfd_cell *cell = mfd_get_cell(host->pdev);
803 struct tmio_mmc_data *pdata = cell->driver_data; 803 struct tmio_mmc_data *pdata = cell->driver_data;
804 dma_cookie_t cookie; 804 dma_cookie_t cookie;
805 int ret, i; 805 int ret, i;
@@ -869,7 +869,7 @@ static void tmio_mmc_start_dma_tx(struct tmio_mmc_host *host)
869 struct scatterlist *sg = host->sg_ptr, *sg_tmp; 869 struct scatterlist *sg = host->sg_ptr, *sg_tmp;
870 struct dma_async_tx_descriptor *desc = NULL; 870 struct dma_async_tx_descriptor *desc = NULL;
871 struct dma_chan *chan = host->chan_tx; 871 struct dma_chan *chan = host->chan_tx;
872 struct mfd_cell *cell = host->pdev->dev.platform_data; 872 struct mfd_cell *cell = mfd_get_cell(host->pdev);
873 struct tmio_mmc_data *pdata = cell->driver_data; 873 struct tmio_mmc_data *pdata = cell->driver_data;
874 dma_cookie_t cookie; 874 dma_cookie_t cookie;
875 int ret, i; 875 int ret, i;
@@ -1063,7 +1063,7 @@ static void tmio_mmc_release_dma(struct tmio_mmc_host *host)
1063static int tmio_mmc_start_data(struct tmio_mmc_host *host, 1063static int tmio_mmc_start_data(struct tmio_mmc_host *host,
1064 struct mmc_data *data) 1064 struct mmc_data *data)
1065{ 1065{
1066 struct mfd_cell *cell = host->pdev->dev.platform_data; 1066 struct mfd_cell *cell = mfd_get_cell(host->pdev);
1067 struct tmio_mmc_data *pdata = cell->driver_data; 1067 struct tmio_mmc_data *pdata = cell->driver_data;
1068 1068
1069 pr_debug("setup data transfer: blocksize %08x nr_blocks %d\n", 1069 pr_debug("setup data transfer: blocksize %08x nr_blocks %d\n",
@@ -1169,7 +1169,7 @@ static void tmio_mmc_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
1169static int tmio_mmc_get_ro(struct mmc_host *mmc) 1169static int tmio_mmc_get_ro(struct mmc_host *mmc)
1170{ 1170{
1171 struct tmio_mmc_host *host = mmc_priv(mmc); 1171 struct tmio_mmc_host *host = mmc_priv(mmc);
1172 struct mfd_cell *cell = host->pdev->dev.platform_data; 1172 struct mfd_cell *cell = mfd_get_cell(host->pdev);
1173 struct tmio_mmc_data *pdata = cell->driver_data; 1173 struct tmio_mmc_data *pdata = cell->driver_data;
1174 1174
1175 return ((pdata->flags & TMIO_MMC_WRPROTECT_DISABLE) || 1175 return ((pdata->flags & TMIO_MMC_WRPROTECT_DISABLE) ||
@@ -1179,7 +1179,7 @@ static int tmio_mmc_get_ro(struct mmc_host *mmc)
1179static int tmio_mmc_get_cd(struct mmc_host *mmc) 1179static int tmio_mmc_get_cd(struct mmc_host *mmc)
1180{ 1180{
1181 struct tmio_mmc_host *host = mmc_priv(mmc); 1181 struct tmio_mmc_host *host = mmc_priv(mmc);
1182 struct mfd_cell *cell = host->pdev->dev.platform_data; 1182 struct mfd_cell *cell = mfd_get_cell(host->pdev);
1183 struct tmio_mmc_data *pdata = cell->driver_data; 1183 struct tmio_mmc_data *pdata = cell->driver_data;
1184 1184
1185 if (!pdata->get_cd) 1185 if (!pdata->get_cd)
@@ -1199,7 +1199,7 @@ static const struct mmc_host_ops tmio_mmc_ops = {
1199#ifdef CONFIG_PM 1199#ifdef CONFIG_PM
1200static int tmio_mmc_suspend(struct platform_device *dev, pm_message_t state) 1200static int tmio_mmc_suspend(struct platform_device *dev, pm_message_t state)
1201{ 1201{
1202 struct mfd_cell *cell = (struct mfd_cell *)dev->dev.platform_data; 1202 struct mfd_cell *cell = mfd_get_cell(dev);
1203 struct mmc_host *mmc = platform_get_drvdata(dev); 1203 struct mmc_host *mmc = platform_get_drvdata(dev);
1204 int ret; 1204 int ret;
1205 1205
@@ -1214,7 +1214,7 @@ static int tmio_mmc_suspend(struct platform_device *dev, pm_message_t state)
1214 1214
1215static int tmio_mmc_resume(struct platform_device *dev) 1215static int tmio_mmc_resume(struct platform_device *dev)
1216{ 1216{
1217 struct mfd_cell *cell = (struct mfd_cell *)dev->dev.platform_data; 1217 struct mfd_cell *cell = mfd_get_cell(dev);
1218 struct mmc_host *mmc = platform_get_drvdata(dev); 1218 struct mmc_host *mmc = platform_get_drvdata(dev);
1219 int ret = 0; 1219 int ret = 0;
1220 1220
@@ -1237,7 +1237,7 @@ out:
1237 1237
1238static int __devinit tmio_mmc_probe(struct platform_device *dev) 1238static int __devinit tmio_mmc_probe(struct platform_device *dev)
1239{ 1239{
1240 struct mfd_cell *cell = (struct mfd_cell *)dev->dev.platform_data; 1240 struct mfd_cell *cell = mfd_get_cell(dev);
1241 struct tmio_mmc_data *pdata; 1241 struct tmio_mmc_data *pdata;
1242 struct resource *res_ctl; 1242 struct resource *res_ctl;
1243 struct tmio_mmc_host *host; 1243 struct tmio_mmc_host *host;
@@ -1352,7 +1352,7 @@ out:
1352 1352
1353static int __devexit tmio_mmc_remove(struct platform_device *dev) 1353static int __devexit tmio_mmc_remove(struct platform_device *dev)
1354{ 1354{
1355 struct mfd_cell *cell = (struct mfd_cell *)dev->dev.platform_data; 1355 struct mfd_cell *cell = mfd_get_cell(dev);
1356 struct mmc_host *mmc = platform_get_drvdata(dev); 1356 struct mmc_host *mmc = platform_get_drvdata(dev);
1357 1357
1358 platform_set_drvdata(dev, NULL); 1358 platform_set_drvdata(dev, NULL);
diff --git a/drivers/w1/masters/ds1wm.c b/drivers/w1/masters/ds1wm.c
index 6b85e7fefa4..94f55d80f9a 100644
--- a/drivers/w1/masters/ds1wm.c
+++ b/drivers/w1/masters/ds1wm.c
@@ -336,7 +336,7 @@ static int ds1wm_probe(struct platform_device *pdev)
336 if (!pdev) 336 if (!pdev)
337 return -ENODEV; 337 return -ENODEV;
338 338
339 cell = pdev->dev.platform_data; 339 cell = mfd_get_cell(pdev);
340 if (!cell) 340 if (!cell)
341 return -ENODEV; 341 return -ENODEV;
342 342