diff options
author | Ville Syrjälä <ville.syrjala@linux.intel.com> | 2013-12-10 14:44:43 -0500 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2013-12-11 17:52:12 -0500 |
commit | 3dda20a974e013a4985560904c0e491a70a25251 (patch) | |
tree | 1fcb8a2dc3a5aa3ab5782e917ef4ac0f3eca761b | |
parent | 0476190e107f398cfe0b50101bee4f8bd8e0fe30 (diff) |
drm/i915: Record BB_ADDR for every ring
Every ring seems to have a BB_ADDR registers, so include them all in the
error state.
v2: Also include the _UDW on BDW
Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Reviewed-by: Ben Widawsky <ben@bwidawsk.net>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
-rw-r--r-- | drivers/gpu/drm/i915/i915_drv.h | 2 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/i915_gpu_error.c | 12 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/i915_reg.h | 3 |
3 files changed, 9 insertions, 8 deletions
diff --git a/drivers/gpu/drm/i915/i915_drv.h b/drivers/gpu/drm/i915/i915_drv.h index 98fd1c043777..a3804b29ef90 100644 --- a/drivers/gpu/drm/i915/i915_drv.h +++ b/drivers/gpu/drm/i915/i915_drv.h | |||
@@ -323,7 +323,7 @@ struct drm_i915_error_state { | |||
323 | u32 instps[I915_NUM_RINGS]; | 323 | u32 instps[I915_NUM_RINGS]; |
324 | u32 extra_instdone[I915_NUM_INSTDONE_REG]; | 324 | u32 extra_instdone[I915_NUM_INSTDONE_REG]; |
325 | u32 seqno[I915_NUM_RINGS]; | 325 | u32 seqno[I915_NUM_RINGS]; |
326 | u64 bbaddr; | 326 | u64 bbaddr[I915_NUM_RINGS]; |
327 | u32 fault_reg[I915_NUM_RINGS]; | 327 | u32 fault_reg[I915_NUM_RINGS]; |
328 | u32 done_reg; | 328 | u32 done_reg; |
329 | u32 faddr[I915_NUM_RINGS]; | 329 | u32 faddr[I915_NUM_RINGS]; |
diff --git a/drivers/gpu/drm/i915/i915_gpu_error.c b/drivers/gpu/drm/i915/i915_gpu_error.c index 9a642921182b..a707cca692e4 100644 --- a/drivers/gpu/drm/i915/i915_gpu_error.c +++ b/drivers/gpu/drm/i915/i915_gpu_error.c | |||
@@ -247,12 +247,11 @@ static void i915_ring_error_state(struct drm_i915_error_state_buf *m, | |||
247 | err_printf(m, " IPEIR: 0x%08x\n", error->ipeir[ring]); | 247 | err_printf(m, " IPEIR: 0x%08x\n", error->ipeir[ring]); |
248 | err_printf(m, " IPEHR: 0x%08x\n", error->ipehr[ring]); | 248 | err_printf(m, " IPEHR: 0x%08x\n", error->ipehr[ring]); |
249 | err_printf(m, " INSTDONE: 0x%08x\n", error->instdone[ring]); | 249 | err_printf(m, " INSTDONE: 0x%08x\n", error->instdone[ring]); |
250 | if (ring == RCS && INTEL_INFO(dev)->gen >= 4) | 250 | if (INTEL_INFO(dev)->gen >= 4) { |
251 | err_printf(m, " BBADDR: 0x%08llx\n", error->bbaddr); | 251 | err_printf(m, " BBADDR: 0x%08llx\n", error->bbaddr[ring]); |
252 | if (INTEL_INFO(dev)->gen >= 4) | ||
253 | err_printf(m, " BB_STATE: 0x%08x\n", error->bbstate[ring]); | 252 | err_printf(m, " BB_STATE: 0x%08x\n", error->bbstate[ring]); |
254 | if (INTEL_INFO(dev)->gen >= 4) | ||
255 | err_printf(m, " INSTPS: 0x%08x\n", error->instps[ring]); | 253 | err_printf(m, " INSTPS: 0x%08x\n", error->instps[ring]); |
254 | } | ||
256 | err_printf(m, " INSTPM: 0x%08x\n", error->instpm[ring]); | 255 | err_printf(m, " INSTPM: 0x%08x\n", error->instpm[ring]); |
257 | err_printf(m, " FADDR: 0x%08x\n", error->faddr[ring]); | 256 | err_printf(m, " FADDR: 0x%08x\n", error->faddr[ring]); |
258 | if (INTEL_INFO(dev)->gen >= 6) { | 257 | if (INTEL_INFO(dev)->gen >= 6) { |
@@ -725,8 +724,9 @@ static void i915_record_ring_state(struct drm_device *dev, | |||
725 | error->ipehr[ring->id] = I915_READ(RING_IPEHR(ring->mmio_base)); | 724 | error->ipehr[ring->id] = I915_READ(RING_IPEHR(ring->mmio_base)); |
726 | error->instdone[ring->id] = I915_READ(RING_INSTDONE(ring->mmio_base)); | 725 | error->instdone[ring->id] = I915_READ(RING_INSTDONE(ring->mmio_base)); |
727 | error->instps[ring->id] = I915_READ(RING_INSTPS(ring->mmio_base)); | 726 | error->instps[ring->id] = I915_READ(RING_INSTPS(ring->mmio_base)); |
728 | if (ring->id == RCS) | 727 | error->bbaddr[ring->id] = I915_READ(RING_BBADDR(ring->mmio_base)); |
729 | error->bbaddr = I915_READ(BB_ADDR); | 728 | if (INTEL_INFO(dev)->gen >= 8) |
729 | error->bbaddr[ring->id] |= (u64) I915_READ(RING_BBADDR_UDW(ring->mmio_base)) << 32; | ||
730 | error->bbstate[ring->id] = I915_READ(RING_BBSTATE(ring->mmio_base)); | 730 | error->bbstate[ring->id] = I915_READ(RING_BBSTATE(ring->mmio_base)); |
731 | } else { | 731 | } else { |
732 | error->faddr[ring->id] = I915_READ(DMA_FADD_I8XX); | 732 | error->faddr[ring->id] = I915_READ(DMA_FADD_I8XX); |
diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h index 2d203905bd70..8828ee4eabec 100644 --- a/drivers/gpu/drm/i915/i915_reg.h +++ b/drivers/gpu/drm/i915/i915_reg.h | |||
@@ -734,6 +734,8 @@ | |||
734 | #define HWSTAM 0x02098 | 734 | #define HWSTAM 0x02098 |
735 | #define DMA_FADD_I8XX 0x020d0 | 735 | #define DMA_FADD_I8XX 0x020d0 |
736 | #define RING_BBSTATE(base) ((base)+0x110) | 736 | #define RING_BBSTATE(base) ((base)+0x110) |
737 | #define RING_BBADDR(base) ((base)+0x140) | ||
738 | #define RING_BBADDR_UDW(base) ((base)+0x168) /* gen8+ */ | ||
737 | 739 | ||
738 | #define ERROR_GEN6 0x040a0 | 740 | #define ERROR_GEN6 0x040a0 |
739 | #define GEN7_ERR_INT 0x44040 | 741 | #define GEN7_ERR_INT 0x44040 |
@@ -924,7 +926,6 @@ | |||
924 | #define CM0_COLOR_EVICT_DISABLE (1<<3) | 926 | #define CM0_COLOR_EVICT_DISABLE (1<<3) |
925 | #define CM0_DEPTH_WRITE_DISABLE (1<<1) | 927 | #define CM0_DEPTH_WRITE_DISABLE (1<<1) |
926 | #define CM0_RC_OP_FLUSH_DISABLE (1<<0) | 928 | #define CM0_RC_OP_FLUSH_DISABLE (1<<0) |
927 | #define BB_ADDR 0x02140 /* 8 bytes */ | ||
928 | #define GFX_FLSH_CNTL 0x02170 /* 915+ only */ | 929 | #define GFX_FLSH_CNTL 0x02170 /* 915+ only */ |
929 | #define GFX_FLSH_CNTL_GEN6 0x101008 | 930 | #define GFX_FLSH_CNTL_GEN6 0x101008 |
930 | #define GFX_FLSH_CNTL_EN (1<<0) | 931 | #define GFX_FLSH_CNTL_EN (1<<0) |