aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/video/backlight/backlight.c
diff options
context:
space:
mode:
authorRichard Purdie <rpurdie@rpsys.net>2007-02-08 17:25:09 -0500
committerRichard Purdie <rpurdie@rpsys.net>2007-02-20 03:38:45 -0500
commit28ee086d5b36aab2931f6740e409bb0fb6c65e5f (patch)
tree0a308c80affcc39c2c869f29f1109e5ee9d6140f /drivers/video/backlight/backlight.c
parenta8db3c1948eb30cd6988b5b96b654f591e6280b1 (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/video/backlight/backlight.c')
-rw-r--r--drivers/video/backlight/backlight.c10
1 files changed, 4 insertions, 6 deletions
diff --git a/drivers/video/backlight/backlight.c b/drivers/video/backlight/backlight.c
index 7a85be4d2b0a..347081daf7a4 100644
--- a/drivers/video/backlight/backlight.c
+++ b/drivers/video/backlight/backlight.c
@@ -37,8 +37,7 @@ static int fb_notifier_callback(struct notifier_block *self,
37 if (!bd->props->check_fb || 37 if (!bd->props->check_fb ||
38 bd->props->check_fb(evdata->info)) { 38 bd->props->check_fb(evdata->info)) {
39 bd->props->fb_blank = *(int *)evdata->data; 39 bd->props->fb_blank = *(int *)evdata->data;
40 if (bd->props && bd->props->update_status) 40 backlight_update_status(bd);
41 bd->props->update_status(bd);
42 } 41 }
43 up(&bd->sem); 42 up(&bd->sem);
44 return 0; 43 return 0;
@@ -97,8 +96,7 @@ static ssize_t backlight_store_power(struct class_device *cdev, const char *buf,
97 if (bd->props) { 96 if (bd->props) {
98 pr_debug("backlight: set power to %d\n", power); 97 pr_debug("backlight: set power to %d\n", power);
99 bd->props->power = power; 98 bd->props->power = power;
100 if (bd->props->update_status) 99 backlight_update_status(bd);
101 bd->props->update_status(bd);
102 rc = count; 100 rc = count;
103 } 101 }
104 up(&bd->sem); 102 up(&bd->sem);
@@ -140,8 +138,7 @@ static ssize_t backlight_store_brightness(struct class_device *cdev, const char
140 pr_debug("backlight: set brightness to %d\n", 138 pr_debug("backlight: set brightness to %d\n",
141 brightness); 139 brightness);
142 bd->props->brightness = brightness; 140 bd->props->brightness = brightness;
143 if (bd->props->update_status) 141 backlight_update_status(bd);
144 bd->props->update_status(bd);
145 rc = count; 142 rc = count;
146 } 143 }
147 } 144 }
@@ -230,6 +227,7 @@ struct backlight_device *backlight_device_register(const char *name,
230 if (!new_bd) 227 if (!new_bd)
231 return ERR_PTR(-ENOMEM); 228 return ERR_PTR(-ENOMEM);
232 229
230 mutex_init(&new_bd->update_lock);
233 init_MUTEX(&new_bd->sem); 231 init_MUTEX(&new_bd->sem);
234 new_bd->props = bp; 232 new_bd->props = bp;
235 memset(&new_bd->class_dev, 0, sizeof(new_bd->class_dev)); 233 memset(&new_bd->class_dev, 0, sizeof(new_bd->class_dev));