On 05.01.2017 11:05, Inki Dae wrote: > > 2017년 01월 02일 17:39에 Andrzej Hajda 이(가) 쓴 글: >> In case of HW trigger mode, sysreg register should be configured to >> enable TE functionality. The patch refactors also trigger setup function. >> >> Signed-off-by: Andrzej Hajda <a.hajda@xxxxxxxxxxx> >> --- >> v2: fixed bitop operator (thanks Ilia) >> --- >> drivers/gpu/drm/exynos/exynos5433_drm_decon.c | 40 +++++++++++++++++++++------ >> 1 file changed, 32 insertions(+), 8 deletions(-) >> >> diff --git a/drivers/gpu/drm/exynos/exynos5433_drm_decon.c b/drivers/gpu/drm/exynos/exynos5433_drm_decon.c >> index 6ca1f31..b63b8e6 100644 >> --- a/drivers/gpu/drm/exynos/exynos5433_drm_decon.c >> +++ b/drivers/gpu/drm/exynos/exynos5433_drm_decon.c >> @@ -13,9 +13,11 @@ >> #include <linux/platform_device.h> >> #include <linux/clk.h> >> #include <linux/component.h> >> +#include <linux/mfd/syscon.h> >> #include <linux/of_device.h> >> #include <linux/of_gpio.h> >> #include <linux/pm_runtime.h> >> +#include <linux/regmap.h> >> >> #include <video/exynos5433_decon.h> >> >> @@ -25,6 +27,9 @@ >> #include "exynos_drm_plane.h" >> #include "exynos_drm_iommu.h" >> >> +#define DSD_CFG_MUX 0x1004 >> +#define DSD_CFG_MUX_TE_UNMASK_GLOBAL BIT(13) >> + >> #define WINDOWS_NR 3 >> #define MIN_FB_WIDTH_FOR_16WORD_BURST 128 >> >> @@ -56,6 +61,7 @@ struct decon_context { >> struct exynos_drm_plane planes[WINDOWS_NR]; >> struct exynos_drm_plane_config configs[WINDOWS_NR]; >> void __iomem *addr; >> + struct regmap *sysreg; >> struct clk *clks[ARRAY_SIZE(decon_clks_name)]; >> int pipe; >> unsigned long flags; >> @@ -117,12 +123,22 @@ static void decon_disable_vblank(struct exynos_drm_crtc *crtc) >> >> static void decon_setup_trigger(struct decon_context *ctx) >> { >> - 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 | >> - TRIGCON_HWTRIGMASK | TRIGCON_HWTRIGEN; >> - writel(val, ctx->addr + DECON_TRIGCON); >> + if (!(ctx->out_type & (IFTYPE_I80 | I80_HW_TRG))) >> + return; >> + >> + if (!(ctx->out_type & I80_HW_TRG)) { >> + writel(TRIGCON_TE_AUTO_MASK | TRIGCON_SWTRIGEN >> + | TRIGCON_TE_AUTO_MASK | TRIGCON_SWTRIGEN, >> + ctx->addr + DECON_TRIGCON); >> + return; >> + } >> + >> + writel(TRIGCON_TRIGEN_PER_F | TRIGCON_TRIGEN_F | TRIGCON_HWTRIGMASK >> + | TRIGCON_HWTRIGEN, ctx->addr + DECON_TRIGCON); >> + >> + if (regmap_update_bits(ctx->sysreg, DSD_CFG_MUX, >> + DSD_CFG_MUX_TE_UNMASK_GLOBAL, ~0)) >> + DRM_ERROR("Cannot update sysreg.\n"); >> } >> >> static void decon_commit(struct exynos_drm_crtc *crtc) >> @@ -147,8 +163,7 @@ 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); >> + decon_setup_trigger(ctx); > Calling this function in video mode is unnecessary. Why did you remove above condition? I have moved the condition to decon_setup_trigger. Regards Andrzej > >> >> /* lcd on and use command if */ >> val = VIDOUT_LCD_ON; >> @@ -640,6 +655,15 @@ static int exynos5433_decon_probe(struct platform_device *pdev) >> ctx->out_type |= IFTYPE_I80; >> } >> >> + if (ctx->out_type & I80_HW_TRG) { >> + ctx->sysreg = syscon_regmap_lookup_by_phandle(dev->of_node, >> + "samsung,disp-sysreg"); >> + if (IS_ERR(ctx->sysreg)) { >> + dev_err(dev, "failed to get system register\n"); >> + return PTR_ERR(ctx->sysreg); >> + } >> + } >> + >> for (i = 0; i < ARRAY_SIZE(decon_clks_name); i++) { >> struct clk *clk; >> >> > _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/dri-devel