diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/leds/Kconfig | 8 | ||||
-rw-r--r-- | drivers/leds/leds-clevo-mail.c | 37 |
2 files changed, 42 insertions, 3 deletions
diff --git a/drivers/leds/Kconfig b/drivers/leds/Kconfig index 659448ead685..922c3df548a5 100644 --- a/drivers/leds/Kconfig +++ b/drivers/leds/Kconfig | |||
@@ -122,9 +122,11 @@ config LEDS_CLEVO_MAIL | |||
122 | programs through the leds subsystem. This LED have three | 122 | programs through the leds subsystem. This LED have three |
123 | known mode: off, blink at 0.5Hz and blink at 1Hz. | 123 | known mode: off, blink at 0.5Hz and blink at 1Hz. |
124 | 124 | ||
125 | As this LED cannot change it's brightness it blinks instead. | 125 | The driver supports two kinds of interface: using ledtrig-timer |
126 | The brightness value 0 means off, 1..127 means blink at 0.5Hz | 126 | or through /sys/class/leds/clevo::mail/brightness. As this LED |
127 | and 128..255 means blink at 1Hz. | 127 | cannot change it's brightness it blinks instead. The brightness |
128 | value 0 means off, 1..127 means blink at 0.5Hz and 128..255 means | ||
129 | blink at 1Hz. | ||
128 | 130 | ||
129 | This module can drive the mail LED for the following notebooks: | 131 | This module can drive the mail LED for the following notebooks: |
130 | 132 | ||
diff --git a/drivers/leds/leds-clevo-mail.c b/drivers/leds/leds-clevo-mail.c index 49a7972459c9..6c3d33b8e383 100644 --- a/drivers/leds/leds-clevo-mail.c +++ b/drivers/leds/leds-clevo-mail.c | |||
@@ -92,9 +92,46 @@ static void clevo_mail_led_set(struct led_classdev *led_cdev, | |||
92 | 92 | ||
93 | } | 93 | } |
94 | 94 | ||
95 | static int clevo_mail_led_blink(struct led_classdev *led_cdev, | ||
96 | unsigned long* delay_on, | ||
97 | unsigned long* delay_off) | ||
98 | { | ||
99 | int status = -EINVAL; | ||
100 | |||
101 | if (*delay_on == 0 /* ms */ && *delay_off == 0 /* ms */) { | ||
102 | /* Special case: the leds subsystem requested us to | ||
103 | * chose one user friendly blinking of the LED, and | ||
104 | * start it. Let's blink the led slowly (0.5Hz). | ||
105 | */ | ||
106 | *delay_on = 1000; /* ms */ | ||
107 | *delay_off = 1000; /* ms */ | ||
108 | i8042_command(NULL, CLEVO_MAIL_LED_BLINK_0_5HZ); | ||
109 | status = 0; | ||
110 | |||
111 | } else if (*delay_on == 500 /* ms */ && *delay_off == 500 /* ms */) { | ||
112 | /* blink the led with 1Hz */ | ||
113 | i8042_command(NULL, CLEVO_MAIL_LED_BLINK_1HZ); | ||
114 | status = 0; | ||
115 | |||
116 | } else if (*delay_on == 1000 /* ms */ && *delay_off == 1000 /* ms */) { | ||
117 | /* blink the led with 0.5Hz */ | ||
118 | i8042_command(NULL, CLEVO_MAIL_LED_BLINK_0_5HZ); | ||
119 | status = 0; | ||
120 | |||
121 | } else { | ||
122 | printk(KERN_DEBUG KBUILD_MODNAME | ||
123 | ": clevo_mail_led_blink(..., %lu, %lu)," | ||
124 | " returning -EINVAL (unsupported)\n", | ||
125 | *delay_on, *delay_off); | ||
126 | } | ||
127 | |||
128 | return status; | ||
129 | } | ||
130 | |||
95 | static struct led_classdev clevo_mail_led = { | 131 | static struct led_classdev clevo_mail_led = { |
96 | .name = "clevo::mail", | 132 | .name = "clevo::mail", |
97 | .brightness_set = clevo_mail_led_set, | 133 | .brightness_set = clevo_mail_led_set, |
134 | .blink_set = clevo_mail_led_blink, | ||
98 | }; | 135 | }; |
99 | 136 | ||
100 | static int __init clevo_mail_led_probe(struct platform_device *pdev) | 137 | static int __init clevo_mail_led_probe(struct platform_device *pdev) |