diff options
Diffstat (limited to 'drivers/gpu/drm/radeon/si.c')
| -rw-r--r-- | drivers/gpu/drm/radeon/si.c | 57 | 
1 files changed, 36 insertions, 21 deletions
diff --git a/drivers/gpu/drm/radeon/si.c b/drivers/gpu/drm/radeon/si.c index 53e313b0575..7c3e330c7b5 100644 --- a/drivers/gpu/drm/radeon/si.c +++ b/drivers/gpu/drm/radeon/si.c @@ -1765,18 +1765,31 @@ void si_ring_ib_execute(struct radeon_device *rdev, struct radeon_ib *ib)  	struct radeon_ring *ring = &rdev->ring[ib->ring];  	u32 header; -	if (ring->rptr_save_reg) { -		uint32_t next_rptr = ring->wptr + 3 + 4 + 8; -		radeon_ring_write(ring, PACKET3(PACKET3_SET_CONFIG_REG, 1)); -		radeon_ring_write(ring, ((ring->rptr_save_reg -  -					  PACKET3_SET_CONFIG_REG_START) >> 2)); -		radeon_ring_write(ring, next_rptr); -	} +	if (ib->is_const_ib) { +		/* set switch buffer packet before const IB */ +		radeon_ring_write(ring, PACKET3(PACKET3_SWITCH_BUFFER, 0)); +		radeon_ring_write(ring, 0); -	if (ib->is_const_ib)  		header = PACKET3(PACKET3_INDIRECT_BUFFER_CONST, 2); -	else +	} else { +		u32 next_rptr; +		if (ring->rptr_save_reg) { +			next_rptr = ring->wptr + 3 + 4 + 8; +			radeon_ring_write(ring, PACKET3(PACKET3_SET_CONFIG_REG, 1)); +			radeon_ring_write(ring, ((ring->rptr_save_reg - +						  PACKET3_SET_CONFIG_REG_START) >> 2)); +			radeon_ring_write(ring, next_rptr); +		} else if (rdev->wb.enabled) { +			next_rptr = ring->wptr + 5 + 4 + 8; +			radeon_ring_write(ring, PACKET3(PACKET3_WRITE_DATA, 3)); +			radeon_ring_write(ring, (1 << 8)); +			radeon_ring_write(ring, ring->next_rptr_gpu_addr & 0xfffffffc); +			radeon_ring_write(ring, upper_32_bits(ring->next_rptr_gpu_addr) & 0xffffffff); +			radeon_ring_write(ring, next_rptr); +		} +  		header = PACKET3(PACKET3_INDIRECT_BUFFER, 2); +	}  	radeon_ring_write(ring, header);  	radeon_ring_write(ring, @@ -1787,18 +1800,20 @@ void si_ring_ib_execute(struct radeon_device *rdev, struct radeon_ib *ib)  	radeon_ring_write(ring, upper_32_bits(ib->gpu_addr) & 0xFFFF);  	radeon_ring_write(ring, ib->length_dw | (ib->vm_id << 24)); -	/* flush read cache over gart for this vmid */ -	radeon_ring_write(ring, PACKET3(PACKET3_SET_CONFIG_REG, 1)); -	radeon_ring_write(ring, (CP_COHER_CNTL2 - PACKET3_SET_CONFIG_REG_START) >> 2); -	radeon_ring_write(ring, ib->vm_id); -	radeon_ring_write(ring, PACKET3(PACKET3_SURFACE_SYNC, 3)); -	radeon_ring_write(ring, PACKET3_TCL1_ACTION_ENA | -			  PACKET3_TC_ACTION_ENA | -			  PACKET3_SH_KCACHE_ACTION_ENA | -			  PACKET3_SH_ICACHE_ACTION_ENA); -	radeon_ring_write(ring, 0xFFFFFFFF); -	radeon_ring_write(ring, 0); -	radeon_ring_write(ring, 10); /* poll interval */ +	if (!ib->is_const_ib) { +		/* flush read cache over gart for this vmid */ +		radeon_ring_write(ring, PACKET3(PACKET3_SET_CONFIG_REG, 1)); +		radeon_ring_write(ring, (CP_COHER_CNTL2 - PACKET3_SET_CONFIG_REG_START) >> 2); +		radeon_ring_write(ring, ib->vm_id); +		radeon_ring_write(ring, PACKET3(PACKET3_SURFACE_SYNC, 3)); +		radeon_ring_write(ring, PACKET3_TCL1_ACTION_ENA | +				  PACKET3_TC_ACTION_ENA | +				  PACKET3_SH_KCACHE_ACTION_ENA | +				  PACKET3_SH_ICACHE_ACTION_ENA); +		radeon_ring_write(ring, 0xFFFFFFFF); +		radeon_ring_write(ring, 0); +		radeon_ring_write(ring, 10); /* poll interval */ +	}  }  /*  |