diff options
-rw-r--r-- | drivers/video/fbdev/mxc/mxc_ipuv3_fb.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/drivers/video/fbdev/mxc/mxc_ipuv3_fb.c b/drivers/video/fbdev/mxc/mxc_ipuv3_fb.c index 926990316639..50b4f31bc536 100644 --- a/drivers/video/fbdev/mxc/mxc_ipuv3_fb.c +++ b/drivers/video/fbdev/mxc/mxc_ipuv3_fb.c @@ -1120,6 +1120,7 @@ static int mxcfb_set_par(struct fb_info *fbi) int ov_pos_ret = 0; struct mxcfb_info *mxc_fbi_fg = NULL; bool ovfbi_enable = false, on_the_fly; + int prev_line_length; if (ipu_ch_param_bad_alpha_pos(fbi_to_pixfmt(fbi, true)) && mxc_fbi->alpha_chan_en) { @@ -1143,6 +1144,7 @@ static int mxcfb_set_par(struct fb_info *fbi) if (fbi->var.xres == 0 || fbi->var.yres == 0) return 0; + prev_line_length = fbi->fix.line_length; mxcfb_set_fix(fbi); mxcfb_check_resolve(fbi); @@ -1214,6 +1216,11 @@ static int mxcfb_set_par(struct fb_info *fbi) if (mxcfb_map_video_memory(fbi) < 0) return -ENOMEM; + } else { + if (prev_line_length && (prev_line_length != fbi->fix.line_length)) { + memset((char *)fbi->screen_base, 0, fbi->fix.smem_len); + mxc_fbi->first_set_par = false; + } } if (mxc_fbi->first_set_par) { |