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/reset-sunxi.c | |
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/reset-sunxi.c')
-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 | } |