Hi Andrzej, 2016년 04월 05일 21:52에 Inki Dae 이(가) 쓴 글: > Hi Andrzej, > > 2016-04-05 20:07 GMT+09:00 Andrzej Hajda <a.hajda@xxxxxxxxxxx>: >> Hi Inki, >> >> On 04/05/2016 10:27 AM, Inki Dae wrote: >>> This patch cleans up interface type relevant codes. >>> >>> Trigger mode is determinded only by i80 mode, which isn't >>> related to Display types - HDMI or Display controller. >>> So this patch makes the trigger mode to be set only in case of >>> i80 mode. >> >> With this patch HDMI path image has serious synchronization problems. >> Exynos5433 documentation says that HDMI Timing Generator generates VSYNC >> signal which works as a hardware trigger for DECON-TV, so I guess >> trigger is required. > > Right. One I missed. For DECON-TV, seems that HW trigger mode is mandatory. Looks considered already. for DECON-TV, I80_HW_TRG flag is used mandatorily, .compatible = "samsung,exynos5433-decon-tv", .data = (void *)(I80_HW_TRG | IFTYPE_HDMI) >> >> Btw, I think it could be good to remove suffixes I80_RGV from >> TRIGCON_HWTRIGEN_I80_RGB and TRIGCON_HWTRIGMASK_I80_RGB - they are >> misleading and differ from documentation. > > Indeed. Looked strange when I wrote the suffixes. will send another cleanup patch. Thanks, Inki Dae > >> >> As far as I have tested I80 mode works OK on Decon5433. > > Thanks for testing. > Inki Dae > >> >> Regards >> Andrzej >> >>> >>> Signed-off-by: Inki Dae <inki.dae@xxxxxxxxxxx> >>> --- >>> drivers/gpu/drm/exynos/exynos5433_drm_decon.c | 53 ++++++++++++++------------- >>> 1 file changed, 27 insertions(+), 26 deletions(-) >>> >>> diff --git a/drivers/gpu/drm/exynos/exynos5433_drm_decon.c b/drivers/gpu/drm/exynos/exynos5433_drm_decon.c >>> index 5245bc5..5922e99 100644 >>> --- a/drivers/gpu/drm/exynos/exynos5433_drm_decon.c >>> +++ b/drivers/gpu/drm/exynos/exynos5433_drm_decon.c >>> @@ -28,6 +28,10 @@ >>> #define WINDOWS_NR 3 >>> #define MIN_FB_WIDTH_FOR_16WORD_BURST 128 >>> >>> +#define IFTYPE_I80 (1 << 0) >>> +#define I80_HW_TRG (1 << 1) >>> +#define IFTYPE_HDMI (1 << 2) >>> + >>> static const char * const decon_clks_name[] = { >>> "pclk", >>> "aclk_decon", >>> @@ -38,12 +42,6 @@ static const char * const decon_clks_name[] = { >>> "sclk_decon_eclk", >>> }; >>> >>> -enum decon_iftype { >>> - IFTYPE_RGB, >>> - IFTYPE_I80, >>> - IFTYPE_HDMI >>> -}; >>> - >>> enum decon_flag_bits { >>> BIT_CLKS_ENABLED, >>> BIT_IRQS_ENABLED, >>> @@ -61,7 +59,7 @@ struct decon_context { >>> struct clk *clks[ARRAY_SIZE(decon_clks_name)]; >>> int pipe; >>> unsigned long flags; >>> - enum decon_iftype out_type; >>> + unsigned int out_type; >>> int first_win; >>> }; >>> >>> @@ -95,7 +93,7 @@ static int decon_enable_vblank(struct exynos_drm_crtc *crtc) >>> >>> if (!test_and_set_bit(BIT_IRQS_ENABLED, &ctx->flags)) { >>> val = VIDINTCON0_INTEN; >>> - if (ctx->out_type == IFTYPE_I80) >>> + if (ctx->out_type & IFTYPE_I80) >>> val |= VIDINTCON0_FRAMEDONE; >>> else >>> val |= VIDINTCON0_INTFRMEN; >>> @@ -119,7 +117,7 @@ static void decon_disable_vblank(struct exynos_drm_crtc *crtc) >>> >>> static void decon_setup_trigger(struct decon_context *ctx) >>> { >>> - u32 val = (ctx->out_type != IFTYPE_HDMI) >>> + u32 val = !(ctx->out_type & I80_HW_TRG) >>> ? TRIGCON_TRIGEN_PER_F | TRIGCON_TRIGEN_F | >>> TRIGCON_TE_AUTO_MASK | TRIGCON_SWTRIGEN >>> : TRIGCON_TRIGEN_PER_F | TRIGCON_TRIGEN_F | >>> @@ -136,7 +134,7 @@ static void decon_commit(struct exynos_drm_crtc *crtc) >>> if (test_bit(BIT_SUSPENDED, &ctx->flags)) >>> return; >>> >>> - if (ctx->out_type == IFTYPE_HDMI) { >>> + if (ctx->out_type & IFTYPE_HDMI) { >>> m->crtc_hsync_start = m->crtc_hdisplay + 10; >>> m->crtc_hsync_end = m->crtc_htotal - 92; >>> m->crtc_vsync_start = m->crtc_vdisplay + 1; >>> @@ -151,17 +149,20 @@ static void decon_commit(struct exynos_drm_crtc *crtc) >>> >>> /* lcd on and use command if */ >>> val = VIDOUT_LCD_ON; >>> - if (ctx->out_type == IFTYPE_I80) >>> + if (ctx->out_type & IFTYPE_I80) { >>> val |= VIDOUT_COMMAND_IF; >>> - else >>> + decon_setup_trigger(ctx); >>> + } else { >>> val |= VIDOUT_RGB_IF; >>> + } >>> + >>> writel(val, ctx->addr + DECON_VIDOUTCON0); >>> >>> val = VIDTCON2_LINEVAL(m->vdisplay - 1) | >>> VIDTCON2_HOZVAL(m->hdisplay - 1); >>> writel(val, ctx->addr + DECON_VIDTCON2); >>> >>> - if (ctx->out_type != IFTYPE_I80) { >>> + if (!(ctx->out_type & IFTYPE_I80)) { >>> val = VIDTCON00_VBPD_F( >>> m->crtc_vtotal - m->crtc_vsync_end - 1) | >>> VIDTCON00_VFPD_F( >>> @@ -183,8 +184,6 @@ static void decon_commit(struct exynos_drm_crtc *crtc) >>> writel(val, ctx->addr + DECON_VIDTCON11); >>> } >>> >>> - decon_setup_trigger(ctx); >>> - >>> /* enable output and display signal */ >>> decon_set_bits(ctx, DECON_VIDCON0, VIDCON0_ENVID | VIDCON0_ENVID_F, ~0); >>> } >>> @@ -300,7 +299,7 @@ static void decon_update_plane(struct exynos_drm_crtc *crtc, >>> val = dma_addr + pitch * state->src.h; >>> writel(val, ctx->addr + DECON_VIDW0xADD1B0(win)); >>> >>> - if (ctx->out_type != IFTYPE_HDMI) >>> + if (!(ctx->out_type & IFTYPE_HDMI)) >>> val = BIT_VAL(pitch - state->crtc.w * bpp, 27, 14) >>> | BIT_VAL(state->crtc.w * bpp, 13, 0); >>> else >>> @@ -348,7 +347,7 @@ static void decon_atomic_flush(struct exynos_drm_crtc *crtc) >>> for (i = ctx->first_win; i < WINDOWS_NR; i++) >>> decon_shadow_protect_win(ctx, i, false); >>> >>> - if (ctx->out_type == IFTYPE_I80) >>> + if (ctx->out_type & IFTYPE_I80) >>> set_bit(BIT_WIN_UPDATED, &ctx->flags); >>> } >>> >>> @@ -374,7 +373,7 @@ static void decon_swreset(struct decon_context *ctx) >>> >>> WARN(tries == 0, "failed to software reset DECON\n"); >>> >>> - if (ctx->out_type != IFTYPE_HDMI) >>> + if (!(ctx->out_type & IFTYPE_HDMI)) >>> return; >>> >>> writel(VIDCON0_CLKVALUP | VIDCON0_VLCKFREE, ctx->addr + DECON_VIDCON0); >>> @@ -383,7 +382,9 @@ static void decon_swreset(struct decon_context *ctx) >>> writel(VIDCON1_VCLK_RUN_VDEN_DISABLE, ctx->addr + DECON_VIDCON1); >>> writel(CRCCTRL_CRCEN | CRCCTRL_CRCSTART_F | CRCCTRL_CRCCLKEN, >>> ctx->addr + DECON_CRCCTRL); >>> - decon_setup_trigger(ctx); >>> + >>> + if (ctx->out_type & IFTYPE_I80) >>> + decon_setup_trigger(ctx); >>> } >>> >>> static void decon_enable(struct exynos_drm_crtc *crtc) >>> @@ -509,7 +510,7 @@ static int decon_bind(struct device *dev, struct device *master, void *data) >>> } >>> >>> exynos_plane = &ctx->planes[ctx->first_win]; >>> - out_type = (ctx->out_type == IFTYPE_HDMI) ? EXYNOS_DISPLAY_TYPE_HDMI >>> + out_type = (ctx->out_type & IFTYPE_HDMI) ? EXYNOS_DISPLAY_TYPE_HDMI >>> : EXYNOS_DISPLAY_TYPE_LCD; >>> ctx->crtc = exynos_drm_crtc_create(drm_dev, &exynos_plane->base, >>> ctx->pipe, out_type, >>> @@ -617,11 +618,11 @@ static const struct dev_pm_ops exynos5433_decon_pm_ops = { >>> static const struct of_device_id exynos5433_decon_driver_dt_match[] = { >>> { >>> .compatible = "samsung,exynos5433-decon", >>> - .data = (void *)IFTYPE_RGB >>> + .data = (void *)I80_HW_TRG >>> }, >>> { >>> .compatible = "samsung,exynos5433-decon-tv", >>> - .data = (void *)IFTYPE_HDMI >>> + .data = (void *)(I80_HW_TRG | IFTYPE_HDMI) >>> }, >>> {}, >>> }; >>> @@ -644,12 +645,12 @@ static int exynos5433_decon_probe(struct platform_device *pdev) >>> ctx->dev = dev; >>> >>> of_id = of_match_device(exynos5433_decon_driver_dt_match, &pdev->dev); >>> - ctx->out_type = (enum decon_iftype)of_id->data; >>> + ctx->out_type = (unsigned int)of_id->data; >>> >>> - if (ctx->out_type == IFTYPE_HDMI) >>> + if (ctx->out_type & IFTYPE_HDMI) >>> ctx->first_win = 1; >>> else if (of_get_child_by_name(dev->of_node, "i80-if-timings")) >>> - ctx->out_type = IFTYPE_I80; >>> + ctx->out_type |= IFTYPE_I80; >>> >>> for (i = 0; i < ARRAY_SIZE(decon_clks_name); i++) { >>> struct clk *clk; >>> @@ -674,7 +675,7 @@ static int exynos5433_decon_probe(struct platform_device *pdev) >>> } >>> >>> res = platform_get_resource_byname(pdev, IORESOURCE_IRQ, >>> - (ctx->out_type == IFTYPE_I80) ? "lcd_sys" : "vsync"); >>> + (ctx->out_type & IFTYPE_I80) ? "lcd_sys" : "vsync"); >>> if (!res) { >>> dev_err(dev, "cannot find IRQ resource\n"); >>> return -ENXIO; >>> >> >> _______________________________________________ >> dri-devel mailing list >> dri-devel@xxxxxxxxxxxxxxxxxxxxx >> https://lists.freedesktop.org/mailman/listinfo/dri-devel > -- > To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html > > -- To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html