diff options
author | Álvaro Fernández Rojas <noltari@gmail.com> | 2015-10-08 06:35:53 -0400 |
---|---|---|
committer | Jacek Anaszewski <j.anaszewski@samsung.com> | 2015-11-03 02:59:40 -0500 |
commit | d8fe1606d1a7181c877d8b1727cdcfb82f76e91c (patch) | |
tree | d7e4a1627e6d7686ce06cf9438232f830ba63efa | |
parent | 79653fbb3365002899e7d25ec5ca96aff4241ede (diff) |
leds-bcm6328: simplify and improve default-state handling
This patch simplifies and improves the code related to
default-state handling.
It also changes the code to power off the LEDs by default.
Signed-off-by: Álvaro Fernández Rojas <noltari@gmail.com>
Signed-off-by: Jacek Anaszewski <j.anaszewski@samsung.com>
-rw-r--r-- | drivers/leds/leds-bcm6328.c | 24 |
1 files changed, 15 insertions, 9 deletions
diff --git a/drivers/leds/leds-bcm6328.c b/drivers/leds/leds-bcm6328.c index e1c19557450f..bf063fae4ad0 100644 --- a/drivers/leds/leds-bcm6328.c +++ b/drivers/leds/leds-bcm6328.c | |||
@@ -281,11 +281,10 @@ static int bcm6328_led(struct device *dev, struct device_node *nc, u32 reg, | |||
281 | "linux,default-trigger", | 281 | "linux,default-trigger", |
282 | NULL); | 282 | NULL); |
283 | 283 | ||
284 | spin_lock_irqsave(lock, flags); | ||
284 | if (!of_property_read_string(nc, "default-state", &state)) { | 285 | if (!of_property_read_string(nc, "default-state", &state)) { |
285 | spin_lock_irqsave(lock, flags); | ||
286 | if (!strcmp(state, "on")) { | 286 | if (!strcmp(state, "on")) { |
287 | led->cdev.brightness = LED_FULL; | 287 | led->cdev.brightness = LED_FULL; |
288 | bcm6328_led_mode(led, BCM6328_LED_MODE_ON); | ||
289 | } else if (!strcmp(state, "keep")) { | 288 | } else if (!strcmp(state, "keep")) { |
290 | void __iomem *mode; | 289 | void __iomem *mode; |
291 | unsigned long val, shift; | 290 | unsigned long val, shift; |
@@ -296,21 +295,28 @@ static int bcm6328_led(struct device *dev, struct device_node *nc, u32 reg, | |||
296 | else | 295 | else |
297 | mode = mem + BCM6328_REG_MODE_LO; | 296 | mode = mem + BCM6328_REG_MODE_LO; |
298 | 297 | ||
299 | val = bcm6328_led_read(mode) >> (shift % 16); | 298 | val = bcm6328_led_read(mode) >> |
299 | BCM6328_LED_SHIFT(shift % 16); | ||
300 | val &= BCM6328_LED_MODE_MASK; | 300 | val &= BCM6328_LED_MODE_MASK; |
301 | if (val == BCM6328_LED_MODE_ON) | 301 | if ((led->active_low && val == BCM6328_LED_MODE_ON) || |
302 | (!led->active_low && val == BCM6328_LED_MODE_OFF)) | ||
302 | led->cdev.brightness = LED_FULL; | 303 | led->cdev.brightness = LED_FULL; |
303 | else { | 304 | else |
304 | led->cdev.brightness = LED_OFF; | 305 | led->cdev.brightness = LED_OFF; |
305 | bcm6328_led_mode(led, BCM6328_LED_MODE_OFF); | ||
306 | } | ||
307 | } else { | 306 | } else { |
308 | led->cdev.brightness = LED_OFF; | 307 | led->cdev.brightness = LED_OFF; |
309 | bcm6328_led_mode(led, BCM6328_LED_MODE_OFF); | ||
310 | } | 308 | } |
311 | spin_unlock_irqrestore(lock, flags); | 309 | } else { |
310 | led->cdev.brightness = LED_OFF; | ||
312 | } | 311 | } |
313 | 312 | ||
313 | if ((led->active_low && led->cdev.brightness == LED_FULL) || | ||
314 | (!led->active_low && led->cdev.brightness == LED_OFF)) | ||
315 | bcm6328_led_mode(led, BCM6328_LED_MODE_ON); | ||
316 | else | ||
317 | bcm6328_led_mode(led, BCM6328_LED_MODE_OFF); | ||
318 | spin_unlock_irqrestore(lock, flags); | ||
319 | |||
314 | led->cdev.brightness_set = bcm6328_led_set; | 320 | led->cdev.brightness_set = bcm6328_led_set; |
315 | led->cdev.blink_set = bcm6328_blink_set; | 321 | led->cdev.blink_set = bcm6328_blink_set; |
316 | 322 | ||