From ed5bebf29e82beab3456901e26a495ae0a49ebad Mon Sep 17 00:00:00 2001 From: Laurent Pinchart Date: Wed, 31 Aug 2011 13:00:54 +0200 Subject: fbdev: sh_mobile_lcdc: Add support for format changes at runtime Implement .fb_set_par to support frame buffer format changes at runtime. Signed-off-by: Laurent Pinchart Signed-off-by: Florian Tobias Schandinat --- drivers/video/sh_mobile_lcdcfb.c | 14 ++++++++++++++ 1 file changed, 14 insertions(+) (limited to 'drivers/video/sh_mobile_lcdcfb.c') diff --git a/drivers/video/sh_mobile_lcdcfb.c b/drivers/video/sh_mobile_lcdcfb.c index 33b0ff83c154..f9f420d3c403 100644 --- a/drivers/video/sh_mobile_lcdcfb.c +++ b/drivers/video/sh_mobile_lcdcfb.c @@ -1154,6 +1154,19 @@ static int sh_mobile_check_var(struct fb_var_screeninfo *var, struct fb_info *in return 0; } +static int sh_mobile_set_par(struct fb_info *info) +{ + struct sh_mobile_lcdc_chan *ch = info->par; + int ret; + + sh_mobile_lcdc_stop(ch->lcdc); + ret = sh_mobile_lcdc_start(ch->lcdc); + if (ret < 0) + dev_err(info->dev, "%s: unable to restart LCDC\n", __func__); + + return ret; +} + /* * Screen blanking. Behavior is as follows: * FB_BLANK_UNBLANK: screen unblanked, clocks enabled @@ -1211,6 +1224,7 @@ static struct fb_ops sh_mobile_lcdc_ops = { .fb_open = sh_mobile_open, .fb_release = sh_mobile_release, .fb_check_var = sh_mobile_check_var, + .fb_set_par = sh_mobile_set_par, }; static int sh_mobile_lcdc_update_bl(struct backlight_device *bdev) -- cgit v1.2.3