diff options
author | Balaji Rao <balajirrao@openmoko.org> | 2009-02-25 13:53:03 +0000 |
---|---|---|
committer | Andy Green <agreen@octopus.localdomain> | 2009-02-25 13:53:03 +0000 |
commit | 83cf37799009f6a3db4fef141c798c876124954f (patch) | |
tree | ba9042624039a0452db558548b050f04c9de37e5 /drivers/video/display | |
parent | e6fe14056d17b7ee5f328634c8b7529330a28f88 (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.c | 7 |
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"); |