aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlan Jenkins <alan-jenkins@tuffmail.co.uk>2009-12-03 02:45:15 -0500
committerLen Brown <len.brown@intel.com>2009-12-09 15:54:33 -0500
commit325fb8e9aeddf7bf8a7a892869dca00e7305c41e (patch)
tree7171a806baf28188a576b95a5682d19dc783877e
parentf90be874303eddc53c199083a37bc44d65ab8351 (diff)
eeepc-laptop: re-add check for eeepc->backlight == NULL
As Corentin points out, we do not create a backlight device if the ACPI video driver is able to provide equivalent functionality. So we do need to check before we try to update the backlight device. We now ignore brightness events completely if we have not created a backlight device. This is slightly more cautious than the original check. Signed-off-by: Alan Jenkins <alan-jenkins@tuffmail.co.uk> Signed-off-by: Len Brown <len.brown@intel.com>
-rw-r--r--drivers/platform/x86/eeepc-laptop.c42
1 files changed, 25 insertions, 17 deletions
diff --git a/drivers/platform/x86/eeepc-laptop.c b/drivers/platform/x86/eeepc-laptop.c
index 5f0eb767e8a6..d07a4c0ec7e9 100644
--- a/drivers/platform/x86/eeepc-laptop.c
+++ b/drivers/platform/x86/eeepc-laptop.c
@@ -1230,27 +1230,35 @@ static void eeepc_acpi_notify(struct acpi_device *device, u32 event)
1230 dev_name(&device->dev), event, 1230 dev_name(&device->dev), event,
1231 count); 1231 count);
1232 1232
1233 /* Brightness events are special */
1233 if (event >= NOTIFY_BRN_MIN && event <= NOTIFY_BRN_MAX) { 1234 if (event >= NOTIFY_BRN_MIN && event <= NOTIFY_BRN_MAX) {
1234 int old_brightness, new_brightness;
1235 1235
1236 /* Update backlight device. */ 1236 /* Ignore them completely if the acpi video driver is used */
1237 old_brightness = eeepc_backlight_notify(eeepc); 1237 if (eeepc->backlight_device != NULL) {
1238 1238 int old_brightness, new_brightness;
1239 /* Convert brightness event to keypress (obsolescent hack). */ 1239
1240 new_brightness = event - NOTIFY_BRN_MIN; 1240 /* Update the backlight device. */
1241 1241 old_brightness = eeepc_backlight_notify(eeepc);
1242 if (new_brightness < old_brightness) { 1242
1243 event = NOTIFY_BRN_MIN; /* brightness down */ 1243 /* Convert event to keypress (obsolescent hack) */
1244 } else if (new_brightness > old_brightness) { 1244 new_brightness = event - NOTIFY_BRN_MIN;
1245 event = NOTIFY_BRN_MAX; /* brightness up */ 1245
1246 } else { 1246 if (new_brightness < old_brightness) {
1247 /* 1247 event = NOTIFY_BRN_MIN; /* brightness down */
1248 * no change in brightness - already at min/max, 1248 } else if (new_brightness > old_brightness) {
1249 * event will be desired value (or else ignored). 1249 event = NOTIFY_BRN_MAX; /* brightness up */
1250 */ 1250 } else {
1251 /*
1252 * no change in brightness - already at min/max,
1253 * event will be desired value (or else ignored)
1254 */
1255 }
1256 eeepc_input_notify(eeepc, event);
1251 } 1257 }
1258 } else {
1259 /* Everything else is a bona-fide keypress event */
1260 eeepc_input_notify(eeepc, event);
1252 } 1261 }
1253 eeepc_input_notify(eeepc, event);
1254} 1262}
1255 1263
1256static void cmsg_quirk(struct eeepc_laptop *eeepc, int cm, const char *name) 1264static void cmsg_quirk(struct eeepc_laptop *eeepc, int cm, const char *name)