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

Commit 91ec5d11 authored by Ben Widawsky's avatar Ben Widawsky Committed by Daniel Vetter
Browse files

drm/i915: Add some more registers to error state



Chris:
Do we also want to capture?
  GAC_ECO_BITS /* gen6,7 */
  GAM_ECOCHK /* gen6,7 */
  GAB_CTL /* gen6 */
  GFX_MODE /* gen6 */

Requested-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: default avatarBen Widawsky <ben@bwidawsk.net>
Reviewed-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
parent 362b8af7
Loading
Loading
Loading
Loading
+4 −0
Original line number Original line Diff line number Diff line
@@ -307,6 +307,10 @@ struct drm_i915_error_state {
	u32 error; /* gen6+ */
	u32 error; /* gen6+ */
	u32 err_int; /* gen7 */
	u32 err_int; /* gen7 */
	u32 done_reg;
	u32 done_reg;
	u32 gac_eco;
	u32 gam_ecochk;
	u32 gab_ctl;
	u32 gfx_mode;
	u32 extra_instdone[I915_NUM_INSTDONE_REG];
	u32 extra_instdone[I915_NUM_INSTDONE_REG];
	u32 pipestat[I915_MAX_PIPES];
	u32 pipestat[I915_MAX_PIPES];
	u64 fence[I915_MAX_NUM_FENCES];
	u64 fence[I915_MAX_NUM_FENCES];
+10 −1
Original line number Original line Diff line number Diff line
@@ -1001,8 +1001,11 @@ static void i915_capture_reg_state(struct drm_i915_private *dev_priv,
	if (IS_GEN7(dev))
	if (IS_GEN7(dev))
		error->err_int = I915_READ(GEN7_ERR_INT);
		error->err_int = I915_READ(GEN7_ERR_INT);


	if (IS_GEN6(dev))
	if (IS_GEN6(dev)) {
		error->forcewake = I915_READ(FORCEWAKE);
		error->forcewake = I915_READ(FORCEWAKE);
		error->gab_ctl = I915_READ(GAB_CTL);
		error->gfx_mode = I915_READ(GFX_MODE);
	}


	if (IS_GEN2(dev))
	if (IS_GEN2(dev))
		error->ier = I915_READ16(IER);
		error->ier = I915_READ16(IER);
@@ -1018,6 +1021,12 @@ static void i915_capture_reg_state(struct drm_i915_private *dev_priv,
	}
	}


	/* 3: Feature specific registers */
	/* 3: Feature specific registers */
	if (IS_GEN6(dev) || IS_GEN7(dev)) {
		error->gam_ecochk = I915_READ(GAM_ECOCHK);
		error->gac_eco = I915_READ(GAC_ECO_BITS);
	}

	/* 4: Everything else */
	if (HAS_HW_CONTEXTS(dev))
	if (HAS_HW_CONTEXTS(dev))
		error->ccid = I915_READ(CCID);
		error->ccid = I915_READ(CCID);