[PATCH 3/4] Use devm_request_irq to avoid some checks

From: Marcos Paulo de Souza
Date: Thu Oct 18 2012 - 19:41:44 EST


With this we can remove a lot of checks.

Signed-off-by: Marcos Paulo de Souza <marcos.souza.org@xxxxxxxxx>
---
drivers/power/jz4740-battery.c | 25 ++++++++-----------------
1 file changed, 8 insertions(+), 17 deletions(-)

diff --git a/drivers/power/jz4740-battery.c b/drivers/power/jz4740-battery.c
index 9d9b2a8..b80f7ed 100644
--- a/drivers/power/jz4740-battery.c
+++ b/drivers/power/jz4740-battery.c
@@ -307,8 +307,8 @@ static int __devinit jz_battery_probe(struct platform_device *pdev)

INIT_DELAYED_WORK(&jz_battery->work, jz_battery_work);

- ret = request_irq(jz_battery->irq, jz_battery_irq_handler, 0, pdev->name,
- jz_battery);
+ ret = devm_request_irq(&pdev->dev, jz_battery->irq, jz_battery_irq_handler,
+ 0, pdev->name, jz_battery);
if (ret) {
dev_err(&pdev->dev, "Failed to request irq %d\n", ret);
goto err;
@@ -319,7 +319,7 @@ static int __devinit jz_battery_probe(struct platform_device *pdev)
ret = gpio_request(pdata->gpio_charge, dev_name(&pdev->dev));
if (ret) {
dev_err(&pdev->dev, "charger state gpio request failed.\n");
- goto err_free_irq;
+ goto err;
}
ret = gpio_direction_input(pdata->gpio_charge);
if (ret) {
@@ -330,7 +330,8 @@ static int __devinit jz_battery_probe(struct platform_device *pdev)
jz_battery->charge_irq = gpio_to_irq(pdata->gpio_charge);

if (jz_battery->charge_irq >= 0) {
- ret = request_irq(jz_battery->charge_irq,
+ ret = devm_request_irq(&pdev->dev,
+ jz_battery->charge_irq,
jz_battery_charge_irq,
IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING,
dev_name(&pdev->dev), jz_battery);
@@ -352,7 +353,7 @@ static int __devinit jz_battery_probe(struct platform_device *pdev)
ret = power_supply_register(&pdev->dev, &jz_battery->battery);
if (ret) {
dev_err(&pdev->dev, "power supply battery register failed.\n");
- goto err_free_charge_irq;
+ goto err_free_gpio;
}

platform_set_drvdata(pdev, jz_battery);
@@ -360,16 +361,11 @@ static int __devinit jz_battery_probe(struct platform_device *pdev)

return 0;

-err_free_charge_irq:
- if (jz_battery->charge_irq >= 0)
- free_irq(jz_battery->charge_irq, jz_battery);
err_free_gpio:
if (gpio_is_valid(pdata->gpio_charge))
gpio_free(jz_battery->pdata->gpio_charge);
-err_free_irq:
- free_irq(jz_battery->irq, jz_battery);
- platform_set_drvdata(pdev, NULL);
err:
+ platform_set_drvdata(pdev, NULL);
return ret;
}

@@ -379,16 +375,11 @@ static int __devexit jz_battery_remove(struct platform_device *pdev)

cancel_delayed_work_sync(&jz_battery->work);

- if (gpio_is_valid(jz_battery->pdata->gpio_charge)) {
- if (jz_battery->charge_irq >= 0)
- free_irq(jz_battery->charge_irq, jz_battery);
+ if (gpio_is_valid(jz_battery->pdata->gpio_charge))
gpio_free(jz_battery->pdata->gpio_charge);
- }

power_supply_unregister(&jz_battery->battery);

- free_irq(jz_battery->irq, jz_battery);
-
return 0;
}

--
1.7.9.5

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/