Received: by 10.223.176.5 with SMTP id f5csp311246wra; Thu, 8 Feb 2018 22:36:31 -0800 (PST) X-Google-Smtp-Source: AH8x225L2KmBMH1Vy5dPjZkmD81okZLE4rKiw4dI0U9t7mRA/hAw/BlBlRW4+qHfDZkpby837kc9 X-Received: by 10.98.207.198 with SMTP id b189mr1339599pfg.148.1518158191539; Thu, 08 Feb 2018 22:36:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518158191; cv=none; d=google.com; s=arc-20160816; b=vuRdOI8/1OLGxfaSfRfq4RfJ618E5SIx5oYx2LBbWhVnmL3AQzwOfdPQS/VhUnTPbr Tm2UBQq0oC9g7URLtQDQfJ//1qt2U3CgkN3IY8nKSPi67BUn1UqRxA6OdxIBVgYb6FSN F365tN9QjP8K8yuZQXKhUsFUCV52DQYdxmF3XNvqDY9Mn8ggQ6WMWIzocgwNfTrETPpK YqL/oGU5UnQEcNaGo7B1M1n3D0QZNQd9KnapmI5FT8nk+r17sp2nAMUni20cDfrQND2H 2XmzioPhHIH1QB2i5QddQLSb6Ebxln4BpznpuFPJwItc2xzB0y6qmlQ9udfU2Ph6hSbc lb8Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=fp4Gd555MpbInfEntEVFUpAzVpyKDgcQkoms1by9/WA=; b=EcG0oK8hUPQBMkhDyxiNLS4uuRDHce3S6lFDWRo8WpmSOVVZkiQ53kMQNsiPS68qrl 3tycDAtr0yB98aiLfah5JExhpEXP5LYT6RxEXmeQ+p555VvRvVAqHBteiL3ARqYyBaW/ vH/mx56ZELZ3wY+7qHPISUQv+KcF987JuI0UogJqv3zGu4QKkV0ANt0WkkaSDHpf85Hs 7v3w0zOd+Bazj2N2yoD5CoO45sLAQuwdy/xbbPl56wscIRhwoNY/Hy1YSDggzcSwozXM 1VurkEVIcKBarDziVAEAwrggnkFjTmTGfTtyvCF6XXzo3p1hNAKISRWoo0qkb5/tni3m 1K5w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gateworks-com.20150623.gappssmtp.com header.s=20150623 header.b=hwjX2uBh; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 34-v6si1130598plz.22.2018.02.08.22.36.17; Thu, 08 Feb 2018 22:36:31 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gateworks-com.20150623.gappssmtp.com header.s=20150623 header.b=hwjX2uBh; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752590AbeBIGfM (ORCPT + 99 others); Fri, 9 Feb 2018 01:35:12 -0500 Received: from mail-pg0-f68.google.com ([74.125.83.68]:34267 "EHLO mail-pg0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751031AbeBIGcz (ORCPT ); Fri, 9 Feb 2018 01:32:55 -0500 Received: by mail-pg0-f68.google.com with SMTP id s73so3003239pgc.1 for ; Thu, 08 Feb 2018 22:32:55 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gateworks-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=fp4Gd555MpbInfEntEVFUpAzVpyKDgcQkoms1by9/WA=; b=hwjX2uBhLGHFXa8BvOndlGV/zGJ3hptOEdJc5S+OPcmGWoYIgUJtjOnUx7l07uYXJr n0NM1GVOVN2ElhU96fDntApr+T6LzAtRS9o6T/9OXAnIs+ylrGXaEBy8+6sjkrQQjC0F 92/EMv1qSPzo1fEmN5N+U2fR0+CeGZpLMacAx8ndonDpcR8oCpoVJso0ZelCsNRLQ3zo Yxlab3RWKLJB2fF/HHwga2q7L0AMP2ZFL52DxbNQVozsqrU7R1si9bBNxBHMtk064X+F /oG4RP7+dkQEktVnd+Thpp2EQRvtkL0RQgyfJEHu4Yd91JcB1zwB50u9m4ZZH1IPVKSk MhYA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=fp4Gd555MpbInfEntEVFUpAzVpyKDgcQkoms1by9/WA=; b=Gf7b/ukgeh42ZYpfYAQ2o28iu/7iOk311khWsBrF5JnXoNft5AcVFik2RndnmZdtFb wYEx2fkUxVeWiGdzjTn42q/wC2UzyOWbGrhDOn+0sXx+KmhgEHBPKZKwUyKmUigeO8w+ Nlb0ffM283KAJHWS+wWew+0zlY052NsvZSon2Q6FhfxDeXO1HxMZfGuqaK9UZZRxGGS9 45mWYBY8O1KRG/qUlFBlIoExry+B/uzSZN6r10tazk9bF9d2oFBA17SPeY2IC+9avwUO FjLCRVLqnB5boa7FE6eClROvv7+oWM1j+kzHIdBF2rWrz+3+wZBvZKDprbnEvijBi01H bJjA== X-Gm-Message-State: APf1xPAxNqPnShO0UkN76bf6Ocl2Po6nq0lJ7NrEDzKAW26GTtJO7F1r Ch639XVzLIHa96bTdG8xMSMmOGKe X-Received: by 10.98.150.14 with SMTP id c14mr1732445pfe.210.1518157974575; Thu, 08 Feb 2018 22:32:54 -0800 (PST) Received: from tharvey.pdc.gateworks.com (68-189-91-139.static.snlo.ca.charter.com. [68.189.91.139]) by smtp.gmail.com with ESMTPSA id b68sm3531608pfg.159.2018.02.08.22.32.52 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Thu, 08 Feb 2018 22:32:53 -0800 (PST) From: Tim Harvey To: linux-media@vger.kernel.org, alsa-devel@alsa-project.org Cc: devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, shawnguo@kernel.org, Steve Longerbeam , Philipp Zabel , Hans Verkuil , Mauro Carvalho Chehab , Hans Verkuil , Randy Dunlap , Hans Verkuil Subject: [PATCH v10 1/8] v4l2-dv-timings: add v4l2_hdmi_colorimetry() Date: Thu, 8 Feb 2018 22:32:29 -0800 Message-Id: <1518157956-14220-2-git-send-email-tharvey@gateworks.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1518157956-14220-1-git-send-email-tharvey@gateworks.com> References: <1518157956-14220-1-git-send-email-tharvey@gateworks.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Hans Verkuil Add the v4l2_hdmi_colorimetry() function so we have a single function that determines the colorspace, YCbCr encoding, quantization range and transfer function from the InfoFrame data. Cc: Randy Dunlap Signed-off-by: Hans Verkuil --- v9: - fix kernel-doc format (Randy) drivers/media/v4l2-core/v4l2-dv-timings.c | 141 ++++++++++++++++++++++++++++++ include/media/v4l2-dv-timings.h | 21 +++++ 2 files changed, 162 insertions(+) diff --git a/drivers/media/v4l2-core/v4l2-dv-timings.c b/drivers/media/v4l2-core/v4l2-dv-timings.c index 930f9c5..5663d86 100644 --- a/drivers/media/v4l2-core/v4l2-dv-timings.c +++ b/drivers/media/v4l2-core/v4l2-dv-timings.c @@ -27,6 +27,7 @@ #include #include #include +#include MODULE_AUTHOR("Hans Verkuil"); MODULE_DESCRIPTION("V4L2 DV Timings Helper Functions"); @@ -814,3 +815,143 @@ struct v4l2_fract v4l2_calc_aspect_ratio(u8 hor_landscape, u8 vert_portrait) return aspect; } EXPORT_SYMBOL_GPL(v4l2_calc_aspect_ratio); + +/** v4l2_hdmi_rx_colorimetry - determine HDMI colorimetry information + * based on various InfoFrames. + * @avi: the AVI InfoFrame + * @hdmi: the HDMI Vendor InfoFrame, may be NULL + * @height: the frame height + * + * Determines the HDMI colorimetry information, i.e. how the HDMI + * pixel color data should be interpreted. + * + * Note that some of the newer features (DCI-P3, HDR) are not yet + * implemented: the hdmi.h header needs to be updated to the HDMI 2.0 + * and CTA-861-G standards. + */ +struct v4l2_hdmi_colorimetry +v4l2_hdmi_rx_colorimetry(const struct hdmi_avi_infoframe *avi, + const struct hdmi_vendor_infoframe *hdmi, + unsigned int height) +{ + struct v4l2_hdmi_colorimetry c = { + V4L2_COLORSPACE_SRGB, + V4L2_YCBCR_ENC_DEFAULT, + V4L2_QUANTIZATION_FULL_RANGE, + V4L2_XFER_FUNC_SRGB + }; + bool is_ce = avi->video_code || (hdmi && hdmi->vic); + bool is_sdtv = height <= 576; + bool default_is_lim_range_rgb = avi->video_code > 1; + + switch (avi->colorspace) { + case HDMI_COLORSPACE_RGB: + /* RGB pixel encoding */ + switch (avi->colorimetry) { + case HDMI_COLORIMETRY_EXTENDED: + switch (avi->extended_colorimetry) { + case HDMI_EXTENDED_COLORIMETRY_ADOBE_RGB: + c.colorspace = V4L2_COLORSPACE_ADOBERGB; + c.xfer_func = V4L2_XFER_FUNC_ADOBERGB; + break; + case HDMI_EXTENDED_COLORIMETRY_BT2020: + c.colorspace = V4L2_COLORSPACE_BT2020; + c.xfer_func = V4L2_XFER_FUNC_709; + break; + default: + break; + } + break; + default: + break; + } + switch (avi->quantization_range) { + case HDMI_QUANTIZATION_RANGE_LIMITED: + c.quantization = V4L2_QUANTIZATION_LIM_RANGE; + break; + case HDMI_QUANTIZATION_RANGE_FULL: + break; + default: + if (default_is_lim_range_rgb) + c.quantization = V4L2_QUANTIZATION_LIM_RANGE; + break; + } + break; + + default: + /* YCbCr pixel encoding */ + c.quantization = V4L2_QUANTIZATION_LIM_RANGE; + switch (avi->colorimetry) { + case HDMI_COLORIMETRY_NONE: + if (!is_ce) + break; + if (is_sdtv) { + c.colorspace = V4L2_COLORSPACE_SMPTE170M; + c.ycbcr_enc = V4L2_YCBCR_ENC_601; + } else { + c.colorspace = V4L2_COLORSPACE_REC709; + c.ycbcr_enc = V4L2_YCBCR_ENC_709; + } + c.xfer_func = V4L2_XFER_FUNC_709; + break; + case HDMI_COLORIMETRY_ITU_601: + c.colorspace = V4L2_COLORSPACE_SMPTE170M; + c.ycbcr_enc = V4L2_YCBCR_ENC_601; + c.xfer_func = V4L2_XFER_FUNC_709; + break; + case HDMI_COLORIMETRY_ITU_709: + c.colorspace = V4L2_COLORSPACE_REC709; + c.ycbcr_enc = V4L2_YCBCR_ENC_709; + c.xfer_func = V4L2_XFER_FUNC_709; + break; + case HDMI_COLORIMETRY_EXTENDED: + switch (avi->extended_colorimetry) { + case HDMI_EXTENDED_COLORIMETRY_XV_YCC_601: + c.colorspace = V4L2_COLORSPACE_REC709; + c.ycbcr_enc = V4L2_YCBCR_ENC_XV709; + c.xfer_func = V4L2_XFER_FUNC_709; + break; + case HDMI_EXTENDED_COLORIMETRY_XV_YCC_709: + c.colorspace = V4L2_COLORSPACE_REC709; + c.ycbcr_enc = V4L2_YCBCR_ENC_XV601; + c.xfer_func = V4L2_XFER_FUNC_709; + break; + case HDMI_EXTENDED_COLORIMETRY_S_YCC_601: + c.colorspace = V4L2_COLORSPACE_SRGB; + c.ycbcr_enc = V4L2_YCBCR_ENC_601; + c.xfer_func = V4L2_XFER_FUNC_SRGB; + break; + case HDMI_EXTENDED_COLORIMETRY_ADOBE_YCC_601: + c.colorspace = V4L2_COLORSPACE_ADOBERGB; + c.ycbcr_enc = V4L2_YCBCR_ENC_601; + c.xfer_func = V4L2_XFER_FUNC_ADOBERGB; + break; + case HDMI_EXTENDED_COLORIMETRY_BT2020: + c.colorspace = V4L2_COLORSPACE_BT2020; + c.ycbcr_enc = V4L2_YCBCR_ENC_BT2020; + c.xfer_func = V4L2_XFER_FUNC_709; + break; + case HDMI_EXTENDED_COLORIMETRY_BT2020_CONST_LUM: + c.colorspace = V4L2_COLORSPACE_BT2020; + c.ycbcr_enc = V4L2_YCBCR_ENC_BT2020_CONST_LUM; + c.xfer_func = V4L2_XFER_FUNC_709; + break; + default: /* fall back to ITU_709 */ + c.colorspace = V4L2_COLORSPACE_REC709; + c.ycbcr_enc = V4L2_YCBCR_ENC_709; + c.xfer_func = V4L2_XFER_FUNC_709; + break; + } + break; + default: + break; + } + /* + * YCC Quantization Range signaling is more-or-less broken, + * let's just ignore this. + */ + break; + } + return c; +} +EXPORT_SYMBOL_GPL(v4l2_hdmi_rx_colorimetry); diff --git a/include/media/v4l2-dv-timings.h b/include/media/v4l2-dv-timings.h index 61a1889..835aef7 100644 --- a/include/media/v4l2-dv-timings.h +++ b/include/media/v4l2-dv-timings.h @@ -223,5 +223,26 @@ static inline bool can_reduce_fps(struct v4l2_bt_timings *bt) return false; } +/** + * struct v4l2_hdmi_rx_colorimetry - describes the HDMI colorimetry information + * @colorspace: enum v4l2_colorspace, the colorspace + * @ycbcr_enc: enum v4l2_ycbcr_encoding, Y'CbCr encoding + * @quantization: enum v4l2_quantization, colorspace quantization + * @xfer_func: enum v4l2_xfer_func, colorspace transfer function + */ +struct v4l2_hdmi_colorimetry { + enum v4l2_colorspace colorspace; + enum v4l2_ycbcr_encoding ycbcr_enc; + enum v4l2_quantization quantization; + enum v4l2_xfer_func xfer_func; +}; + +struct hdmi_avi_infoframe; +struct hdmi_vendor_infoframe; + +struct v4l2_hdmi_colorimetry +v4l2_hdmi_rx_colorimetry(const struct hdmi_avi_infoframe *avi, + const struct hdmi_vendor_infoframe *hdmi, + unsigned int height); #endif -- 2.7.4