Commit cbec6477 authored by Stylon Wang's avatar Stylon Wang Committed by Alex Deucher

drm/amd/display: Support P010 pixel format

[Why]
P010 pixel format is not declared as supported in DRM and DM.

[How]
Add P010 format to the support list presented to DRM and checked in DM
Signed-off-by: default avatarStylon Wang <stylon.wang@amd.com>
Reviewed-by: default avatarNicholas Kazlauskas <Nicholas.Kazlauskas@amd.com>
Acked-by: default avatarRodrigo Siqueira <Rodrigo.Siqueira@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 33eef72f
...@@ -3639,6 +3639,9 @@ fill_dc_plane_info_and_addr(struct amdgpu_device *adev, ...@@ -3639,6 +3639,9 @@ fill_dc_plane_info_and_addr(struct amdgpu_device *adev,
case DRM_FORMAT_NV12: case DRM_FORMAT_NV12:
plane_info->format = SURFACE_PIXEL_FORMAT_VIDEO_420_YCrCb; plane_info->format = SURFACE_PIXEL_FORMAT_VIDEO_420_YCrCb;
break; break;
case DRM_FORMAT_P010:
plane_info->format = SURFACE_PIXEL_FORMAT_VIDEO_420_10bpc_YCrCb;
break;
default: default:
DRM_ERROR( DRM_ERROR(
"Unsupported screen format %s\n", "Unsupported screen format %s\n",
...@@ -5535,6 +5538,8 @@ static int get_plane_formats(const struct drm_plane *plane, ...@@ -5535,6 +5538,8 @@ static int get_plane_formats(const struct drm_plane *plane,
if (plane_cap && plane_cap->pixel_format_support.nv12) if (plane_cap && plane_cap->pixel_format_support.nv12)
formats[num_formats++] = DRM_FORMAT_NV12; formats[num_formats++] = DRM_FORMAT_NV12;
if (plane_cap && plane_cap->pixel_format_support.p010)
formats[num_formats++] = DRM_FORMAT_P010;
break; break;
case DRM_PLANE_TYPE_OVERLAY: case DRM_PLANE_TYPE_OVERLAY:
......
...@@ -552,7 +552,8 @@ static const struct dc_plane_cap plane_cap = { ...@@ -552,7 +552,8 @@ static const struct dc_plane_cap plane_cap = {
.pixel_format_support = { .pixel_format_support = {
.argb8888 = true, .argb8888 = true,
.nv12 = true, .nv12 = true,
.fp16 = true .fp16 = true,
.p010 = true
}, },
.max_upscale_factor = { .max_upscale_factor = {
......
...@@ -1012,7 +1012,8 @@ static const struct dc_plane_cap plane_cap = { ...@@ -1012,7 +1012,8 @@ static const struct dc_plane_cap plane_cap = {
.pixel_format_support = { .pixel_format_support = {
.argb8888 = true, .argb8888 = true,
.nv12 = true, .nv12 = true,
.fp16 = true .fp16 = true,
.p010 = true
}, },
.max_upscale_factor = { .max_upscale_factor = {
......
...@@ -838,7 +838,8 @@ static const struct dc_plane_cap plane_cap = { ...@@ -838,7 +838,8 @@ static const struct dc_plane_cap plane_cap = {
.pixel_format_support = { .pixel_format_support = {
.argb8888 = true, .argb8888 = true,
.nv12 = true, .nv12 = true,
.fp16 = true .fp16 = true,
.p010 = true
}, },
.max_upscale_factor = { .max_upscale_factor = {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment