From b02f7acb2c1f40b69b6e50ae6ccb28ee89ef465c Mon Sep 17 00:00:00 2001 From: Huang Jiachai Date: Mon, 8 Aug 2016 14:26:32 +0800 Subject: [PATCH] video: rockchip: fb: only open vop one time when switch screen Change-Id: I7c95d25d80e303aae41dd9bec0e3eb326c4baba7 Signed-off-by: Huang Jiachai --- drivers/video/rockchip/rk_fb.c | 73 ++++++++++++++-------------------- 1 file changed, 30 insertions(+), 43 deletions(-) diff --git a/drivers/video/rockchip/rk_fb.c b/drivers/video/rockchip/rk_fb.c index c8393580a059..a66afcbec547 100644 --- a/drivers/video/rockchip/rk_fb.c +++ b/drivers/video/rockchip/rk_fb.c @@ -3671,50 +3671,37 @@ int rk_fb_switch_screen(struct rk_screen *screen, int enable, int lcdc_id) if (!dev_drv->uboot_logo || load_screen || (rk_fb->disp_policy != DISPLAY_POLICY_BOX)) { - for (i = 0; i < dev_drv->lcdc_win_num; i++) { - info = rk_fb->fb[dev_drv->fb_index_base + i]; - fb_par = (struct rk_fb_par *)info->par; - win_id = dev_drv->ops->fb_get_win_id(dev_drv, info->fix.id); - win = dev_drv->win[win_id]; - if (win && fb_par->state) { - dev_drv->ops->load_screen(dev_drv, 1); - - info->var.activate |= FB_ACTIVATE_FORCE; - if (rk_fb->disp_mode == ONE_DUAL) { - info->var.grayscale &= 0xff; - info->var.grayscale |= - (dev_drv->cur_screen->xsize << 8) + - (dev_drv->cur_screen->ysize << 20); - } - if (dev_drv->uboot_logo && win->state) { - if (win->area[0].xpos || - win->area[0].ypos) { - win->area[0].xpos = - (screen->mode.xres - - win->area[0].xsize) / 2; - win->area[0].ypos = - (screen->mode.yres - - win->area[0].ysize) / 2; - } else { - win->area[0].xsize = - screen->mode.xres; - win->area[0].ysize = - screen->mode.yres; - } - dev_drv->ops->set_par(dev_drv, i); - dev_drv->ops->cfg_done(dev_drv); - } else if (!dev_drv->win[win_id]->state) { - dev_drv->ops->open(dev_drv, win_id, 1); - /* dev_drv->suspend_flag = 0; */ - /* mutex_lock(&dev_drv->win_config); - * info->var.xoffset = 0; - * info->var.yoffset = 0; - * info->fbops->fb_set_par(info); - * info->fbops->fb_pan_display(&info->var, - * info); - * mutex_unlock(&dev_drv->win_config); - */ + info = rk_fb->fb[dev_drv->fb_index_base]; + fb_par = (struct rk_fb_par *)info->par; + win_id = 0; + win = dev_drv->win[win_id]; + if (win && fb_par->state) { + dev_drv->ops->load_screen(dev_drv, 1); + info->var.activate |= FB_ACTIVATE_FORCE; + if (rk_fb->disp_mode == ONE_DUAL) { + info->var.grayscale &= 0xff; + info->var.grayscale |= + (dev_drv->cur_screen->xsize << 8) + + (dev_drv->cur_screen->ysize << 20); + } + if (dev_drv->uboot_logo && win->state) { + if (win->area[0].xpos || + win->area[0].ypos) { + win->area[0].xpos = + (screen->mode.xres - + win->area[0].xsize) / 2; + win->area[0].ypos = + (screen->mode.yres - + win->area[0].ysize) / 2; + } else { + win->area[0].xsize = screen->mode.xres; + win->area[0].ysize = screen->mode.yres; } + dev_drv->ops->set_par(dev_drv, i); + dev_drv->ops->cfg_done(dev_drv); + } else if (!dev_drv->win[win_id]->state) { + dev_drv->ops->open(dev_drv, win_id, 1); + info->fbops->fb_pan_display(&info->var, info); } } } else { -- 2.34.1