2008-06-06 08:54:13 +00:00
|
|
|
--- a/drivers/leds/leds-gpio.c
|
|
|
|
+++ b/drivers/leds/leds-gpio.c
|
|
|
|
@@ -41,13 +41,17 @@
|
2008-01-30 15:25:48 +00:00
|
|
|
container_of(led_cdev, struct gpio_led_data, cdev);
|
|
|
|
int level;
|
|
|
|
|
|
|
|
- if (value == LED_OFF)
|
|
|
|
- level = 0;
|
|
|
|
- else
|
|
|
|
- level = 1;
|
|
|
|
-
|
|
|
|
- if (led_dat->active_low)
|
|
|
|
- level = !level;
|
|
|
|
+ switch (value) {
|
|
|
|
+ case LED_OFF:
|
|
|
|
+ level = led_dat->active_low ? 1 : 0;
|
|
|
|
+ break;
|
|
|
|
+ case LED_FULL:
|
|
|
|
+ level = led_dat->active_low ? 0 : 1;
|
|
|
|
+ break;
|
|
|
|
+ default:
|
|
|
|
+ level = value;
|
|
|
|
+ break;
|
|
|
|
+ }
|
|
|
|
|
2008-06-17 14:30:18 +00:00
|
|
|
/* Setting GPIOs with I2C/etc requires a task context, and we don't
|
|
|
|
* seem to have a reliable way to know if we're already in one; so
|