With this we can remove a lot of checks. Signed-off-by: Marcos Paulo de Souza <marcos.souza....@gmail.com> --- 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 majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/