aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/amd/amdgpu/amdgpu_uvd.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_uvd.c')
-rw-r--r--drivers/gpu/drm/amd/amdgpu/amdgpu_uvd.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_uvd.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_uvd.c
index 375759c8639c..2f7a5efa21c2 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_uvd.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_uvd.c
@@ -460,6 +460,14 @@ static int amdgpu_uvd_cs_msg_decode(uint32_t *msg, unsigned buf_sizes[])
460 min_dpb_size += ALIGN(width_in_mb * height_in_mb * 32, 64); 460 min_dpb_size += ALIGN(width_in_mb * height_in_mb * 32, 64);
461 break; 461 break;
462 462
463 case 16: /* H265 */
464 image_size = (ALIGN(width, 16) * ALIGN(height, 16) * 3) / 2;
465 image_size = ALIGN(image_size, 256);
466
467 num_dpb_buffer = (le32_to_cpu(msg[59]) & 0xff) + 2;
468 min_dpb_size = image_size * num_dpb_buffer;
469 break;
470
463 default: 471 default:
464 DRM_ERROR("UVD codec not handled %d!\n", stream_type); 472 DRM_ERROR("UVD codec not handled %d!\n", stream_type);
465 return -EINVAL; 473 return -EINVAL;