2016년 05월 10일 16:08에 Andrzej Hajda 이(가) 쓴 글: > On 05/10/2016 08:24 AM, Inki Dae wrote: >> Hi Andrzej, >> >> 2016년 05월 10일 15:08에 Andrzej Hajda 이(가) 쓴 글: >>> Hi Inki, >>> >>> >>> On 05/10/2016 07:31 AM, Inki Dae wrote: >>>> Hi Andrzej, >>>> >>>> 2016년 04월 29일 22:42에 Andrzej Hajda 이(가) 쓴 글: >>>>> It seems trigger cannot be configured too early, otherwise it does not work in >>>>> case of panel. The patch fixes also trigger flag logic, previously HW-TRIGGER >>>>> flag was cleared in case of panel - as a result panel used always software >>>> Andrzej, sorry but I can't understand what above two lines mean. Can you give me more details? >>> Details below. >>> >>>>> trigger. >>>>> >>>>> Signed-off-by: Andrzej Hajda <a.hajda@xxxxxxxxxxx> >>>>> --- >>>>> drivers/gpu/drm/exynos/exynos5433_drm_decon.c | 10 ++++------ >>>>> 1 file changed, 4 insertions(+), 6 deletions(-) >>>>> >>>>> diff --git a/drivers/gpu/drm/exynos/exynos5433_drm_decon.c b/drivers/gpu/drm/exynos/exynos5433_drm_decon.c >>>>> index 7b4f699..9ae913b 100644 >>>>> --- a/drivers/gpu/drm/exynos/exynos5433_drm_decon.c >>>>> +++ b/drivers/gpu/drm/exynos/exynos5433_drm_decon.c >>>>> @@ -151,11 +151,13 @@ static void decon_commit(struct exynos_drm_crtc *crtc) >>>>> val = CMU_CLKGAGE_MODE_SFR_F | CMU_CLKGAGE_MODE_MEM_F; >>>>> writel(val, ctx->addr + DECON_CMU); >>>>> >>>>> + if (ctx->out_type & (IFTYPE_I80 | I80_HW_TRG)) >>>>> + decon_setup_trigger(ctx); >>>> Shouldn't it be configured in case of using SW trigger mode also? >>>> >>>> Thanks, >>>> Inki Dae >>>> >>>>> + >>>>> /* lcd on and use command if */ >>>>> val = VIDOUT_LCD_ON; >>>>> if (ctx->out_type & IFTYPE_I80) { >>>>> val |= VIDOUT_COMMAND_IF; >>>>> - decon_setup_trigger(ctx); >>>>> } else { >>>>> val |= VIDOUT_RGB_IF; >>>>> } >>>>> @@ -380,9 +382,6 @@ 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); >>>>> - >>>>> - if (ctx->out_type & IFTYPE_I80) >>>>> - decon_setup_trigger(ctx); >>>>> } >>>>> >>>>> static void decon_enable(struct exynos_drm_crtc *crtc) >>>>> @@ -652,9 +651,8 @@ static int exynos5433_decon_probe(struct platform_device *pdev) >>>>> >>>>> if (ctx->out_type & IFTYPE_HDMI) { >>>>> ctx->first_win = 1; >>>>> - ctx->out_type = IFTYPE_I80; >>>>> } else if (of_get_child_by_name(dev->of_node, "i80-if-timings")) { >>>>> - ctx->out_type = IFTYPE_I80; >>>>> + ctx->out_type |= IFTYPE_I80; >>> ctx->out_type was overwritten here with IFTYPE_I80. So when >>> decon_setup_trigger >>> were called I80_HW_TRG bit was always clear and DECON_TRIGCON was configured >>> to use soft trigger. >> Indeed. Then shouldn't decon_setup_trigger function be called in both cases - SW and HW trigger modes? >> Is there any reason to call the function only in case of HW trigger mode? > > With this patch function is called under following condition: >> + if (ctx->out_type & (IFTYPE_I80 | I80_HW_TRG)) >> + decon_setup_trigger(ctx); > > So it is called always in case of I80 mode, in such case value of I80_HW_TRG > determines if it should use sw or hw trigger. Ah, sorry. I misleaded above condition. Thanks, Inki Dae > > Regards > Andrzej > > >> >> Thanks, >> Inki Dae >> >>> Regards >>> Andrzej >>> >>>>> } >>>>> >>>>> for (i = 0; i < ARRAY_SIZE(decon_clks_name); i++) { >>>>> >>> > > _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/dri-devel