aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/power/reset/gpio-poweroff.c
diff options
context:
space:
mode:
authorUwe Kleine-König <u.kleine-koenig@pengutronix.de>2015-05-18 16:45:06 -0400
committerSebastian Reichel <sre@kernel.org>2015-05-23 14:03:30 -0400
commita34c0a8bf8caae7a82de08dbcca2c7c11907c805 (patch)
treee78a15892ae53803b6aac08fc63f0530de44b8b0 /drivers/power/reset/gpio-poweroff.c
parentb01e7c3b803e6f0498d4db0b124e3b4efb5ac728 (diff)
power: reset: gpio-poweroff: let devm_gpiod_get set direction of gpio
Since 39b2bbe3d715 (gpio: add flags argument to gpiod_get*() functions) which appeared in v3.17-rc1, the gpiod_get* functions take an additional parameter that allows to specify direction and initial value for output. Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de> Reviewed-by: Linus Walleij <linus.walleij@linaro.org> Signed-off-by: Sebastian Reichel <sre@kernel.org>
Diffstat (limited to 'drivers/power/reset/gpio-poweroff.c')
-rw-r--r--drivers/power/reset/gpio-poweroff.c25
1 files changed, 8 insertions, 17 deletions
diff --git a/drivers/power/reset/gpio-poweroff.c b/drivers/power/reset/gpio-poweroff.c
index e5332f1db8a7..be3d81ff51cc 100644
--- a/drivers/power/reset/gpio-poweroff.c
+++ b/drivers/power/reset/gpio-poweroff.c
@@ -48,6 +48,7 @@ static void gpio_poweroff_do_poweroff(void)
48static int gpio_poweroff_probe(struct platform_device *pdev) 48static int gpio_poweroff_probe(struct platform_device *pdev)
49{ 49{
50 bool input = false; 50 bool input = false;
51 enum gpiod_flags flags;
51 52
52 /* If a pm_power_off function has already been added, leave it alone */ 53 /* If a pm_power_off function has already been added, leave it alone */
53 if (pm_power_off != NULL) { 54 if (pm_power_off != NULL) {
@@ -57,25 +58,15 @@ static int gpio_poweroff_probe(struct platform_device *pdev)
57 return -EBUSY; 58 return -EBUSY;
58 } 59 }
59 60
60 reset_gpio = devm_gpiod_get(&pdev->dev, NULL);
61 if (IS_ERR(reset_gpio))
62 return PTR_ERR(reset_gpio);
63
64 input = of_property_read_bool(pdev->dev.of_node, "input"); 61 input = of_property_read_bool(pdev->dev.of_node, "input");
62 if (input)
63 flags = GPIOD_IN;
64 else
65 flags = GPIOD_OUT_LOW;
65 66
66 if (input) { 67 reset_gpio = devm_gpiod_get(&pdev->dev, NULL, flags);
67 if (gpiod_direction_input(reset_gpio)) { 68 if (IS_ERR(reset_gpio))
68 dev_err(&pdev->dev, 69 return PTR_ERR(reset_gpio);
69 "Could not set direction of reset GPIO to input\n");
70 return -ENODEV;
71 }
72 } else {
73 if (gpiod_direction_output(reset_gpio, 0)) {
74 dev_err(&pdev->dev,
75 "Could not set direction of reset GPIO\n");
76 return -ENODEV;
77 }
78 }
79 70
80 pm_power_off = &gpio_poweroff_do_poweroff; 71 pm_power_off = &gpio_poweroff_do_poweroff;
81 return 0; 72 return 0;