aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVille Syrjälä <ville.syrjala@linux.intel.com>2013-12-10 14:44:43 -0500
committerDaniel Vetter <daniel.vetter@ffwll.ch>2013-12-11 17:52:12 -0500
commit3dda20a974e013a4985560904c0e491a70a25251 (patch)
tree1fcb8a2dc3a5aa3ab5782e917ef4ac0f3eca761b
parent0476190e107f398cfe0b50101bee4f8bd8e0fe30 (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.h2
-rw-r--r--drivers/gpu/drm/i915/i915_gpu_error.c12
-rw-r--r--drivers/gpu/drm/i915/i915_reg.h3
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)