summaryrefslogtreecommitdiffstats
path: root/drivers/reset
diff options
context:
space:
mode:
authorOlof Johansson <olof@lixom.net>2014-05-21 17:42:56 -0400
committerOlof Johansson <olof@lixom.net>2014-05-21 17:42:56 -0400
commited99885ccb89471f52d34b74b15fc9059bf07504 (patch)
treef032dab24235b27e2f75c0046c445f23e5329d79 /drivers/reset
parent02be9746e3169f92010872d111eef51404ee99c5 (diff)
parentcd90f0cf4454861a4f87bdfdcf01e8b98cc94869 (diff)
Merge branch 'sunxi/drivers-for-3.16' of https://github.com/mripard/linux into next/drivers
Merge "Allwinner drivers changes for 3.16" from Maxime Ripard: Reset drivers for the A31, that have been merged with reset maintainer's Acked-by. * 'sunxi/drivers-for-3.16' of https://github.com/mripard/linux: reset: sunxi: allow MFD subdevices probe reset: sunxi: document sunxi's reset controllers bindings Signed-off-by: Olof Johansson <olof@lixom.net>
Diffstat (limited to 'drivers/reset')
-rw-r--r--drivers/reset/reset-sunxi.c21
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
146static int sunxi_reset_probe(struct platform_device *pdev) 146static 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
151static int sunxi_reset_remove(struct platform_device *pdev) 168static 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}