From: "Chaithrika U S" <chaithrika-l0cyMroinI0@public.gmane.org>
To: 'Chaithrika U S' <chaithrika-l0cyMroinI0@public.gmane.org>,
linux-fbdev-devel-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org
Cc: davinci-linux-open-source-VycZQUHpC/PFrsHnngEfi1aTQe2KTcn/@public.gmane.org,
akpm-de/tnXTf+JLsfHDXvbKv3WD2FQJk+8+b@public.gmane.org,
krzysztof.h1-IjDXvh/HVVUAvxtiuMwx3w@public.gmane.org
Subject: RE: [PATCH] davinci: fb: Calculate the clock divider from pixel clock info
Date: Fri, 23 Oct 2009 10:41:07 +0530 [thread overview]
Message-ID: <032201ca539f$3a879530$af96bf90$@com> (raw)
In-Reply-To: <1256033887-1582-1-git-send-email-chaithrika-l0cyMroinI0@public.gmane.org>
All,
Any comments/suggestions on this patch?
Regards,
Chaithrika
On Tue, Oct 20, 2009 at 15:48:07, Chaithrika U S wrote:
> The clock divider value can be calculated from the pixel clock
> value for the panel. This gives more flexiblity to the driver
> to change the divider value on the fly as in the case of cpufreq
> feature- support for which will be added shortly.
>
> Signed-off-by: Chaithrika U S <chaithrika-l0cyMroinI0@public.gmane.org>
> ---
> This patch applies on Linus' kernel tree.
> Resending this patch as missed out marking fbdev list previously.
>
> drivers/video/da8xx-fb.c | 28 ++++++++++++++++++++--------
> 1 files changed, 20 insertions(+), 8 deletions(-)
>
> diff --git a/drivers/video/da8xx-fb.c b/drivers/video/da8xx-fb.c
> index d065894..d9ab839 100644
> --- a/drivers/video/da8xx-fb.c
> +++ b/drivers/video/da8xx-fb.c
> @@ -113,6 +113,7 @@ struct da8xx_fb_par {
> unsigned short pseudo_palette[16];
> unsigned int databuf_sz;
> unsigned int palette_sz;
> + unsigned int pxl_clk;
> };
>
> /* Variable Screen Information */
> @@ -155,7 +156,7 @@ struct da8xx_panel {
> int vfp; /* Vertical front porch */
> int vbp; /* Vertical back porch */
> int vsw; /* Vertical Sync Pulse Width */
> - int pxl_clk; /* Pixel clock */
> + unsigned int pxl_clk; /* Pixel clock */
> unsigned char invert_pxl_clk; /* Invert Pixel clock */
> };
>
> @@ -171,7 +172,7 @@ static struct da8xx_panel known_lcd_panels[] = {
> .vfp = 2,
> .vbp = 2,
> .vsw = 0,
> - .pxl_clk = 0x10,
> + .pxl_clk = 4608000,
> .invert_pxl_clk = 1,
> },
> /* Sharp LK043T1DG01 */
> @@ -185,7 +186,7 @@ static struct da8xx_panel known_lcd_panels[] = {
> .vfp = 2,
> .vbp = 2,
> .vsw = 10,
> - .pxl_clk = 0x12,
> + .pxl_clk = 7833600,
> .invert_pxl_clk = 0,
> },
> };
> @@ -451,6 +452,18 @@ static void lcd_reset(struct da8xx_fb_par *par)
> lcdc_write(0, LCD_RASTER_CTRL_REG);
> }
>
> +static void lcd_calc_clk_divider(struct da8xx_fb_par *par)
> +{
> + unsigned int lcd_clk, div;
> +
> + lcd_clk = clk_get_rate(par->lcdc_clk);
> + div = lcd_clk / par->pxl_clk;
> +
> + /* Configure the LCD clock divisor. */
> + lcdc_write(LCD_CLK_DIVISOR(div) |
> + (LCD_RASTER_MODE & 0x1), LCD_CTRL_REG);
> +}
> +
> static int lcd_init(struct da8xx_fb_par *par, const struct lcd_ctrl_config *cfg,
> struct da8xx_panel *panel)
> {
> @@ -459,9 +472,8 @@ static int lcd_init(struct da8xx_fb_par *par, const struct lcd_ctrl_config *cfg,
>
> lcd_reset(par);
>
> - /* Configure the LCD clock divisor. */
> - lcdc_write(LCD_CLK_DIVISOR(panel->pxl_clk) |
> - (LCD_RASTER_MODE & 0x1), LCD_CTRL_REG);
> + /* Calculate the divider */
> + lcd_calc_clk_divider(par);
>
> if (panel->invert_pxl_clk)
> lcdc_write((lcdc_read(LCD_RASTER_TIMING_2_REG) |
> @@ -721,6 +733,8 @@ static int __init fb_probe(struct platform_device *device)
> }
>
> par = da8xx_fb_info->par;
> + par->lcdc_clk = fb_clk;
> + par->pxl_clk = lcdc_info->pxl_clk;
>
> if (lcd_init(par, lcd_cfg, lcdc_info) < 0) {
> dev_err(&device->dev, "lcd_init failed\n");
> @@ -753,8 +767,6 @@ static int __init fb_probe(struct platform_device *device)
> da8xx_fb_fix.smem_len = par->databuf_sz - par->palette_sz;
> da8xx_fb_fix.line_length = (lcdc_info->width * lcd_cfg->bpp) / 8;
>
> - par->lcdc_clk = fb_clk;
> -
> par->irq = platform_get_irq(device, 0);
> if (par->irq < 0) {
> ret = -ENOENT;
> --
> 1.5.6
>
next prev parent reply other threads:[~2009-10-23 5:11 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-10-20 10:18 [PATCH] davinci: fb: Calculate the clock divider from pixel clock info Chaithrika U S
[not found] ` <1256033887-1582-1-git-send-email-chaithrika-l0cyMroinI0@public.gmane.org>
2009-10-23 5:11 ` Chaithrika U S [this message]
2009-11-23 3:34 ` Chaithrika U S
-- strict thread matches above, loose matches on Subject: below --
2009-10-16 10:27 Chaithrika U S
2009-10-16 11:06 ` Chaithrika U S
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to='032201ca539f$3a879530$af96bf90$@com' \
--to=chaithrika-l0cymroini0@public.gmane.org \
--cc=akpm-de/tnXTf+JLsfHDXvbKv3WD2FQJk+8+b@public.gmane.org \
--cc=davinci-linux-open-source-VycZQUHpC/PFrsHnngEfi1aTQe2KTcn/@public.gmane.org \
--cc=krzysztof.h1-IjDXvh/HVVUAvxtiuMwx3w@public.gmane.org \
--cc=linux-fbdev-devel-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.