summaryrefslogtreecommitdiffstats
path: root/drivers/watchdog
diff options
context:
space:
mode:
authorGuenter Roeck <linux@roeck-us.net>2017-01-10 18:21:47 -0500
committerGuenter Roeck <linux@roeck-us.net>2017-02-24 17:00:23 -0500
commit89f944c0f9abce176cf442894d29a7ab25f81c76 (patch)
treedaf482e461d3385bb45bdfdb56e92e549eaeaef4 /drivers/watchdog
parent189c049a01c2de60e5b88cf73326b9ba3811a16b (diff)
watchdog: da9055_wdt: Convert to use device managed functions
Use device managed functions to simplify error handling, reduce source code size, improve readability, and reduce the likelyhood of bugs. The conversion was done automatically with coccinelle using the following semantic patches. The semantic patches and the scripts used to generate this commit log are available at https://github.com/groeck/coccinelle-patches - Replace 'goto l; ... l: return e;' with 'return e;' - Drop assignments to otherwise unused variables - Drop remove function - Drop platform_set_drvdata() - Use devm_watchdog_register_driver() to register watchdog device Acked-by: Adam Thomson <Adam.Thomson.Opensource@diasemi.com> Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Diffstat (limited to 'drivers/watchdog')
-rw-r--r--drivers/watchdog/da9055_wdt.c17
1 files changed, 2 insertions, 15 deletions
diff --git a/drivers/watchdog/da9055_wdt.c b/drivers/watchdog/da9055_wdt.c
index 4f30818cf93f..50bdd1022186 100644
--- a/drivers/watchdog/da9055_wdt.c
+++ b/drivers/watchdog/da9055_wdt.c
@@ -147,32 +147,19 @@ static int da9055_wdt_probe(struct platform_device *pdev)
147 ret = da9055_wdt_stop(da9055_wdt); 147 ret = da9055_wdt_stop(da9055_wdt);
148 if (ret < 0) { 148 if (ret < 0) {
149 dev_err(&pdev->dev, "Failed to stop watchdog, %d\n", ret); 149 dev_err(&pdev->dev, "Failed to stop watchdog, %d\n", ret);
150 goto err; 150 return ret;
151 } 151 }
152 152
153 platform_set_drvdata(pdev, driver_data); 153 ret = devm_watchdog_register_device(&pdev->dev, &driver_data->wdt);
154
155 ret = watchdog_register_device(&driver_data->wdt);
156 if (ret != 0) 154 if (ret != 0)
157 dev_err(da9055->dev, "watchdog_register_device() failed: %d\n", 155 dev_err(da9055->dev, "watchdog_register_device() failed: %d\n",
158 ret); 156 ret);
159 157
160err:
161 return ret; 158 return ret;
162} 159}
163 160
164static int da9055_wdt_remove(struct platform_device *pdev)
165{
166 struct da9055_wdt_data *driver_data = platform_get_drvdata(pdev);
167
168 watchdog_unregister_device(&driver_data->wdt);
169
170 return 0;
171}
172
173static struct platform_driver da9055_wdt_driver = { 161static struct platform_driver da9055_wdt_driver = {
174 .probe = da9055_wdt_probe, 162 .probe = da9055_wdt_probe,
175 .remove = da9055_wdt_remove,
176 .driver = { 163 .driver = {
177 .name = "da9055-watchdog", 164 .name = "da9055-watchdog",
178 }, 165 },