Skip to content

Commit 9d2f41f

Browse files
committed
drm/i915: dump the DMA fetch addr register on pre-gen6
It exists way back to gen2, bug got moved around on gen4 a bit. Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Signed-Off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
1 parent a0b1c7a commit 9d2f41f

File tree

3 files changed

+4
-2
lines changed

3 files changed

+4
-2
lines changed

drivers/gpu/drm/i915/i915_debugfs.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -757,8 +757,8 @@ static void i915_ring_error_state(struct seq_file *m,
757757
if (INTEL_INFO(dev)->gen >= 4)
758758
seq_printf(m, " INSTPS: 0x%08x\n", error->instps[ring]);
759759
seq_printf(m, " INSTPM: 0x%08x\n", error->instpm[ring]);
760+
seq_printf(m, " FADDR: 0x%08x\n", error->faddr[ring]);
760761
if (INTEL_INFO(dev)->gen >= 6) {
761-
seq_printf(m, " FADDR: 0x%08x\n", error->faddr[ring]);
762762
seq_printf(m, " FAULT_REG: 0x%08x\n", error->fault_reg[ring]);
763763
seq_printf(m, " SYNC_0: 0x%08x\n",
764764
error->semaphore_mboxes[ring][0]);

drivers/gpu/drm/i915/i915_irq.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1029,7 +1029,6 @@ static void i915_record_ring_state(struct drm_device *dev,
10291029
struct drm_i915_private *dev_priv = dev->dev_private;
10301030

10311031
if (INTEL_INFO(dev)->gen >= 6) {
1032-
error->faddr[ring->id] = I915_READ(RING_DMA_FADD(ring->mmio_base));
10331032
error->fault_reg[ring->id] = I915_READ(RING_FAULT_REG(ring));
10341033
error->semaphore_mboxes[ring->id][0]
10351034
= I915_READ(RING_SYNC_0(ring->mmio_base));
@@ -1038,6 +1037,7 @@ static void i915_record_ring_state(struct drm_device *dev,
10381037
}
10391038

10401039
if (INTEL_INFO(dev)->gen >= 4) {
1040+
error->faddr[ring->id] = I915_READ(RING_DMA_FADD(ring->mmio_base));
10411041
error->ipeir[ring->id] = I915_READ(RING_IPEIR(ring->mmio_base));
10421042
error->ipehr[ring->id] = I915_READ(RING_IPEHR(ring->mmio_base));
10431043
error->instdone[ring->id] = I915_READ(RING_INSTDONE(ring->mmio_base));
@@ -1047,6 +1047,7 @@ static void i915_record_ring_state(struct drm_device *dev,
10471047
error->bbaddr = I915_READ64(BB_ADDR);
10481048
}
10491049
} else {
1050+
error->faddr[ring->id] = I915_READ(DMA_FADD_I8XX);
10501051
error->ipeir[ring->id] = I915_READ(IPEIR);
10511052
error->ipehr[ring->id] = I915_READ(IPEHR);
10521053
error->instdone[ring->id] = I915_READ(INSTDONE);

drivers/gpu/drm/i915/i915_reg.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -474,6 +474,7 @@
474474
#define INSTDONE 0x02090
475475
#define NOPID 0x02094
476476
#define HWSTAM 0x02098
477+
#define DMA_FADD_I8XX 0x020d0
477478

478479
#define ERROR_GEN6 0x040a0
479480

0 commit comments

Comments
 (0)