power: reset: ltc2952: prefer devm_gpiod_get over gpiod_get
This reduces cleanup code and chance of errors. Signed-off-by: Frans Klaver <frans.klaver@xsens.com> Signed-off-by: Sebastian Reichel <sre@kernel.org>
This commit is contained in:
parent
f66472df69
commit
62113b3117
1 changed files with 10 additions and 34 deletions
|
@ -207,44 +207,34 @@ static int ltc2952_poweroff_init(struct platform_device *pdev)
|
||||||
data = ltc2952_data;
|
data = ltc2952_data;
|
||||||
ltc2952_poweroff_default(ltc2952_data);
|
ltc2952_poweroff_default(ltc2952_data);
|
||||||
|
|
||||||
ltc2952_data->gpio_watchdog = gpiod_get(&pdev->dev, "watchdog");
|
ltc2952_data->gpio_watchdog = devm_gpiod_get(&pdev->dev, "watchdog",
|
||||||
|
GPIOD_OUT_LOW);
|
||||||
if (IS_ERR(ltc2952_data->gpio_watchdog)) {
|
if (IS_ERR(ltc2952_data->gpio_watchdog)) {
|
||||||
ret = PTR_ERR(ltc2952_data->gpio_watchdog);
|
ret = PTR_ERR(ltc2952_data->gpio_watchdog);
|
||||||
dev_err(&pdev->dev, "unable to claim gpio \"watchdog\"\n");
|
dev_err(&pdev->dev, "unable to claim gpio \"watchdog\"\n");
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
ltc2952_data->gpio_kill = gpiod_get(&pdev->dev, "kill");
|
ltc2952_data->gpio_kill = devm_gpiod_get(&pdev->dev, "kill",
|
||||||
|
GPIOD_OUT_LOW);
|
||||||
if (IS_ERR(ltc2952_data->gpio_kill)) {
|
if (IS_ERR(ltc2952_data->gpio_kill)) {
|
||||||
ret = PTR_ERR(ltc2952_data->gpio_kill);
|
ret = PTR_ERR(ltc2952_data->gpio_kill);
|
||||||
dev_err(&pdev->dev, "unable to claim gpio \"kill\"\n");
|
dev_err(&pdev->dev, "unable to claim gpio \"kill\"\n");
|
||||||
goto err_kill;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
ltc2952_data->gpio_trigger = gpiod_get(&pdev->dev, "trigger");
|
ltc2952_data->gpio_trigger = devm_gpiod_get(&pdev->dev, "trigger",
|
||||||
|
GPIOD_IN);
|
||||||
if (IS_ERR(ltc2952_data->gpio_trigger)) {
|
if (IS_ERR(ltc2952_data->gpio_trigger)) {
|
||||||
ret = PTR_ERR(ltc2952_data->gpio_trigger);
|
ret = PTR_ERR(ltc2952_data->gpio_trigger);
|
||||||
dev_err(&pdev->dev, "unable to claim gpio \"trigger\"\n");
|
dev_err(&pdev->dev, "unable to claim gpio \"trigger\"\n");
|
||||||
goto err_trigger;
|
return ret;
|
||||||
}
|
|
||||||
|
|
||||||
ret = gpiod_direction_output(
|
|
||||||
ltc2952_data->gpio_watchdog, 0);
|
|
||||||
if (ret) {
|
|
||||||
dev_err(&pdev->dev, "unable to use watchdog-gpio as output\n");
|
|
||||||
goto err_io;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = gpiod_direction_output(ltc2952_data->gpio_kill, 0);
|
|
||||||
if (ret) {
|
|
||||||
dev_err(&pdev->dev, "unable to use kill-gpio as output\n");
|
|
||||||
goto err_io;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virq = gpiod_to_irq(ltc2952_data->gpio_trigger);
|
virq = gpiod_to_irq(ltc2952_data->gpio_trigger);
|
||||||
if (virq < 0) {
|
if (virq < 0) {
|
||||||
dev_err(&pdev->dev, "cannot map GPIO as interrupt");
|
dev_err(&pdev->dev, "cannot map GPIO as interrupt");
|
||||||
goto err_io;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = devm_request_irq(&pdev->dev, virq,
|
ret = devm_request_irq(&pdev->dev, virq,
|
||||||
|
@ -255,19 +245,10 @@ static int ltc2952_poweroff_init(struct platform_device *pdev)
|
||||||
|
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_err(&pdev->dev, "cannot configure an interrupt handler\n");
|
dev_err(&pdev->dev, "cannot configure an interrupt handler\n");
|
||||||
goto err_io;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
err_io:
|
|
||||||
gpiod_put(ltc2952_data->gpio_trigger);
|
|
||||||
err_trigger:
|
|
||||||
gpiod_put(ltc2952_data->gpio_kill);
|
|
||||||
err_kill:
|
|
||||||
gpiod_put(ltc2952_data->gpio_watchdog);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ltc2952_poweroff_probe(struct platform_device *pdev)
|
static int ltc2952_poweroff_probe(struct platform_device *pdev)
|
||||||
|
@ -301,11 +282,6 @@ static int ltc2952_poweroff_remove(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
pm_power_off = NULL;
|
pm_power_off = NULL;
|
||||||
|
|
||||||
if (ltc2952_data) {
|
|
||||||
gpiod_put(ltc2952_data->gpio_trigger);
|
|
||||||
gpiod_put(ltc2952_data->gpio_watchdog);
|
|
||||||
gpiod_put(ltc2952_data->gpio_kill);
|
|
||||||
}
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue