diff options
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c | 36 | 
1 files changed, 34 insertions, 2 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c index fa572b40989e..0dce4421418c 100644 --- a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c +++ b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c @@ -7437,6 +7437,38 @@ static void gfx_v9_0_ring_emit_cleaner_shader(struct amdgpu_ring *ring)  	amdgpu_ring_write(ring, 0);  /* RESERVED field, programmed to zero */  } +static void gfx_v9_0_ring_begin_use_compute(struct amdgpu_ring *ring) +{ +	struct amdgpu_device *adev = ring->adev; +	struct amdgpu_ip_block *gfx_block = +		amdgpu_device_ip_get_ip_block(adev, AMD_IP_BLOCK_TYPE_GFX); + +	amdgpu_gfx_enforce_isolation_ring_begin_use(ring); + +	/* Raven and PCO APUs seem to have stability issues +	 * with compute and gfxoff and gfx pg.  Disable gfx pg during +	 * submission and allow again afterwards. +	 */ +	if (gfx_block && amdgpu_ip_version(adev, GC_HWIP, 0) == IP_VERSION(9, 1, 0)) +		gfx_v9_0_set_powergating_state(gfx_block, AMD_PG_STATE_UNGATE); +} + +static void gfx_v9_0_ring_end_use_compute(struct amdgpu_ring *ring) +{ +	struct amdgpu_device *adev = ring->adev; +	struct amdgpu_ip_block *gfx_block = +		amdgpu_device_ip_get_ip_block(adev, AMD_IP_BLOCK_TYPE_GFX); + +	/* Raven and PCO APUs seem to have stability issues +	 * with compute and gfxoff and gfx pg.  Disable gfx pg during +	 * submission and allow again afterwards. +	 */ +	if (gfx_block && amdgpu_ip_version(adev, GC_HWIP, 0) == IP_VERSION(9, 1, 0)) +		gfx_v9_0_set_powergating_state(gfx_block, AMD_PG_STATE_GATE); + +	amdgpu_gfx_enforce_isolation_ring_end_use(ring); +} +  static const struct amd_ip_funcs gfx_v9_0_ip_funcs = {  	.name = "gfx_v9_0",  	.early_init = gfx_v9_0_early_init, @@ -7613,8 +7645,8 @@ static const struct amdgpu_ring_funcs gfx_v9_0_ring_funcs_compute = {  	.emit_wave_limit = gfx_v9_0_emit_wave_limit,  	.reset = gfx_v9_0_reset_kcq,  	.emit_cleaner_shader = gfx_v9_0_ring_emit_cleaner_shader, -	.begin_use = amdgpu_gfx_enforce_isolation_ring_begin_use, -	.end_use = amdgpu_gfx_enforce_isolation_ring_end_use, +	.begin_use = gfx_v9_0_ring_begin_use_compute, +	.end_use = gfx_v9_0_ring_end_use_compute,  };  static const struct amdgpu_ring_funcs gfx_v9_0_ring_funcs_kiq = { | 
