aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/video/backlight/ld9040.c
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2012-01-10 19:42:48 -0500
committerLinus Torvalds <torvalds@linux-foundation.org>2012-01-10 19:42:48 -0500
commit40ba587923ae67090d9f141c1d3c951be5c1420e (patch)
tree342a72fc0ee13a0d2496ef970b64dfeadf1355d2 /drivers/video/backlight/ld9040.c
parent54c2c5761febcca46c8037d3a81612991e6c209a (diff)
parent6b550f9495947fc279d12c38feaf98500e8d0646 (diff)
Merge branch 'akpm' (aka "Andrew's patch-bomb")
Andrew elucidates: - First installmeant of MM. We have a HUGE number of MM patches this time. It's crazy. - MAINTAINERS updates - backlight updates - leds - checkpatch updates - misc ELF stuff - rtc updates - reiserfs - procfs - some misc other bits * akpm: (124 commits) user namespace: make signal.c respect user namespaces workqueue: make alloc_workqueue() take printf fmt and args for name procfs: add hidepid= and gid= mount options procfs: parse mount options procfs: introduce the /proc/<pid>/map_files/ directory procfs: make proc_get_link to use dentry instead of inode signal: add block_sigmask() for adding sigmask to current->blocked sparc: make SA_NOMASK a synonym of SA_NODEFER reiserfs: don't lock root inode searching reiserfs: don't lock journal_init() reiserfs: delay reiserfs lock until journal initialization reiserfs: delete comments referring to the BKL drivers/rtc/interface.c: fix alarm rollover when day or month is out-of-range drivers/rtc/rtc-twl.c: add DT support for RTC inside twl4030/twl6030 drivers/rtc/: remove redundant spi driver bus initialization drivers/rtc/rtc-jz4740.c: make jz4740_rtc_driver static drivers/rtc/rtc-mc13xxx.c: make mc13xxx_rtc_idtable static rtc: convert drivers/rtc/* to use module_platform_driver() drivers/rtc/rtc-wm831x.c: convert to devm_kzalloc() drivers/rtc/rtc-wm831x.c: remove unused period IRQ handler ...
Diffstat (limited to 'drivers/video/backlight/ld9040.c')
-rw-r--r--drivers/video/backlight/ld9040.c71
1 files changed, 59 insertions, 12 deletions
diff --git a/drivers/video/backlight/ld9040.c b/drivers/video/backlight/ld9040.c
index da9a5ce0ccb8..78dafc0c8fc5 100644
--- a/drivers/video/backlight/ld9040.c
+++ b/drivers/video/backlight/ld9040.c
@@ -31,6 +31,7 @@
31#include <linux/lcd.h> 31#include <linux/lcd.h>
32#include <linux/backlight.h> 32#include <linux/backlight.h>
33#include <linux/module.h> 33#include <linux/module.h>
34#include <linux/regulator/consumer.h>
34 35
35#include "ld9040_gamma.h" 36#include "ld9040_gamma.h"
36 37
@@ -53,8 +54,51 @@ struct ld9040 {
53 struct lcd_device *ld; 54 struct lcd_device *ld;
54 struct backlight_device *bd; 55 struct backlight_device *bd;
55 struct lcd_platform_data *lcd_pd; 56 struct lcd_platform_data *lcd_pd;
57
58 struct mutex lock;
59 bool enabled;
60};
61
62static struct regulator_bulk_data supplies[] = {
63 { .supply = "vdd3", },
64 { .supply = "vci", },
56}; 65};
57 66
67static void ld9040_regulator_enable(struct ld9040 *lcd)
68{
69 int ret = 0;
70 struct lcd_platform_data *pd = NULL;
71
72 pd = lcd->lcd_pd;
73 mutex_lock(&lcd->lock);
74 if (!lcd->enabled) {
75 ret = regulator_bulk_enable(ARRAY_SIZE(supplies), supplies);
76 if (ret)
77 goto out;
78
79 lcd->enabled = true;
80 }
81 mdelay(pd->power_on_delay);
82out:
83 mutex_unlock(&lcd->lock);
84}
85
86static void ld9040_regulator_disable(struct ld9040 *lcd)
87{
88 int ret = 0;
89
90 mutex_lock(&lcd->lock);
91 if (lcd->enabled) {
92 ret = regulator_bulk_disable(ARRAY_SIZE(supplies), supplies);
93 if (ret)
94 goto out;
95
96 lcd->enabled = false;
97 }
98out:
99 mutex_unlock(&lcd->lock);
100}
101
58static const unsigned short seq_swreset[] = { 102static const unsigned short seq_swreset[] = {
59 0x01, COMMAND_ONLY, 103 0x01, COMMAND_ONLY,
60 ENDDEF, 0x00 104 ENDDEF, 0x00
@@ -532,13 +576,8 @@ static int ld9040_power_on(struct ld9040 *lcd)
532 return -EFAULT; 576 return -EFAULT;
533 } 577 }
534 578
535 if (!pd->power_on) { 579 /* lcd power on */
536 dev_err(lcd->dev, "power_on is NULL.\n"); 580 ld9040_regulator_enable(lcd);
537 return -EFAULT;
538 } else {
539 pd->power_on(lcd->ld, 1);
540 mdelay(pd->power_on_delay);
541 }
542 581
543 if (!pd->reset) { 582 if (!pd->reset) {
544 dev_err(lcd->dev, "reset is NULL.\n"); 583 dev_err(lcd->dev, "reset is NULL.\n");
@@ -582,11 +621,8 @@ static int ld9040_power_off(struct ld9040 *lcd)
582 621
583 mdelay(pd->power_off_delay); 622 mdelay(pd->power_off_delay);
584 623
585 if (!pd->power_on) { 624 /* lcd power off */
586 dev_err(lcd->dev, "power_on is NULL.\n"); 625 ld9040_regulator_disable(lcd);
587 return -EFAULT;
588 } else
589 pd->power_on(lcd->ld, 0);
590 626
591 return 0; 627 return 0;
592} 628}
@@ -693,6 +729,14 @@ static int ld9040_probe(struct spi_device *spi)
693 goto out_free_lcd; 729 goto out_free_lcd;
694 } 730 }
695 731
732 mutex_init(&lcd->lock);
733
734 ret = regulator_bulk_get(lcd->dev, ARRAY_SIZE(supplies), supplies);
735 if (ret) {
736 dev_err(lcd->dev, "Failed to get regulators: %d\n", ret);
737 goto out_free_lcd;
738 }
739
696 ld = lcd_device_register("ld9040", &spi->dev, lcd, &ld9040_lcd_ops); 740 ld = lcd_device_register("ld9040", &spi->dev, lcd, &ld9040_lcd_ops);
697 if (IS_ERR(ld)) { 741 if (IS_ERR(ld)) {
698 ret = PTR_ERR(ld); 742 ret = PTR_ERR(ld);
@@ -739,6 +783,8 @@ static int ld9040_probe(struct spi_device *spi)
739out_unregister_lcd: 783out_unregister_lcd:
740 lcd_device_unregister(lcd->ld); 784 lcd_device_unregister(lcd->ld);
741out_free_lcd: 785out_free_lcd:
786 regulator_bulk_free(ARRAY_SIZE(supplies), supplies);
787
742 kfree(lcd); 788 kfree(lcd);
743 return ret; 789 return ret;
744} 790}
@@ -750,6 +796,7 @@ static int __devexit ld9040_remove(struct spi_device *spi)
750 ld9040_power(lcd, FB_BLANK_POWERDOWN); 796 ld9040_power(lcd, FB_BLANK_POWERDOWN);
751 backlight_device_unregister(lcd->bd); 797 backlight_device_unregister(lcd->bd);
752 lcd_device_unregister(lcd->ld); 798 lcd_device_unregister(lcd->ld);
799 regulator_bulk_free(ARRAY_SIZE(supplies), supplies);
753 kfree(lcd); 800 kfree(lcd);
754 801
755 return 0; 802 return 0;