aboutsummaryrefslogtreecommitdiff
path: root/drivers/video/display
diff options
context:
space:
mode:
authorBalaji Rao <balajirrao@openmoko.org>2009-02-25 13:53:03 +0000
committerAndy Green <agreen@octopus.localdomain>2009-02-25 13:53:03 +0000
commit83cf37799009f6a3db4fef141c798c876124954f (patch)
treeba9042624039a0452db558548b050f04c9de37e5 /drivers/video/display
parente6fe14056d17b7ee5f328634c8b7529330a28f88 (diff)
Fix jbt6k74 qvga_normal state handling
Hi Andy, Here's the fix for the qvga-normal bug we observed the other day here - when the screen is powered up again after a blanking, in qvga-normal mode, we see a WSOD(kind of!)
Diffstat (limited to 'drivers/video/display')
-rw-r--r--drivers/video/display/jbt6k74.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/drivers/video/display/jbt6k74.c b/drivers/video/display/jbt6k74.c
index 141e8d27601..930c106b99c 100644
--- a/drivers/video/display/jbt6k74.c
+++ b/drivers/video/display/jbt6k74.c
@@ -112,6 +112,7 @@ static const char *jbt_state_names[] = {
struct jbt_info {
enum jbt_state state, last_state;
+ enum jbt_state normal_state; /* QVGA or VGA */
struct spi_device *spi_dev;
struct mutex lock; /* protects tx_buf and reg_cache */
struct notifier_block fb_notif;
@@ -446,6 +447,10 @@ int jbt6k74_enter_state(struct jbt_info *jbt, enum jbt_state new_state)
if (rc == 0)
jbt->state = new_state;
+ if (new_state == JBT_STATE_NORMAL ||
+ new_state == JBT_STATE_QVGA_NORMAL)
+ jbt->normal_state = new_state;
+
return rc;
}
EXPORT_SYMBOL_GPL(jbt6k74_enter_state);
@@ -595,7 +600,7 @@ static int fb_notifier_callback(struct notifier_block *self,
switch (fb_blank) {
case FB_BLANK_UNBLANK:
dev_info(&jbt->spi_dev->dev, "**** jbt6k74 unblank\n");
- jbt6k74_enter_state(jbt, JBT_STATE_NORMAL);
+ jbt6k74_enter_state(jbt, jbt->normal_state);
break;
case FB_BLANK_NORMAL:
dev_info(&jbt->spi_dev->dev, "**** jbt6k74 normal\n");