[RFC][PATCH 7/7] drm: Add CSC helper stuff

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



From: Ville Syrjälä <ville.syrjala@xxxxxxxxxxxxxxx>

Signed-off-by: Ville Syrjälä <ville.syrjala@xxxxxxxxxxxxxxx>
---
 drivers/gpu/drm/drm_crtc_helper.c |   48 ++++++++++++++++++++++++++++++++
 include/drm/drm_crtc.h            |   55 +++++++++++++++++++++++++++++++++++++
 include/drm/drm_crtc_helper.h     |    5 +++
 3 files changed, 108 insertions(+), 0 deletions(-)

diff --git a/drivers/gpu/drm/drm_crtc_helper.c b/drivers/gpu/drm/drm_crtc_helper.c
index 490b7bc..b06465c 100644
--- a/drivers/gpu/drm/drm_crtc_helper.c
+++ b/drivers/gpu/drm/drm_crtc_helper.c
@@ -1482,3 +1482,51 @@ int drm_calc_vscale(struct drm_region *src, struct drm_region *dst,
 	return vscale;
 }
 EXPORT_SYMBOL(drm_calc_vscale);
+
+/**
+ * drm_chroma_phase_offsets - calculate the chroma phase offsets
+ * @ret_xoff: returned horizontal offset (16.16)
+ * @ret_yoff: returned vertical offset (16.16)
+ * @hsub: horizontal chroma subsampling factor
+ * @vsub: vertical chroma subsampling factor
+ * @chroma: chroma siting information (@drm_chroma_siting)
+ * @second_chroma_plane: first or second chroma plane?
+ *
+ * Calculates the phase offset between chroma and luma pixel centers,
+ * based on infromation provided in @chroma, @hsub, @vsub, and
+ * @second_chroma_plane.
+ *
+ * RETURNS:
+ * The chroma phase offsets in 16.16 format. The returned
+ * phase offsets are in chroma (ie. subsampled) coordinate space.
+ */
+void drm_chroma_phase_offsets(int *ret_xoff, int *ret_yoff,
+			      int hsub, int vsub,
+			      enum drm_chroma_siting chroma,
+			      bool second_chroma_plane)
+{
+	*ret_xoff = 0;
+	*ret_yoff = 0;
+
+	switch (chroma & 0x3) {
+	case DRM_CHROMA_SITING_HORZ_LEFT:
+		break;
+	case DRM_CHROMA_SITING_HORZ_CENTER:
+		*ret_xoff -= (hsub - 1) * 0x8000 / hsub;
+		break;
+	}
+
+	switch (chroma & 0xc0) {
+	case DRM_CHROMA_SITING_VERT_TOP:
+		break;
+	case DRM_CHROMA_SITING_VERT_CENTER:
+		*ret_yoff -= (vsub - 1) * 0x8000 / vsub;
+		break;
+	}
+
+	/* Chroma planes out of phase by 0.5 chroma lines? */
+	if (second_chroma_plane &&
+	    (chroma & DRM_CHROMA_SITING_MISALIGNED_PLANES))
+		*ret_yoff -= 0x8000;
+}
+EXPORT_SYMBOL(drm_chroma_phase_offsets);
diff --git a/include/drm/drm_crtc.h b/include/drm/drm_crtc.h
index 736d68d..55ff998 100644
--- a/include/drm/drm_crtc.h
+++ b/include/drm/drm_crtc.h
@@ -903,4 +903,59 @@ extern int drm_mode_mmap_dumb_ioctl(struct drm_device *dev,
 extern int drm_mode_destroy_dumb_ioctl(struct drm_device *dev,
 				      void *data, struct drm_file *file_priv);
 
+/**
+ * drm_csc_range - indicates the valid range for color values
+ * @DRM_CSC_RANGE_UNKNOWN: not specified, implementation defined result
+ * @DRM_CSC_RANGE_MPEG: "MPEG" range (16-235 for Y, 16-240 for Cb/Cr)
+ * @DRM_CSC_RANGE_JPEG: "JPEG" or full range (0-255 for Y/Cb/Cr)
+ */
+enum drm_csc_range {
+	DRM_CSC_RANGE_UNKNOWN = 0x0,
+
+	DRM_CSC_RANGE_MPEG    = 0x1,
+	DRM_CSC_RANGE_JPEG    = 0x2,
+};
+
+/**
+ * drm_csc_matrix - specifies the color space conversion matrix
+ * @DRM_CSC_MATRIX_UNKNOWN: not specified, implementation defined result
+ * @DRM_CSC_MATRIX_BT601: ITU-R BT.601
+ * @DRM_CSC_MATRIX_BT709: ITU-R BT.709
+ */
+enum drm_csc_matrix {
+	DRM_CSC_MATRIX_UNKNOWN = 0x0,
+
+	DRM_CSC_MATRIX_BT601   = 0x1,
+	DRM_CSC_MATRIX_BT709   = 0x2,
+};
+
+/**
+ * drm_chroma_siting - chroma siting information
+ * @DRM_CHROMA_SITING_UNKNOWN: not specified, implementation defined result
+ * @DRM_CHROMA_SITING_HORZ_LEFT: horizontally co-sited with the left luma sample
+ * @DRM_CHROMA_SITING_HORZ_CENTER: horizontally interstitially sited with luma samples
+ * @DRM_CHROMA_SITING_VERT_TOP: vertically co-sited with the top luma sample
+ * @DRM_CHROMA_SITING_VERT_CENTER: vertically interstitially sited with luma samples
+ * @DRM_CHROMA_SITING_MISALIGNED_PLANES: chroma planes out of phase with each other by 0.5 lines
+ * @DRM_CHROMA_SITING_MPEG1: chroma siting convention used in MPEG1
+ * @DRM_CHROMA_SITING_MPEG2: chroma siting convention used in MPEG2
+ * @DRM_CHROMA_SITING_DV: chroma siting convention used in DV
+ */
+enum drm_chroma_siting {
+	DRM_CHROMA_SITING_UNKNOWN     = 0x0,
+
+	DRM_CHROMA_SITING_HORZ_LEFT   = 0x1,
+	DRM_CHROMA_SITING_HORZ_CENTER = 0x2,
+
+	DRM_CHROMA_SITING_VERT_TOP    = 0x4,
+	DRM_CHROMA_SITING_VERT_CENTER = 0x8,
+
+	DRM_CHROMA_SITING_MISALIGNED_PLANES = 0x10,
+
+	/* typical configurations */
+	DRM_CHROMA_SITING_MPEG1 = DRM_CHROMA_SITING_HORZ_CENTER | DRM_CHROMA_SITING_VERT_CENTER,
+	DRM_CHROMA_SITING_MPEG2 = DRM_CHROMA_SITING_HORZ_LEFT | DRM_CHROMA_SITING_VERT_CENTER,
+	DRM_CHROMA_SITING_DV    = DRM_CHROMA_SITING_HORZ_LEFT | DRM_CHROMA_SITING_VERT_TOP | DRM_CHROMA_SITING_MISALIGNED_PLANES,
+};
+
 #endif /* __DRM_CRTC_H__ */
diff --git a/include/drm/drm_crtc_helper.h b/include/drm/drm_crtc_helper.h
index e23aa02..7541f96 100644
--- a/include/drm/drm_crtc_helper.h
+++ b/include/drm/drm_crtc_helper.h
@@ -182,4 +182,9 @@ extern int drm_calc_hscale(struct drm_region *src, struct drm_region *dst,
 extern int drm_calc_vscale(struct drm_region *src, struct drm_region *dst,
 			   int min_vscale, int max_vscale);
 
+extern void drm_chroma_phase_offsets(int *ret_xoff, int *ret_yoff,
+				     int hsub, int vsub,
+				     enum drm_chroma_siting chroma,
+				     bool second_chroma_plane);
+
 #endif
-- 
1.7.3.4

_______________________________________________
dri-devel mailing list
dri-devel@xxxxxxxxxxxxxxxxxxxxx
http://lists.freedesktop.org/mailman/listinfo/dri-devel



[Index of Archives]     [Linux DRI Users]     [Linux Intel Graphics]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux