aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/radeon/r600.c
diff options
context:
space:
mode:
authorAlex Deucher <alexander.deucher@amd.com>2012-07-17 14:02:31 -0400
committerChristian König <deathsimple@vodafone.de>2012-07-18 07:53:17 -0400
commit89d35807fb0fe53b84e88e759cc39107a6195e5f (patch)
treeafb2e2cb9439239e6f83ad339ad624f42d012adc /drivers/gpu/drm/radeon/r600.c
parent8b25ed3482885e5f1dc65ace796e90f879d76c52 (diff)
drm/radeon: update rptr saving logic for memory buffers
Add support for using memory buffers rather than scratch registers. Some rings may not be able to write to scratch registers. Signed-off-by: Alex Deucher <alexander.deucher@amd.com> Reviewed-by: Christian König <christian.koenig@amd.com>
Diffstat (limited to 'drivers/gpu/drm/radeon/r600.c')
-rw-r--r--drivers/gpu/drm/radeon/r600.c20
1 files changed, 15 insertions, 5 deletions
diff --git a/drivers/gpu/drm/radeon/r600.c b/drivers/gpu/drm/radeon/r600.c
index 9f24a804f6e..c5b2e906936 100644
--- a/drivers/gpu/drm/radeon/r600.c
+++ b/drivers/gpu/drm/radeon/r600.c
@@ -2163,10 +2163,12 @@ void r600_ring_init(struct radeon_device *rdev, struct radeon_ring *ring, unsign
2163 ring->ring_size = ring_size; 2163 ring->ring_size = ring_size;
2164 ring->align_mask = 16 - 1; 2164 ring->align_mask = 16 - 1;
2165 2165
2166 r = radeon_scratch_get(rdev, &ring->rptr_save_reg); 2166 if (radeon_ring_supports_scratch_reg(rdev, ring)) {
2167 if (r) { 2167 r = radeon_scratch_get(rdev, &ring->rptr_save_reg);
2168 DRM_ERROR("failed to get scratch reg for rptr save (%d).\n", r); 2168 if (r) {
2169 ring->rptr_save_reg = 0; 2169 DRM_ERROR("failed to get scratch reg for rptr save (%d).\n", r);
2170 ring->rptr_save_reg = 0;
2171 }
2170 } 2172 }
2171} 2173}
2172 2174
@@ -2576,13 +2578,21 @@ void r600_fini(struct radeon_device *rdev)
2576void r600_ring_ib_execute(struct radeon_device *rdev, struct radeon_ib *ib) 2578void r600_ring_ib_execute(struct radeon_device *rdev, struct radeon_ib *ib)
2577{ 2579{
2578 struct radeon_ring *ring = &rdev->ring[ib->ring]; 2580 struct radeon_ring *ring = &rdev->ring[ib->ring];
2581 u32 next_rptr;
2579 2582
2580 if (ring->rptr_save_reg) { 2583 if (ring->rptr_save_reg) {
2581 uint32_t next_rptr = ring->wptr + 3 + 4; 2584 next_rptr = ring->wptr + 3 + 4;
2582 radeon_ring_write(ring, PACKET3(PACKET3_SET_CONFIG_REG, 1)); 2585 radeon_ring_write(ring, PACKET3(PACKET3_SET_CONFIG_REG, 1));
2583 radeon_ring_write(ring, ((ring->rptr_save_reg - 2586 radeon_ring_write(ring, ((ring->rptr_save_reg -
2584 PACKET3_SET_CONFIG_REG_OFFSET) >> 2)); 2587 PACKET3_SET_CONFIG_REG_OFFSET) >> 2));
2585 radeon_ring_write(ring, next_rptr); 2588 radeon_ring_write(ring, next_rptr);
2589 } else if (rdev->wb.enabled) {
2590 next_rptr = ring->wptr + 5 + 4;
2591 radeon_ring_write(ring, PACKET3(PACKET3_MEM_WRITE, 3));
2592 radeon_ring_write(ring, ring->next_rptr_gpu_addr & 0xfffffffc);
2593 radeon_ring_write(ring, (upper_32_bits(ring->next_rptr_gpu_addr) & 0xff) | (1 << 18));
2594 radeon_ring_write(ring, next_rptr);
2595 radeon_ring_write(ring, 0);
2586 } 2596 }
2587 2597
2588 radeon_ring_write(ring, PACKET3(PACKET3_INDIRECT_BUFFER, 2)); 2598 radeon_ring_write(ring, PACKET3(PACKET3_INDIRECT_BUFFER, 2));