summaryrefslogtreecommitdiffstats
path: root/drivers/video/auo_k1901fb.c
diff options
context:
space:
mode:
authorHeiko Stübner <heiko@sntech.de>2013-03-22 15:13:37 +0100
committerTomi Valkeinen <tomi.valkeinen@ti.com>2013-04-04 12:08:06 +0200
commit70f1e28e65dec704cd49bf7e21c2c372096cf5b3 (patch)
tree1fefaac9ed8d2e8fe0ccd91b727c237017dd240d /drivers/video/auo_k1901fb.c
parentAUO-K190x: Use correct line length (diff)
downloadlinux-70f1e28e65dec704cd49bf7e21c2c372096cf5b3.tar.xz
linux-70f1e28e65dec704cd49bf7e21c2c372096cf5b3.zip
AUO-K190x: add runtime-pm calls to controller init functions
The controller init may be called from a context where the device is runtime suspended, leading to a deadlock, as the controllers only accepts the wakeup command when suspended. Signed-off-by: Heiko Stübner <heiko@sntech.de> Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
Diffstat (limited to 'drivers/video/auo_k1901fb.c')
-rw-r--r--drivers/video/auo_k1901fb.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/video/auo_k1901fb.c b/drivers/video/auo_k1901fb.c
index 9efbe2763447..12b9adcb75c5 100644
--- a/drivers/video/auo_k1901fb.c
+++ b/drivers/video/auo_k1901fb.c
@@ -101,9 +101,12 @@
static void auok1901_init(struct auok190xfb_par *par)
{
+ struct device *dev = par->info->device;
struct auok190x_board *board = par->board;
u16 init_param = 0;
+ pm_runtime_get_sync(dev);
+
init_param |= AUOK190X_INIT_INVERSE_WHITE;
init_param |= AUOK190X_INIT_FORMAT0;
init_param |= AUOK1901_INIT_RESOLUTION(par->resolution);
@@ -113,6 +116,9 @@ static void auok1901_init(struct auok190xfb_par *par)
/* let the controller finish */
board->wait_for_rdy(par);
+
+ pm_runtime_mark_last_busy(dev);
+ pm_runtime_put_autosuspend(dev);
}
static void auok1901_update_region(struct auok190xfb_par *par, int mode,