diff options
author | Richard Purdie <rpurdie@rpsys.net> | 2007-02-08 17:25:09 -0500 |
---|---|---|
committer | Richard Purdie <rpurdie@rpsys.net> | 2007-02-20 03:38:45 -0500 |
commit | 28ee086d5b36aab2931f6740e409bb0fb6c65e5f (patch) | |
tree | 0a308c80affcc39c2c869f29f1109e5ee9d6140f /drivers/misc/asus-laptop.c | |
parent | a8db3c1948eb30cd6988b5b96b654f591e6280b1 (diff) |
backlight: Fix external uses of backlight internal semaphore
backlight_device->sem has a very specific use as documented in the
header file. The external users of this are using it for a different
reason, to serialise access to the update_status() method.
backlight users were supposed to implement their own internal
serialisation of update_status() if needed but everyone is doing
things differently and incorrectly. Therefore add a global mutex to
take care of serialisation for everyone, once and for all.
Locking for get_brightness remains optional since most users don't
need it.
Also update the lcd class in a similar way.
Signed-off-by: Richard Purdie <rpurdie@rpsys.net>
Diffstat (limited to 'drivers/misc/asus-laptop.c')
-rw-r--r-- | drivers/misc/asus-laptop.c | 20 |
1 files changed, 5 insertions, 15 deletions
diff --git a/drivers/misc/asus-laptop.c b/drivers/misc/asus-laptop.c index d15ee5e34201..7ace5b9a3d28 100644 --- a/drivers/misc/asus-laptop.c +++ b/drivers/misc/asus-laptop.c | |||
@@ -348,13 +348,8 @@ static void lcd_blank(int blank) | |||
348 | struct backlight_device *bd = asus_backlight_device; | 348 | struct backlight_device *bd = asus_backlight_device; |
349 | 349 | ||
350 | if (bd) { | 350 | if (bd) { |
351 | down(&bd->sem); | 351 | bd->props->power = blank; |
352 | if (likely(bd->props)) { | 352 | backlight_update_status(bd); |
353 | bd->props->power = blank; | ||
354 | if (likely(bd->props->update_status)) | ||
355 | bd->props->update_status(bd); | ||
356 | } | ||
357 | up(&bd->sem); | ||
358 | } | 353 | } |
359 | } | 354 | } |
360 | 355 | ||
@@ -1028,14 +1023,9 @@ static int asus_backlight_init(struct device *dev) | |||
1028 | 1023 | ||
1029 | asus_backlight_device = bd; | 1024 | asus_backlight_device = bd; |
1030 | 1025 | ||
1031 | down(&bd->sem); | 1026 | bd->props->brightness = read_brightness(NULL); |
1032 | if (likely(bd->props)) { | 1027 | bd->props->power = FB_BLANK_UNBLANK; |
1033 | bd->props->brightness = read_brightness(NULL); | 1028 | backlight_update_status(bd); |
1034 | bd->props->power = FB_BLANK_UNBLANK; | ||
1035 | if (likely(bd->props->update_status)) | ||
1036 | bd->props->update_status(bd); | ||
1037 | } | ||
1038 | up(&bd->sem); | ||
1039 | } | 1029 | } |
1040 | return 0; | 1030 | return 0; |
1041 | } | 1031 | } |