mirror of https://gitee.com/openkylin/linux.git
drm/radeon: Make r100_cp_ring_info() and radeon_ring_gfx() safe (v2)
Prevent NULL pointer dereference in case when radeon_ring_fini() did it's job. Reading of r100_cp_ring_info and radeon_ring_gfx debugfs entries will lead to a KP if ring buffer was deallocated, e.g. on failed ring test. Seen on PA-RISC machine having "radeon: ring test failed (scratch(0x8504)=0xCAFEDEAD)" issue. v2: agd5f: add some parens around ring->ready check Signed-off-by: Alex Ivanov <gnidorah@p0n4ik.tk> Signed-off-by: Alex Deucher <alexander.deucher@amd.com> Cc: stable@vger.kernel.org
This commit is contained in:
parent
42baf21d91
commit
0eb3448aa6
|
@ -2933,9 +2933,11 @@ static int r100_debugfs_cp_ring_info(struct seq_file *m, void *data)
|
||||||
seq_printf(m, "CP_RB_RPTR 0x%08x\n", rdp);
|
seq_printf(m, "CP_RB_RPTR 0x%08x\n", rdp);
|
||||||
seq_printf(m, "%u free dwords in ring\n", ring->ring_free_dw);
|
seq_printf(m, "%u free dwords in ring\n", ring->ring_free_dw);
|
||||||
seq_printf(m, "%u dwords in ring\n", count);
|
seq_printf(m, "%u dwords in ring\n", count);
|
||||||
for (j = 0; j <= count; j++) {
|
if (ring->ready) {
|
||||||
i = (rdp + j) & ring->ptr_mask;
|
for (j = 0; j <= count; j++) {
|
||||||
seq_printf(m, "r[%04d]=0x%08x\n", i, ring->ring[i]);
|
i = (rdp + j) & ring->ptr_mask;
|
||||||
|
seq_printf(m, "r[%04d]=0x%08x\n", i, ring->ring[i]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -839,9 +839,11 @@ static int radeon_debugfs_ring_info(struct seq_file *m, void *data)
|
||||||
* packet that is the root issue
|
* packet that is the root issue
|
||||||
*/
|
*/
|
||||||
i = (ring->rptr + ring->ptr_mask + 1 - 32) & ring->ptr_mask;
|
i = (ring->rptr + ring->ptr_mask + 1 - 32) & ring->ptr_mask;
|
||||||
for (j = 0; j <= (count + 32); j++) {
|
if (ring->ready) {
|
||||||
seq_printf(m, "r[%5d]=0x%08x\n", i, ring->ring[i]);
|
for (j = 0; j <= (count + 32); j++) {
|
||||||
i = (i + 1) & ring->ptr_mask;
|
seq_printf(m, "r[%5d]=0x%08x\n", i, ring->ring[i]);
|
||||||
|
i = (i + 1) & ring->ptr_mask;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue