aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/leds/leds-gpio.c
diff options
context:
space:
mode:
authorHeiner Kallweit <hkallweit1@gmail.com>2016-09-14 14:54:31 -0400
committerJacek Anaszewski <j.anaszewski@samsung.com>2016-09-15 10:49:40 -0400
commit061b5c1d013a94af385ba8980ea3b2617f1ff0f6 (patch)
treef11437e438094356e0a29069183df9c5bf52b6ac /drivers/leds/leds-gpio.c
parent68620e594c250ba8c43a78e77f5296cb9952582e (diff)
leds: gpio: fix an unhandled error case in create_gpio_led
gpiod_get_value_cansleep returns 0, 1, or an error code. So far errors are not handled and treated the same as 1. Change this to bail out if an error code is returned and remove the double negation. Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com> Signed-off-by: Jacek Anaszewski <j.anaszewski@samsung.com>
Diffstat (limited to 'drivers/leds/leds-gpio.c')
-rw-r--r--drivers/leds/leds-gpio.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/drivers/leds/leds-gpio.c b/drivers/leds/leds-gpio.c
index 3599b2e4977c..10c851ecc6ce 100644
--- a/drivers/leds/leds-gpio.c
+++ b/drivers/leds/leds-gpio.c
@@ -118,10 +118,13 @@ static int create_gpio_led(const struct gpio_led *template,
118 led_dat->platform_gpio_blink_set = blink_set; 118 led_dat->platform_gpio_blink_set = blink_set;
119 led_dat->cdev.blink_set = gpio_blink_set; 119 led_dat->cdev.blink_set = gpio_blink_set;
120 } 120 }
121 if (template->default_state == LEDS_GPIO_DEFSTATE_KEEP) 121 if (template->default_state == LEDS_GPIO_DEFSTATE_KEEP) {
122 state = !!gpiod_get_value_cansleep(led_dat->gpiod); 122 state = gpiod_get_value_cansleep(led_dat->gpiod);
123 else 123 if (state < 0)
124 return state;
125 } else {
124 state = (template->default_state == LEDS_GPIO_DEFSTATE_ON); 126 state = (template->default_state == LEDS_GPIO_DEFSTATE_ON);
127 }
125 led_dat->cdev.brightness = state ? LED_FULL : LED_OFF; 128 led_dat->cdev.brightness = state ? LED_FULL : LED_OFF;
126 if (!template->retain_state_suspended) 129 if (!template->retain_state_suspended)
127 led_dat->cdev.flags |= LED_CORE_SUSPENDRESUME; 130 led_dat->cdev.flags |= LED_CORE_SUSPENDRESUME;