drm/amdgpu: add HEVC/H.265 UVD support
authorChristian König <christian.koenig@amd.com>
Tue, 5 May 2015 14:36:01 +0000 (16:36 +0200)
committerAlex Deucher <alexander.deucher@amd.com>
Thu, 4 Jun 2015 01:03:59 +0000 (21:03 -0400)
Signed-off-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_uvd.c

index 375759c..2f7a5ef 100644 (file)
@@ -460,6 +460,14 @@ static int amdgpu_uvd_cs_msg_decode(uint32_t *msg, unsigned buf_sizes[])
                min_dpb_size += ALIGN(width_in_mb * height_in_mb * 32, 64);
                break;
 
+       case 16: /* H265 */
+               image_size = (ALIGN(width, 16) * ALIGN(height, 16) * 3) / 2;
+               image_size = ALIGN(image_size, 256);
+
+               num_dpb_buffer = (le32_to_cpu(msg[59]) & 0xff) + 2;
+               min_dpb_size = image_size * num_dpb_buffer;
+               break;
+
        default:
                DRM_ERROR("UVD codec not handled %d!\n", stream_type);
                return -EINVAL;