diff options
Diffstat (limited to 'drivers/video/aty/atyfb_base.c')
-rw-r--r-- | drivers/video/aty/atyfb_base.c | 22 |
1 files changed, 13 insertions, 9 deletions
diff --git a/drivers/video/aty/atyfb_base.c b/drivers/video/aty/atyfb_base.c index 1507d19f481f..19a71f045784 100644 --- a/drivers/video/aty/atyfb_base.c +++ b/drivers/video/aty/atyfb_base.c | |||
@@ -2200,10 +2200,14 @@ static struct backlight_properties aty_bl_data = { | |||
2200 | static void aty_bl_set_power(struct fb_info *info, int power) | 2200 | static void aty_bl_set_power(struct fb_info *info, int power) |
2201 | { | 2201 | { |
2202 | mutex_lock(&info->bl_mutex); | 2202 | mutex_lock(&info->bl_mutex); |
2203 | up(&info->bl_dev->sem); | 2203 | |
2204 | info->bl_dev->props->power = power; | 2204 | if (info->bl_dev) { |
2205 | __aty_bl_update_status(info->bl_dev); | 2205 | down(&info->bl_dev->sem); |
2206 | down(&info->bl_dev->sem); | 2206 | info->bl_dev->props->power = power; |
2207 | __aty_bl_update_status(info->bl_dev); | ||
2208 | up(&info->bl_dev->sem); | ||
2209 | } | ||
2210 | |||
2207 | mutex_unlock(&info->bl_mutex); | 2211 | mutex_unlock(&info->bl_mutex); |
2208 | } | 2212 | } |
2209 | 2213 | ||
@@ -2223,7 +2227,7 @@ static void aty_bl_init(struct atyfb_par *par) | |||
2223 | bd = backlight_device_register(name, par, &aty_bl_data); | 2227 | bd = backlight_device_register(name, par, &aty_bl_data); |
2224 | if (IS_ERR(bd)) { | 2228 | if (IS_ERR(bd)) { |
2225 | info->bl_dev = NULL; | 2229 | info->bl_dev = NULL; |
2226 | printk("aty: Backlight registration failed\n"); | 2230 | printk(KERN_WARNING "aty: Backlight registration failed\n"); |
2227 | goto error; | 2231 | goto error; |
2228 | } | 2232 | } |
2229 | 2233 | ||
@@ -2234,11 +2238,11 @@ static void aty_bl_init(struct atyfb_par *par) | |||
2234 | 0xFF * FB_BACKLIGHT_MAX / MAX_LEVEL); | 2238 | 0xFF * FB_BACKLIGHT_MAX / MAX_LEVEL); |
2235 | mutex_unlock(&info->bl_mutex); | 2239 | mutex_unlock(&info->bl_mutex); |
2236 | 2240 | ||
2237 | up(&bd->sem); | 2241 | down(&bd->sem); |
2238 | bd->props->brightness = aty_bl_data.max_brightness; | 2242 | bd->props->brightness = aty_bl_data.max_brightness; |
2239 | bd->props->power = FB_BLANK_UNBLANK; | 2243 | bd->props->power = FB_BLANK_UNBLANK; |
2240 | bd->props->update_status(bd); | 2244 | bd->props->update_status(bd); |
2241 | down(&bd->sem); | 2245 | up(&bd->sem); |
2242 | 2246 | ||
2243 | #ifdef CONFIG_PMAC_BACKLIGHT | 2247 | #ifdef CONFIG_PMAC_BACKLIGHT |
2244 | mutex_lock(&pmac_backlight_mutex); | 2248 | mutex_lock(&pmac_backlight_mutex); |
@@ -2812,7 +2816,7 @@ static int atyfb_blank(int blank, struct fb_info *info) | |||
2812 | if (par->lock_blank || par->asleep) | 2816 | if (par->lock_blank || par->asleep) |
2813 | return 0; | 2817 | return 0; |
2814 | 2818 | ||
2815 | #ifdef CONFIG_PMAC_BACKLIGHT | 2819 | #ifdef CONFIG_FB_ATY_BACKLIGHT |
2816 | if (machine_is(powermac) && blank > FB_BLANK_NORMAL) | 2820 | if (machine_is(powermac) && blank > FB_BLANK_NORMAL) |
2817 | aty_bl_set_power(info, FB_BLANK_POWERDOWN); | 2821 | aty_bl_set_power(info, FB_BLANK_POWERDOWN); |
2818 | #elif defined(CONFIG_FB_ATY_GENERIC_LCD) | 2822 | #elif defined(CONFIG_FB_ATY_GENERIC_LCD) |
@@ -2844,7 +2848,7 @@ static int atyfb_blank(int blank, struct fb_info *info) | |||
2844 | } | 2848 | } |
2845 | aty_st_le32(CRTC_GEN_CNTL, gen_cntl, par); | 2849 | aty_st_le32(CRTC_GEN_CNTL, gen_cntl, par); |
2846 | 2850 | ||
2847 | #ifdef CONFIG_PMAC_BACKLIGHT | 2851 | #ifdef CONFIG_FB_ATY_BACKLIGHT |
2848 | if (machine_is(powermac) && blank <= FB_BLANK_NORMAL) | 2852 | if (machine_is(powermac) && blank <= FB_BLANK_NORMAL) |
2849 | aty_bl_set_power(info, FB_BLANK_UNBLANK); | 2853 | aty_bl_set_power(info, FB_BLANK_UNBLANK); |
2850 | #elif defined(CONFIG_FB_ATY_GENERIC_LCD) | 2854 | #elif defined(CONFIG_FB_ATY_GENERIC_LCD) |