diff options
| author | Boris BREZILLON <boris.brezillon@free-electrons.com> | 2014-05-14 08:38:16 -0400 |
|---|---|---|
| committer | Maxime Ripard <maxime.ripard@free-electrons.com> | 2014-05-15 04:31:04 -0400 |
| commit | cd90f0cf4454861a4f87bdfdcf01e8b98cc94869 (patch) | |
| tree | 1f806c2c3537ea31db953815ae7b02a348bfc68d /drivers/reset | |
| parent | 1e84443e69c1fdbef76fb3897294e924461a6c0a (diff) | |
reset: sunxi: allow MFD subdevices probe
The current implementation uses sunxi_reset_init function for both early
init and platform device probe.
The sunxi_reset_init function uses DT to retrieve device resources, which
will be an issue if reset controllers are registered from an MFD device
that define resources from mfd_cell definition.
Moreover, we can make of devm functions when we're in the probe context.
Signed-off-by: Boris BREZILLON <boris.brezillon@free-electrons.com>
Acked-by: Maxime Ripard <maxime.ripard@free-electrons.com>
Signed-off-by: Maxime Ripard <maxime.ripard@free-electrons.com>
Acked-by: Philipp Zabel <p.zabel@pengutronix.de>
Diffstat (limited to 'drivers/reset')
| -rw-r--r-- | drivers/reset/reset-sunxi.c | 21 |
1 files changed, 18 insertions, 3 deletions
diff --git a/drivers/reset/reset-sunxi.c b/drivers/reset/reset-sunxi.c index 695bd3496eba..a94e7a7820b4 100644 --- a/drivers/reset/reset-sunxi.c +++ b/drivers/reset/reset-sunxi.c | |||
| @@ -145,7 +145,24 @@ MODULE_DEVICE_TABLE(of, sunxi_reset_dt_ids); | |||
| 145 | 145 | ||
| 146 | static int sunxi_reset_probe(struct platform_device *pdev) | 146 | static int sunxi_reset_probe(struct platform_device *pdev) |
| 147 | { | 147 | { |
| 148 | return sunxi_reset_init(pdev->dev.of_node); | 148 | struct sunxi_reset_data *data; |
| 149 | struct resource *res; | ||
| 150 | |||
| 151 | data = devm_kzalloc(&pdev->dev, sizeof(*data), GFP_KERNEL); | ||
| 152 | if (!data) | ||
| 153 | return -ENOMEM; | ||
| 154 | |||
| 155 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | ||
| 156 | data->membase = devm_ioremap_resource(&pdev->dev, res); | ||
| 157 | if (IS_ERR(data->membase)) | ||
| 158 | return PTR_ERR(data->membase); | ||
| 159 | |||
| 160 | data->rcdev.owner = THIS_MODULE; | ||
| 161 | data->rcdev.nr_resets = resource_size(res) * 32; | ||
| 162 | data->rcdev.ops = &sunxi_reset_ops; | ||
| 163 | data->rcdev.of_node = pdev->dev.of_node; | ||
| 164 | |||
| 165 | return reset_controller_register(&data->rcdev); | ||
| 149 | } | 166 | } |
| 150 | 167 | ||
| 151 | static int sunxi_reset_remove(struct platform_device *pdev) | 168 | static int sunxi_reset_remove(struct platform_device *pdev) |
| @@ -153,8 +170,6 @@ static int sunxi_reset_remove(struct platform_device *pdev) | |||
| 153 | struct sunxi_reset_data *data = platform_get_drvdata(pdev); | 170 | struct sunxi_reset_data *data = platform_get_drvdata(pdev); |
| 154 | 171 | ||
| 155 | reset_controller_unregister(&data->rcdev); | 172 | reset_controller_unregister(&data->rcdev); |
| 156 | iounmap(data->membase); | ||
| 157 | kfree(data); | ||
| 158 | 173 | ||
| 159 | return 0; | 174 | return 0; |
| 160 | } | 175 | } |
