diff options
author | Alex Deucher <alexander.deucher@amd.com> | 2012-07-17 14:02:31 -0400 |
---|---|---|
committer | Christian König <deathsimple@vodafone.de> | 2012-07-18 07:53:17 -0400 |
commit | 89d35807fb0fe53b84e88e759cc39107a6195e5f (patch) | |
tree | afb2e2cb9439239e6f83ad339ad624f42d012adc /drivers/gpu/drm/radeon/r600.c | |
parent | 8b25ed3482885e5f1dc65ace796e90f879d76c52 (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.c | 20 |
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) | |||
2576 | void r600_ring_ib_execute(struct radeon_device *rdev, struct radeon_ib *ib) | 2578 | void 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)); |