diff options
-rw-r--r-- | drivers/video/backlight/corgi_lcd.c | 27 | ||||
-rw-r--r-- | include/linux/spi/corgi_lcd.h | 1 |
2 files changed, 28 insertions, 0 deletions
diff --git a/drivers/video/backlight/corgi_lcd.c b/drivers/video/backlight/corgi_lcd.c index bf69e50d262e..068f14864099 100644 --- a/drivers/video/backlight/corgi_lcd.c +++ b/drivers/video/backlight/corgi_lcd.c | |||
@@ -86,6 +86,7 @@ struct corgi_lcd { | |||
86 | struct lcd_device *lcd_dev; | 86 | struct lcd_device *lcd_dev; |
87 | struct backlight_device *bl_dev; | 87 | struct backlight_device *bl_dev; |
88 | 88 | ||
89 | int limit_mask; | ||
89 | int intensity; | 90 | int intensity; |
90 | int power; | 91 | int power; |
91 | int mode; | 92 | int mode; |
@@ -97,6 +98,11 @@ struct corgi_lcd { | |||
97 | 98 | ||
98 | static int corgi_ssp_lcdtg_send(struct corgi_lcd *lcd, int reg, uint8_t val); | 99 | static int corgi_ssp_lcdtg_send(struct corgi_lcd *lcd, int reg, uint8_t val); |
99 | 100 | ||
101 | static struct corgi_lcd *the_corgi_lcd; | ||
102 | static unsigned long corgibl_flags; | ||
103 | #define CORGIBL_SUSPENDED 0x01 | ||
104 | #define CORGIBL_BATTLOW 0x02 | ||
105 | |||
100 | /* | 106 | /* |
101 | * This is only a psuedo I2C interface. We can't use the standard kernel | 107 | * This is only a psuedo I2C interface. We can't use the standard kernel |
102 | * routines as the interface is write only. We just assume the data is acked... | 108 | * routines as the interface is write only. We just assume the data is acked... |
@@ -413,9 +419,25 @@ static int corgi_bl_update_status(struct backlight_device *bd) | |||
413 | if (bd->props.fb_blank != FB_BLANK_UNBLANK) | 419 | if (bd->props.fb_blank != FB_BLANK_UNBLANK) |
414 | intensity = 0; | 420 | intensity = 0; |
415 | 421 | ||
422 | if (corgibl_flags & CORGIBL_SUSPENDED) | ||
423 | intensity = 0; | ||
424 | if (corgibl_flags & CORGIBL_BATTLOW) | ||
425 | intensity &= lcd->limit_mask; | ||
426 | |||
416 | return corgi_bl_set_intensity(lcd, intensity); | 427 | return corgi_bl_set_intensity(lcd, intensity); |
417 | } | 428 | } |
418 | 429 | ||
430 | void corgibl_limit_intensity(int limit) | ||
431 | { | ||
432 | if (limit) | ||
433 | corgibl_flags |= CORGIBL_BATTLOW; | ||
434 | else | ||
435 | corgibl_flags &= ~CORGIBL_BATTLOW; | ||
436 | |||
437 | backlight_update_status(the_corgi_lcd->bl_dev); | ||
438 | } | ||
439 | EXPORT_SYMBOL(corgibl_limit_intensity); | ||
440 | |||
419 | static struct backlight_ops corgi_bl_ops = { | 441 | static struct backlight_ops corgi_bl_ops = { |
420 | .get_brightness = corgi_bl_get_intensity, | 442 | .get_brightness = corgi_bl_get_intensity, |
421 | .update_status = corgi_bl_update_status, | 443 | .update_status = corgi_bl_update_status, |
@@ -426,6 +448,7 @@ static int corgi_lcd_suspend(struct spi_device *spi, pm_message_t state) | |||
426 | { | 448 | { |
427 | struct corgi_lcd *lcd = dev_get_drvdata(&spi->dev); | 449 | struct corgi_lcd *lcd = dev_get_drvdata(&spi->dev); |
428 | 450 | ||
451 | corgibl_flags |= CORGIBL_SUSPENDED; | ||
429 | corgi_bl_set_intensity(lcd, 0); | 452 | corgi_bl_set_intensity(lcd, 0); |
430 | corgi_lcd_set_power(lcd->lcd_dev, FB_BLANK_POWERDOWN); | 453 | corgi_lcd_set_power(lcd->lcd_dev, FB_BLANK_POWERDOWN); |
431 | return 0; | 454 | return 0; |
@@ -435,6 +458,7 @@ static int corgi_lcd_resume(struct spi_device *spi) | |||
435 | { | 458 | { |
436 | struct corgi_lcd *lcd = dev_get_drvdata(&spi->dev); | 459 | struct corgi_lcd *lcd = dev_get_drvdata(&spi->dev); |
437 | 460 | ||
461 | corgibl_flags &= ~CORGIBL_SUSPENDED; | ||
438 | corgi_lcd_set_power(lcd->lcd_dev, FB_BLANK_UNBLANK); | 462 | corgi_lcd_set_power(lcd->lcd_dev, FB_BLANK_UNBLANK); |
439 | backlight_update_status(lcd->bl_dev); | 463 | backlight_update_status(lcd->bl_dev); |
440 | return 0; | 464 | return 0; |
@@ -488,6 +512,9 @@ static int __devinit corgi_lcd_probe(struct spi_device *spi) | |||
488 | dev_set_drvdata(&spi->dev, lcd); | 512 | dev_set_drvdata(&spi->dev, lcd); |
489 | corgi_lcd_set_power(lcd->lcd_dev, FB_BLANK_UNBLANK); | 513 | corgi_lcd_set_power(lcd->lcd_dev, FB_BLANK_UNBLANK); |
490 | backlight_update_status(lcd->bl_dev); | 514 | backlight_update_status(lcd->bl_dev); |
515 | |||
516 | lcd->limit_mask = pdata->limit_mask; | ||
517 | the_corgi_lcd = lcd; | ||
491 | return 0; | 518 | return 0; |
492 | 519 | ||
493 | err_unregister_lcd: | 520 | err_unregister_lcd: |
diff --git a/include/linux/spi/corgi_lcd.h b/include/linux/spi/corgi_lcd.h index 3c53ac26c8d1..b6161aae2752 100644 --- a/include/linux/spi/corgi_lcd.h +++ b/include/linux/spi/corgi_lcd.h | |||
@@ -8,6 +8,7 @@ struct corgi_lcd_platform_data { | |||
8 | int init_mode; | 8 | int init_mode; |
9 | int max_intensity; | 9 | int max_intensity; |
10 | int default_intensity; | 10 | int default_intensity; |
11 | int limit_mask; | ||
11 | 12 | ||
12 | void (*notify)(int intensity); | 13 | void (*notify)(int intensity); |
13 | void (*kick_battery)(void); | 14 | void (*kick_battery)(void); |