[Intel-gfx] [PATCH 3/3] drm/i915: Only enable the plane after setting the fb base (pre-ILK)
Jesse Barnes
jbarnes at virtuousgeek.org
Tue Apr 19 22:39:49 CEST 2011
On Tue, 19 Apr 2011 21:32:03 +0100
Chris Wilson <chris at chris-wilson.co.uk> wrote:
> When enabling the plane, it is helpful to have already pointed that
> plane to valid memory or else we may incur the wrath of a PGTBL_ER.
> This code preserved the behaviour from the bad old days for unknown
> reasons...
>
> Found by assert_fb_bound_for_plane().
>
> References: https://bugs.freedesktop.org/show_bug.cgi?id=36246
> Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk>
> Cc: Daniel Vetter <daniel.vetter at ffwll.ch>
> Cc: Jesse Barnes <jbarnes at virtuousgeek.org>
> ---
> drivers/gpu/drm/i915/intel_display.c | 2 --
> 1 files changed, 0 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c
> index b9bb20d..f503ad0 100644
> --- a/drivers/gpu/drm/i915/intel_display.c
> +++ b/drivers/gpu/drm/i915/intel_display.c
> @@ -5212,8 +5212,6 @@ static int intel_crtc_mode_set(struct drm_crtc *crtc,
>
> I915_WRITE(DSPCNTR(plane), dspcntr);
> POSTING_READ(DSPCNTR(plane));
> - if (!HAS_PCH_SPLIT(dev))
> - intel_enable_plane(dev_priv, plane, pipe);
>
> ret = intel_pipe_set_base(crtc, x, y, old_fb);
>
As usual, changes like this frighten me. I think the plane enable
prior to the base set has been in there for a *long* time in various
forms. I think Carl tried to take it out when trying to debug eDP on
ILK, but we reverted that when it broke things.
But if it works on all your test machines, I guess that's a start; it's
correct in theory at least.
Reviewed-by: Jesse Barnes <jbarnes at virtuousgeek.org>
--
Jesse Barnes, Intel Open Source Technology Center
More information about the Intel-gfx
mailing list