aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFrans Klaver <frans.klaver@xsens.com>2015-01-14 03:15:35 -0500
committerSebastian Reichel <sre@kernel.org>2015-01-20 07:58:28 -0500
commit07d08237d3ff08c6a53c6e8496bd255176e1d68f (patch)
tree4316178a8ee89d9451957f905eb2f4c45b6ed7fe
parent0a5c6a2276fe06a3ebb6a9ed26c0b8007074958e (diff)
power: reset: ltc2952: prefer devm_request_irq over request_irq
Make use of the fact that we allocated resources can be automatically deallocated. This reduces cleanup code and chance of errors. It also removes the need for the virq member of the ltc2952_poweroff_data struct. Signed-off-by: Frans Klaver <frans.klaver@xsens.com> Signed-off-by: Sebastian Reichel <sre@kernel.org>
-rw-r--r--drivers/power/reset/ltc2952-poweroff.c19
1 files changed, 6 insertions, 13 deletions
diff --git a/drivers/power/reset/ltc2952-poweroff.c b/drivers/power/reset/ltc2952-poweroff.c
index 6487b991ed45..0b0792a9ad56 100644
--- a/drivers/power/reset/ltc2952-poweroff.c
+++ b/drivers/power/reset/ltc2952-poweroff.c
@@ -72,8 +72,6 @@ struct ltc2952_poweroff_data {
72 72
73 struct device *dev; 73 struct device *dev;
74 74
75 unsigned int virq;
76
77 /** 75 /**
78 * 0: trigger 76 * 0: trigger
79 * 1: watchdog 77 * 1: watchdog
@@ -260,13 +258,11 @@ static int ltc2952_poweroff_init(struct platform_device *pdev)
260 goto err_io; 258 goto err_io;
261 } 259 }
262 260
263 ltc2952_data->virq = virq; 261 ret = devm_request_irq(&pdev->dev, virq,
264 ret = request_irq(virq, 262 ltc2952_poweroff_handler,
265 ltc2952_poweroff_handler, 263 (IRQF_TRIGGER_FALLING | IRQF_TRIGGER_RISING),
266 (IRQF_TRIGGER_FALLING | IRQF_TRIGGER_RISING), 264 "ltc2952-poweroff",
267 "ltc2952-poweroff", 265 ltc2952_data);
268 ltc2952_data
269 );
270 266
271 if (ret) { 267 if (ret) {
272 dev_err(&pdev->dev, "cannot configure an interrupt handler\n"); 268 dev_err(&pdev->dev, "cannot configure an interrupt handler\n");
@@ -316,12 +312,9 @@ static int ltc2952_poweroff_remove(struct platform_device *pdev)
316 312
317 pm_power_off = NULL; 313 pm_power_off = NULL;
318 314
319 if (ltc2952_data) { 315 if (ltc2952_data)
320 free_irq(ltc2952_data->virq, ltc2952_data);
321
322 for (i = 0; i < ARRAY_SIZE(ltc2952_data->gpio); i++) 316 for (i = 0; i < ARRAY_SIZE(ltc2952_data->gpio); i++)
323 gpiod_put(ltc2952_data->gpio[i]); 317 gpiod_put(ltc2952_data->gpio[i]);
324 }
325 318
326 return 0; 319 return 0;
327} 320}