Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit eb8a3bf7 authored by Marek Szyprowski's avatar Marek Szyprowski Committed by Inki Dae
Browse files

drm/exynos: fimd: fix window clear code



To correctly disable hardware window during driver init, both enable bits
(WINCONx_ENWIN in WINCON and SHADOWCON_CHx_ENABLE in SHADOWCON) must be
cleared, otherwise hardware fails to re-enable such window later.

While touching this function, also temporarily disable ctx->suspended flag
to let fimd_wait_for_vblank function really to do its job.

Signed-off-by: default avatarMarek Szyprowski <m.szyprowski@samsung.com>
Signed-off-by: default avatarInki Dae <inki.dae@samsung.com>
parent 71b1f195
Loading
Loading
Loading
Loading
+19 −6
Original line number Original line Diff line number Diff line
@@ -214,7 +214,6 @@ static void fimd_wait_for_vblank(struct exynos_drm_manager *mgr)
		DRM_DEBUG_KMS("vblank wait timed out.\n");
		DRM_DEBUG_KMS("vblank wait timed out.\n");
}
}



static void fimd_clear_channel(struct exynos_drm_manager *mgr)
static void fimd_clear_channel(struct exynos_drm_manager *mgr)
{
{
	struct fimd_context *ctx = mgr->ctx;
	struct fimd_context *ctx = mgr->ctx;
@@ -224,17 +223,31 @@ static void fimd_clear_channel(struct exynos_drm_manager *mgr)


	/* Check if any channel is enabled. */
	/* Check if any channel is enabled. */
	for (win = 0; win < WINDOWS_NR; win++) {
	for (win = 0; win < WINDOWS_NR; win++) {
		u32 val = readl(ctx->regs + SHADOWCON);
		u32 val = readl(ctx->regs + WINCON(win));
		if (val & SHADOWCON_CHx_ENABLE(win)) {

		if (val & WINCONx_ENWIN) {
			/* wincon */
			val &= ~WINCONx_ENWIN;
			writel(val, ctx->regs + WINCON(win));

			/* unprotect windows */
			if (ctx->driver_data->has_shadowcon) {
				val = readl(ctx->regs + SHADOWCON);
				val &= ~SHADOWCON_CHx_ENABLE(win);
				val &= ~SHADOWCON_CHx_ENABLE(win);
				writel(val, ctx->regs + SHADOWCON);
				writel(val, ctx->regs + SHADOWCON);
			}
			ch_enabled = 1;
			ch_enabled = 1;
		}
		}
	}
	}


	/* Wait for vsync, as disable channel takes effect at next vsync */
	/* Wait for vsync, as disable channel takes effect at next vsync */
	if (ch_enabled)
	if (ch_enabled) {
		unsigned int state = ctx->suspended;

		ctx->suspended = 0;
		fimd_wait_for_vblank(mgr);
		fimd_wait_for_vblank(mgr);
		ctx->suspended = state;
	}
}
}


static int fimd_mgr_initialize(struct exynos_drm_manager *mgr,
static int fimd_mgr_initialize(struct exynos_drm_manager *mgr,