diff options
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu.h | 1 | ||||
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_uvd.c | 28 | 
2 files changed, 27 insertions, 2 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu.h b/drivers/gpu/drm/amd/amdgpu/amdgpu.h index 9d1909f08d43..8ebc5f1eb4c0 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu.h +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu.h @@ -1681,6 +1681,7 @@ struct amdgpu_uvd {  	struct amdgpu_ring	ring;  	struct amdgpu_irq_src	irq;  	bool			address_64_bit; +	bool			use_ctx_buf;  	struct amd_sched_entity entity;  }; diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_uvd.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_uvd.c index 6c8d16559b00..b11f4e8868d7 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_uvd.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_uvd.c @@ -41,8 +41,15 @@  /* 1 second timeout */  #define UVD_IDLE_TIMEOUT	msecs_to_jiffies(1000) + +/* Firmware versions for VI */ +#define FW_1_65_10	((1 << 24) | (65 << 16) | (10 << 8)) +#define FW_1_87_11	((1 << 24) | (87 << 16) | (11 << 8)) +#define FW_1_87_12	((1 << 24) | (87 << 16) | (12 << 8)) +#define FW_1_37_15	((1 << 24) | (37 << 16) | (15 << 8)) +  /* Polaris10/11 firmware version */ -#define FW_1_66_16 ((1 << 24) | (66 << 16) | (16 << 8)) +#define FW_1_66_16	((1 << 24) | (66 << 16) | (16 << 8))  /* Firmware Names */  #ifdef CONFIG_DRM_AMDGPU_CIK @@ -245,6 +252,23 @@ int amdgpu_uvd_sw_init(struct amdgpu_device *adev)  	if (!amdgpu_ip_block_version_cmp(adev, AMD_IP_BLOCK_TYPE_UVD, 5, 0))  		adev->uvd.address_64_bit = true; +	switch (adev->asic_type) { +	case CHIP_TONGA: +		adev->uvd.use_ctx_buf = adev->uvd.fw_version >= FW_1_65_10; +		break; +	case CHIP_CARRIZO: +		adev->uvd.use_ctx_buf = adev->uvd.fw_version >= FW_1_87_11; +		break; +	case CHIP_FIJI: +		adev->uvd.use_ctx_buf = adev->uvd.fw_version >= FW_1_87_12; +		break; +	case CHIP_STONEY: +		adev->uvd.use_ctx_buf = adev->uvd.fw_version >= FW_1_37_15; +		break; +	default: +		adev->uvd.use_ctx_buf = adev->asic_type >= CHIP_POLARIS10; +	} +  	return 0;  } @@ -554,7 +578,7 @@ static int amdgpu_uvd_cs_msg_decode(struct amdgpu_device *adev, uint32_t *msg,  		/* reference picture buffer */  		min_dpb_size = image_size * num_dpb_buffer; -		if (adev->asic_type < CHIP_POLARIS10){ +		if (!adev->uvd.use_ctx_buf){  			/* macroblock context buffer */  			min_dpb_size +=  				width_in_mb * height_in_mb * num_dpb_buffer * 192; | 

