提交 9aecbc45 编写于 作者: V Ville Syrjälä

drm/nouveau: Replace the iturbt_709 prop with the standard COLOR_ENCODING prop

Replace the ad-hoc iturbt_709 property with the new standard
COLOR_ENCODING property. Compiles, but not tested.

v2: Fix typos (Ilia)

Cc: Daniel Vetter <daniel@ffwll.ch>
Cc: nouveau@lists.freedesktop.org
Cc: Ben Skeggs <bskeggs@redhat.com>
Cc: Ilia Mirkin <imirkin@alum.mit.edu>
Signed-off-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20180220134816.15229-1-ville.syrjala@linux.intel.comReviewed-by: NIlia Mirkin <imirkin@alum.mit.edu>
Acked-by: Ben Skeggs <bskeggs@redhat.com> #irc
上级 df99dd92
...@@ -46,7 +46,6 @@ struct nouveau_plane { ...@@ -46,7 +46,6 @@ struct nouveau_plane {
struct drm_property *brightness; struct drm_property *brightness;
struct drm_property *hue; struct drm_property *hue;
struct drm_property *saturation; struct drm_property *saturation;
struct drm_property *iturbt_709;
} props; } props;
int colorkey; int colorkey;
...@@ -54,7 +53,7 @@ struct nouveau_plane { ...@@ -54,7 +53,7 @@ struct nouveau_plane {
int brightness; int brightness;
int hue; int hue;
int saturation; int saturation;
int iturbt_709; enum drm_color_encoding color_encoding;
void (*set_params)(struct nouveau_plane *); void (*set_params)(struct nouveau_plane *);
}; };
...@@ -166,7 +165,7 @@ nv10_update_plane(struct drm_plane *plane, struct drm_crtc *crtc, ...@@ -166,7 +165,7 @@ nv10_update_plane(struct drm_plane *plane, struct drm_crtc *crtc,
if (fb->format->format == DRM_FORMAT_NV12 || if (fb->format->format == DRM_FORMAT_NV12 ||
fb->format->format == DRM_FORMAT_NV21) fb->format->format == DRM_FORMAT_NV21)
format |= NV_PVIDEO_FORMAT_PLANAR; format |= NV_PVIDEO_FORMAT_PLANAR;
if (nv_plane->iturbt_709) if (nv_plane->color_encoding == DRM_COLOR_YCBCR_BT709)
format |= NV_PVIDEO_FORMAT_MATRIX_ITURBT709; format |= NV_PVIDEO_FORMAT_MATRIX_ITURBT709;
if (nv_plane->colorkey & (1 << 24)) if (nv_plane->colorkey & (1 << 24))
format |= NV_PVIDEO_FORMAT_DISPLAY_COLOR_KEY; format |= NV_PVIDEO_FORMAT_DISPLAY_COLOR_KEY;
...@@ -229,7 +228,7 @@ nv10_set_params(struct nouveau_plane *plane) ...@@ -229,7 +228,7 @@ nv10_set_params(struct nouveau_plane *plane)
nvif_wr32(dev, NV_PVIDEO_COLOR_KEY, plane->colorkey & 0xffffff); nvif_wr32(dev, NV_PVIDEO_COLOR_KEY, plane->colorkey & 0xffffff);
if (plane->cur) { if (plane->cur) {
if (plane->iturbt_709) if (plane->color_encoding == DRM_COLOR_YCBCR_BT709)
format |= NV_PVIDEO_FORMAT_MATRIX_ITURBT709; format |= NV_PVIDEO_FORMAT_MATRIX_ITURBT709;
if (plane->colorkey & (1 << 24)) if (plane->colorkey & (1 << 24))
format |= NV_PVIDEO_FORMAT_DISPLAY_COLOR_KEY; format |= NV_PVIDEO_FORMAT_DISPLAY_COLOR_KEY;
...@@ -258,8 +257,8 @@ nv_set_property(struct drm_plane *plane, ...@@ -258,8 +257,8 @@ nv_set_property(struct drm_plane *plane,
nv_plane->hue = value; nv_plane->hue = value;
else if (property == nv_plane->props.saturation) else if (property == nv_plane->props.saturation)
nv_plane->saturation = value; nv_plane->saturation = value;
else if (property == nv_plane->props.iturbt_709) else if (property == nv_plane->base.color_encoding_property)
nv_plane->iturbt_709 = value; nv_plane->color_encoding = value;
else else
return -EINVAL; return -EINVAL;
...@@ -313,14 +312,11 @@ nv10_overlay_init(struct drm_device *device) ...@@ -313,14 +312,11 @@ nv10_overlay_init(struct drm_device *device)
device, 0, "hue", 0, 359); device, 0, "hue", 0, 359);
plane->props.saturation = drm_property_create_range( plane->props.saturation = drm_property_create_range(
device, 0, "saturation", 0, 8192 - 1); device, 0, "saturation", 0, 8192 - 1);
plane->props.iturbt_709 = drm_property_create_range(
device, 0, "iturbt_709", 0, 1);
if (!plane->props.colorkey || if (!plane->props.colorkey ||
!plane->props.contrast || !plane->props.contrast ||
!plane->props.brightness || !plane->props.brightness ||
!plane->props.hue || !plane->props.hue ||
!plane->props.saturation || !plane->props.saturation)
!plane->props.iturbt_709)
goto cleanup; goto cleanup;
plane->colorkey = 0; plane->colorkey = 0;
...@@ -343,9 +339,13 @@ nv10_overlay_init(struct drm_device *device) ...@@ -343,9 +339,13 @@ nv10_overlay_init(struct drm_device *device)
drm_object_attach_property(&plane->base.base, drm_object_attach_property(&plane->base.base,
plane->props.saturation, plane->saturation); plane->props.saturation, plane->saturation);
plane->iturbt_709 = 0; plane->color_encoding = DRM_COLOR_YCBCR_BT601;
drm_object_attach_property(&plane->base.base, drm_plane_create_color_properties(&plane->base,
plane->props.iturbt_709, plane->iturbt_709); BIT(DRM_COLOR_YCBCR_BT601) |
BIT(DRM_COLOR_YCBCR_BT709),
BIT(DRM_COLOR_YCBCR_LIMITED_RANGE),
DRM_COLOR_YCBCR_BT601,
DRM_COLOR_YCBCR_LIMITED_RANGE);
plane->set_params = nv10_set_params; plane->set_params = nv10_set_params;
nv10_set_params(plane); nv10_set_params(plane);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册