Message ID | 1382022155-21954-8-git-send-email-denis@eukrea.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On 17:02 Thu 17 Oct , Denis Carikli wrote: > This commit is based on the following commit by Fabio Estevam: > 4344429 video: mxsfb: Introduce regulator support > > Cc: Jean-Christophe Plagniol-Villard <plagnioj@jcrosoft.com> > Cc: Tomi Valkeinen <tomi.valkeinen@ti.com> > Cc: linux-fbdev@vger.kernel.org > Cc: Sascha Hauer <kernel@pengutronix.de> > Cc: linux-arm-kernel@lists.infradead.org > Cc: Eric Bénard <eric@eukrea.com> > Signed-off-by: Denis Carikli <denis@eukrea.com> > --- > drivers/video/mx3fb.c | 47 ++++++++++++++++++++++++++++++++++++++++++++++- > 1 file changed, 46 insertions(+), 1 deletion(-) > > diff --git a/drivers/video/mx3fb.c b/drivers/video/mx3fb.c > index 804f874..37704da 100644 > --- a/drivers/video/mx3fb.c > +++ b/drivers/video/mx3fb.c > @@ -27,6 +27,7 @@ > #include <linux/clk.h> > #include <linux/mutex.h> > #include <linux/dma/ipu-dma.h> > +#include <linux/regulator/consumer.h> > > #include <linux/platform_data/dma-imx.h> > #include <linux/platform_data/video-mx3fb.h> > @@ -267,6 +268,7 @@ struct mx3fb_info { > struct dma_async_tx_descriptor *txd; > dma_cookie_t cookie; > struct scatterlist sg[2]; > + struct regulator *reg_lcd; > > struct fb_var_screeninfo cur_var; /* current var info */ > }; > @@ -1001,6 +1003,7 @@ static void __blank(int blank, struct fb_info *fbi) > struct mx3fb_info *mx3_fbi = fbi->par; > struct mx3fb_data *mx3fb = mx3_fbi->mx3fb; > int was_blank = mx3_fbi->blank; > + int ret; > > mx3_fbi->blank = blank; > > @@ -1019,6 +1022,15 @@ static void __blank(int blank, struct fb_info *fbi) > case FB_BLANK_HSYNC_SUSPEND: > case FB_BLANK_NORMAL: > sdc_set_brightness(mx3fb, 0); > + if (mx3_fbi->reg_lcd) { > + if (regulator_is_enabled(mx3_fbi->reg_lcd)) { do we realy need ot check if enabled? this should be handled by the regulator API same as clock I can disable not enabled clock Best Regards, J. > + ret = regulator_disable(mx3_fbi->reg_lcd); > + if (ret) > + dev_warn(fbi->device, > + "lcd regulator disable failed " > + "with error: %d\n", ret); > + } > + } > memset((char *)fbi->screen_base, 0, fbi->fix.smem_len); > /* Give LCD time to update - enough for 50 and 60 Hz */ > msleep(25); > @@ -1026,7 +1038,17 @@ static void __blank(int blank, struct fb_info *fbi) > break; > case FB_BLANK_UNBLANK: > sdc_enable_channel(mx3_fbi); > + if (mx3_fbi->reg_lcd) { > + if (!regulator_is_enabled(mx3_fbi->reg_lcd)) { > + ret = regulator_enable(mx3_fbi->reg_lcd); > + if (ret) > + dev_warn(fbi->device, > + "lcd regulator enable failed " > + "with error: %d\n", ret); > + } > + } > sdc_set_brightness(mx3fb, mx3fb->backlight_level); > + > break; > } > } > @@ -1202,6 +1224,7 @@ static int mx3fb_suspend(struct platform_device *pdev, pm_message_t state) > { > struct mx3fb_data *mx3fb = platform_get_drvdata(pdev); > struct mx3fb_info *mx3_fbi = mx3fb->fbi->par; > + int ret; > > console_lock(); > fb_set_suspend(mx3fb->fbi, 1); > @@ -1210,7 +1233,15 @@ static int mx3fb_suspend(struct platform_device *pdev, pm_message_t state) > if (mx3_fbi->blank == FB_BLANK_UNBLANK) { > sdc_disable_channel(mx3_fbi); > sdc_set_brightness(mx3fb, 0); > - > + if (mx3_fbi->reg_lcd) { > + if (regulator_is_enabled(mx3_fbi->reg_lcd)) { > + ret = regulator_disable(mx3_fbi->reg_lcd); > + if (ret) > + dev_warn(&pdev->dev, > + "lcd regulator disable failed " > + "with error: %d\n", ret); > + } > + } > } > return 0; > } > @@ -1222,10 +1253,20 @@ static int mx3fb_resume(struct platform_device *pdev) > { > struct mx3fb_data *mx3fb = platform_get_drvdata(pdev); > struct mx3fb_info *mx3_fbi = mx3fb->fbi->par; > + int ret; > > if (mx3_fbi->blank == FB_BLANK_UNBLANK) { > sdc_enable_channel(mx3_fbi); > sdc_set_brightness(mx3fb, mx3fb->backlight_level); > + if (mx3_fbi->reg_lcd) { > + if (!regulator_is_enabled(mx3_fbi->reg_lcd)) { > + ret = regulator_enable(mx3_fbi->reg_lcd); > + if (ret) > + dev_warn(&pdev->dev, > + "lcd regulator enable failed " > + "with error: %d\n", ret); > + } > + } > } > > console_lock(); > @@ -1438,6 +1479,10 @@ static int init_fb_chan(struct mx3fb_data *mx3fb, struct idmac_channel *ichan) > if (ret < 0) > goto erfb; > > + mx3fbi->reg_lcd = devm_regulator_get(dev, "lcd"); > + if (IS_ERR(mx3fbi->reg_lcd)) > + mx3fbi->reg_lcd = NULL; > + > return 0; > > erfb: > -- > 1.7.9.5 >
diff --git a/drivers/video/mx3fb.c b/drivers/video/mx3fb.c index 804f874..37704da 100644 --- a/drivers/video/mx3fb.c +++ b/drivers/video/mx3fb.c @@ -27,6 +27,7 @@ #include <linux/clk.h> #include <linux/mutex.h> #include <linux/dma/ipu-dma.h> +#include <linux/regulator/consumer.h> #include <linux/platform_data/dma-imx.h> #include <linux/platform_data/video-mx3fb.h> @@ -267,6 +268,7 @@ struct mx3fb_info { struct dma_async_tx_descriptor *txd; dma_cookie_t cookie; struct scatterlist sg[2]; + struct regulator *reg_lcd; struct fb_var_screeninfo cur_var; /* current var info */ }; @@ -1001,6 +1003,7 @@ static void __blank(int blank, struct fb_info *fbi) struct mx3fb_info *mx3_fbi = fbi->par; struct mx3fb_data *mx3fb = mx3_fbi->mx3fb; int was_blank = mx3_fbi->blank; + int ret; mx3_fbi->blank = blank; @@ -1019,6 +1022,15 @@ static void __blank(int blank, struct fb_info *fbi) case FB_BLANK_HSYNC_SUSPEND: case FB_BLANK_NORMAL: sdc_set_brightness(mx3fb, 0); + if (mx3_fbi->reg_lcd) { + if (regulator_is_enabled(mx3_fbi->reg_lcd)) { + ret = regulator_disable(mx3_fbi->reg_lcd); + if (ret) + dev_warn(fbi->device, + "lcd regulator disable failed " + "with error: %d\n", ret); + } + } memset((char *)fbi->screen_base, 0, fbi->fix.smem_len); /* Give LCD time to update - enough for 50 and 60 Hz */ msleep(25); @@ -1026,7 +1038,17 @@ static void __blank(int blank, struct fb_info *fbi) break; case FB_BLANK_UNBLANK: sdc_enable_channel(mx3_fbi); + if (mx3_fbi->reg_lcd) { + if (!regulator_is_enabled(mx3_fbi->reg_lcd)) { + ret = regulator_enable(mx3_fbi->reg_lcd); + if (ret) + dev_warn(fbi->device, + "lcd regulator enable failed " + "with error: %d\n", ret); + } + } sdc_set_brightness(mx3fb, mx3fb->backlight_level); + break; } } @@ -1202,6 +1224,7 @@ static int mx3fb_suspend(struct platform_device *pdev, pm_message_t state) { struct mx3fb_data *mx3fb = platform_get_drvdata(pdev); struct mx3fb_info *mx3_fbi = mx3fb->fbi->par; + int ret; console_lock(); fb_set_suspend(mx3fb->fbi, 1); @@ -1210,7 +1233,15 @@ static int mx3fb_suspend(struct platform_device *pdev, pm_message_t state) if (mx3_fbi->blank == FB_BLANK_UNBLANK) { sdc_disable_channel(mx3_fbi); sdc_set_brightness(mx3fb, 0); - + if (mx3_fbi->reg_lcd) { + if (regulator_is_enabled(mx3_fbi->reg_lcd)) { + ret = regulator_disable(mx3_fbi->reg_lcd); + if (ret) + dev_warn(&pdev->dev, + "lcd regulator disable failed " + "with error: %d\n", ret); + } + } } return 0; } @@ -1222,10 +1253,20 @@ static int mx3fb_resume(struct platform_device *pdev) { struct mx3fb_data *mx3fb = platform_get_drvdata(pdev); struct mx3fb_info *mx3_fbi = mx3fb->fbi->par; + int ret; if (mx3_fbi->blank == FB_BLANK_UNBLANK) { sdc_enable_channel(mx3_fbi); sdc_set_brightness(mx3fb, mx3fb->backlight_level); + if (mx3_fbi->reg_lcd) { + if (!regulator_is_enabled(mx3_fbi->reg_lcd)) { + ret = regulator_enable(mx3_fbi->reg_lcd); + if (ret) + dev_warn(&pdev->dev, + "lcd regulator enable failed " + "with error: %d\n", ret); + } + } } console_lock(); @@ -1438,6 +1479,10 @@ static int init_fb_chan(struct mx3fb_data *mx3fb, struct idmac_channel *ichan) if (ret < 0) goto erfb; + mx3fbi->reg_lcd = devm_regulator_get(dev, "lcd"); + if (IS_ERR(mx3fbi->reg_lcd)) + mx3fbi->reg_lcd = NULL; + return 0; erfb:
This commit is based on the following commit by Fabio Estevam: 4344429 video: mxsfb: Introduce regulator support Cc: Jean-Christophe Plagniol-Villard <plagnioj@jcrosoft.com> Cc: Tomi Valkeinen <tomi.valkeinen@ti.com> Cc: linux-fbdev@vger.kernel.org Cc: Sascha Hauer <kernel@pengutronix.de> Cc: linux-arm-kernel@lists.infradead.org Cc: Eric Bénard <eric@eukrea.com> Signed-off-by: Denis Carikli <denis@eukrea.com> --- drivers/video/mx3fb.c | 47 ++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 46 insertions(+), 1 deletion(-)