diff options
author | Christian König <christian.koenig@amd.com> | 2013-11-12 06:58:05 -0500 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2013-11-15 15:56:09 -0500 |
commit | 1654b817d8f5f1c27ebc98773fe0e517b0ba2f1e (patch) | |
tree | b12139b37c3d712973baabfd5f8142728e36ef2a /drivers/gpu/drm/radeon/cik.c | |
parent | bd80c8ba995c1dbdddee14acc55c541c499e0442 (diff) |
drm/radeon: allow semaphore emission to fail
To workaround bugs and/or certain limits it's sometimes
useful to fall back to waiting on fences.
Signed-off-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Cc: stable@vger.kernel.org
Diffstat (limited to 'drivers/gpu/drm/radeon/cik.c')
-rw-r--r-- | drivers/gpu/drm/radeon/cik.c | 13 |
1 files changed, 5 insertions, 8 deletions
diff --git a/drivers/gpu/drm/radeon/cik.c b/drivers/gpu/drm/radeon/cik.c index ae92aa041c6a..811fc1b5b4b9 100644 --- a/drivers/gpu/drm/radeon/cik.c +++ b/drivers/gpu/drm/radeon/cik.c | |||
@@ -3556,7 +3556,7 @@ void cik_fence_compute_ring_emit(struct radeon_device *rdev, | |||
3556 | radeon_ring_write(ring, 0); | 3556 | radeon_ring_write(ring, 0); |
3557 | } | 3557 | } |
3558 | 3558 | ||
3559 | void cik_semaphore_ring_emit(struct radeon_device *rdev, | 3559 | bool cik_semaphore_ring_emit(struct radeon_device *rdev, |
3560 | struct radeon_ring *ring, | 3560 | struct radeon_ring *ring, |
3561 | struct radeon_semaphore *semaphore, | 3561 | struct radeon_semaphore *semaphore, |
3562 | bool emit_wait) | 3562 | bool emit_wait) |
@@ -3567,6 +3567,8 @@ void cik_semaphore_ring_emit(struct radeon_device *rdev, | |||
3567 | radeon_ring_write(ring, PACKET3(PACKET3_MEM_SEMAPHORE, 1)); | 3567 | radeon_ring_write(ring, PACKET3(PACKET3_MEM_SEMAPHORE, 1)); |
3568 | radeon_ring_write(ring, addr & 0xffffffff); | 3568 | radeon_ring_write(ring, addr & 0xffffffff); |
3569 | radeon_ring_write(ring, (upper_32_bits(addr) & 0xffff) | sel); | 3569 | radeon_ring_write(ring, (upper_32_bits(addr) & 0xffff) | sel); |
3570 | |||
3571 | return true; | ||
3570 | } | 3572 | } |
3571 | 3573 | ||
3572 | /** | 3574 | /** |
@@ -3609,13 +3611,8 @@ int cik_copy_cpdma(struct radeon_device *rdev, | |||
3609 | return r; | 3611 | return r; |
3610 | } | 3612 | } |
3611 | 3613 | ||
3612 | if (radeon_fence_need_sync(*fence, ring->idx)) { | 3614 | radeon_semaphore_sync_to(sem, *fence); |
3613 | radeon_semaphore_sync_rings(rdev, sem, (*fence)->ring, | 3615 | radeon_semaphore_sync_rings(rdev, sem, ring->idx); |
3614 | ring->idx); | ||
3615 | radeon_fence_note_sync(*fence, ring->idx); | ||
3616 | } else { | ||
3617 | radeon_semaphore_free(rdev, &sem, NULL); | ||
3618 | } | ||
3619 | 3616 | ||
3620 | for (i = 0; i < num_loops; i++) { | 3617 | for (i = 0; i < num_loops; i++) { |
3621 | cur_size_in_bytes = size_in_bytes; | 3618 | cur_size_in_bytes = size_in_bytes; |