On 2014년 10월 01일 15:19, YoungJun Cho wrote: > The I80 interface uses SYS_WE and SYS_CS to process > 1 pixel data, so it requires the twice faster clock > than the pixel clock. > And the frame done interrupt should occurr prior to > the next TE signal, H/W guy recommends to use as 1.73 > times faster clock frequency. > > Signed-off-by: YoungJun Cho <yj44.cho@xxxxxxxxxxx> > Acked-by: Inki Dae <inki.dae@xxxxxxxxxxx> > Acked-by: Kyungmin Park <kyungmin.park@xxxxxxxxxxx> > --- > drivers/gpu/drm/exynos/exynos_drm_fimd.c | 26 ++++++++++++++++++++------ > 1 file changed, 20 insertions(+), 6 deletions(-) > > diff --git a/drivers/gpu/drm/exynos/exynos_drm_fimd.c b/drivers/gpu/drm/exynos/exynos_drm_fimd.c > index b2f6007..05c2a97a 100644 > --- a/drivers/gpu/drm/exynos/exynos_drm_fimd.c > +++ b/drivers/gpu/drm/exynos/exynos_drm_fimd.c > @@ -81,6 +81,11 @@ > #define LCD_WR_HOLD(x) ((x) << 4) > #define I80IFEN_ENABLE (1 << 0) > > +/* I80 interface clock */ > +#define I80_DATA_SAMPLING_CYCLE 2 > +#define I80_TE_PERIOD_US 1667 > +#define I80_DATA_TRANSACTION_TIME_US 964 > + > /* FIMD has totally five hardware windows. */ > #define WINDOWS_NR 5 > > @@ -303,16 +308,25 @@ static void fimd_mgr_remove(struct exynos_drm_manager *mgr) > static u32 fimd_calc_clkdiv(struct fimd_context *ctx, > const struct drm_display_mode *mode) > { > - unsigned long ideal_clk = mode->htotal * mode->vtotal * mode->vrefresh; > + unsigned long ideal_clk; > u32 clkdiv; > > if (ctx->i80_if) { > /* > - * The frame done interrupt should be occurred prior to the > - * next TE signal. > + * The I80 interface uses SYS_WE and SYS_CS to process 1 pixel > + * data, so it requires the twice faster clock than the pixel > + * clock[I80_DATA_SAMPLING_CYCLE]. > + * And the frame done interrupt should occurr prior to the next > + * TE signal, H/W guy recommends to use as 1.73 times faster > + * frequency[I80_TE_PERIOD_US / I80_DATA_TRANSACTION_TIME_US]. > */ > - ideal_clk *= 2; > - } > + ideal_clk = mode->hdisplay * mode->vdisplay * > + I80_DATA_SAMPLING_CYCLE * > + I80_TE_PERIOD_US / I80_DATA_TRANSACTION_TIME_US; How about using one constant directly? I.e., #define RECOMMENDED_VAR 1.73 ... I80_DATA_SAMPLING_CYCLE * RECOMMENDED_VAR Is there any case that the te period and data transaction time should be changed? Thanks, Inki Dae > + } else > + ideal_clk = mode->htotal * mode->vtotal; > + > + ideal_clk *= mode->vrefresh; > > /* Find the clock divider value that gets us closest to ideal_clk */ > clkdiv = DIV_ROUND_UP(clk_get_rate(ctx->lcd_clk), ideal_clk); > @@ -431,7 +445,7 @@ static void fimd_commit(struct exynos_drm_manager *mgr) > val |= VIDCON0_CLKSEL_LCD; > > clkdiv = fimd_calc_clkdiv(ctx, mode); > - if (clkdiv > 1) > + if (clkdiv >= 1) > val |= VIDCON0_CLKVAL_F(clkdiv - 1) | VIDCON0_CLKDIR; > > writel(val, ctx->regs + VIDCON0); > _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/dri-devel