diff options
| -rw-r--r-- | drivers/mfd/mfd-core.c | 2 | ||||
| -rw-r--r-- | drivers/mfd/tc6393xb.c | 4 | ||||
| -rw-r--r-- | include/linux/mfd/core.h | 13 |
3 files changed, 12 insertions, 7 deletions
diff --git a/drivers/mfd/mfd-core.c b/drivers/mfd/mfd-core.c index 50207700140c..ad4e4d16a36a 100644 --- a/drivers/mfd/mfd-core.c +++ b/drivers/mfd/mfd-core.c | |||
| @@ -32,7 +32,7 @@ static int mfd_add_device(struct platform_device *parent, | |||
| 32 | pdev->dev.parent = &parent->dev; | 32 | pdev->dev.parent = &parent->dev; |
| 33 | 33 | ||
| 34 | ret = platform_device_add_data(pdev, | 34 | ret = platform_device_add_data(pdev, |
| 35 | cell, sizeof(struct mfd_cell)); | 35 | cell->platform_data, cell->data_size); |
| 36 | if (ret) | 36 | if (ret) |
| 37 | goto fail_device; | 37 | goto fail_device; |
| 38 | 38 | ||
diff --git a/drivers/mfd/tc6393xb.c b/drivers/mfd/tc6393xb.c index 94e55e8e7ce6..9908aaa4881a 100644 --- a/drivers/mfd/tc6393xb.c +++ b/drivers/mfd/tc6393xb.c | |||
| @@ -466,6 +466,10 @@ static int __devinit tc6393xb_probe(struct platform_device *dev) | |||
| 466 | tc6393xb_attach_irq(dev); | 466 | tc6393xb_attach_irq(dev); |
| 467 | 467 | ||
| 468 | tc6393xb_cells[TC6393XB_CELL_NAND].driver_data = tcpd->nand_data; | 468 | tc6393xb_cells[TC6393XB_CELL_NAND].driver_data = tcpd->nand_data; |
| 469 | tc6393xb_cells[TC6393XB_CELL_NAND].platform_data = | ||
| 470 | &tc6393xb_cells[TC6393XB_CELL_NAND]; | ||
| 471 | tc6393xb_cells[TC6393XB_CELL_NAND].data_size = | ||
| 472 | sizeof(tc6393xb_cells[TC6393XB_CELL_NAND]); | ||
| 469 | 473 | ||
| 470 | retval = mfd_add_devices(dev, | 474 | retval = mfd_add_devices(dev, |
| 471 | tc6393xb_cells, ARRAY_SIZE(tc6393xb_cells), | 475 | tc6393xb_cells, ARRAY_SIZE(tc6393xb_cells), |
diff --git a/include/linux/mfd/core.h b/include/linux/mfd/core.h index b7cbb9968339..ea45d4a5a2ac 100644 --- a/include/linux/mfd/core.h +++ b/include/linux/mfd/core.h | |||
| @@ -29,7 +29,13 @@ struct mfd_cell { | |||
| 29 | int (*suspend)(struct platform_device *dev); | 29 | int (*suspend)(struct platform_device *dev); |
| 30 | int (*resume)(struct platform_device *dev); | 30 | int (*resume)(struct platform_device *dev); |
| 31 | 31 | ||
| 32 | void *driver_data; /* driver-specific data */ | 32 | /* driver-specific data for MFD-aware "cell" drivers */ |
| 33 | void *driver_data; | ||
| 34 | |||
| 35 | /* platform_data can be used to either pass data to "generic" | ||
| 36 | driver or as a hook to mfd_cell for the "cell" drivers */ | ||
| 37 | void *platform_data; | ||
| 38 | size_t data_size; | ||
| 33 | 39 | ||
| 34 | /* | 40 | /* |
| 35 | * This resources can be specified relatievly to the parent device. | 41 | * This resources can be specified relatievly to the parent device. |
| @@ -39,11 +45,6 @@ struct mfd_cell { | |||
| 39 | const struct resource *resources; | 45 | const struct resource *resources; |
| 40 | }; | 46 | }; |
| 41 | 47 | ||
| 42 | static inline struct mfd_cell *mfd_get_cell(struct platform_device *pdev) | ||
| 43 | { | ||
| 44 | return (struct mfd_cell *)pdev->dev.platform_data; | ||
| 45 | } | ||
| 46 | |||
| 47 | extern int mfd_add_devices(struct platform_device *parent, | 48 | extern int mfd_add_devices(struct platform_device *parent, |
| 48 | const struct mfd_cell *cells, int n_devs, | 49 | const struct mfd_cell *cells, int n_devs, |
| 49 | struct resource *mem_base, | 50 | struct resource *mem_base, |
