Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp3177920imj; Mon, 11 Feb 2019 15:33:51 -0800 (PST) X-Google-Smtp-Source: AHgI3IbihY+zwxaNe7igIincUMoFokMkmKpd5zV97umrV0DNmiYgnrHb/ORlKschO9o5Z+byLPD3 X-Received: by 2002:a62:f54f:: with SMTP id n76mr825578pfh.59.1549928031358; Mon, 11 Feb 2019 15:33:51 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549928031; cv=none; d=google.com; s=arc-20160816; b=QSJ1utGL4S1ESyUMuizkC+KP+Bp66lfGtSFOs/jpQsyKFpXhI8E9MAwsKAqXokAbOq BVtAYz/pVxDbnG3x5nVDr7L0v1uqkbANLGwZW/kyarRyrk4yLlmrekWQAJOdY1uhIPHV o/GE+JtXXN1CdHwQydfAdChVDHuGnBFLg7kR2CeZ5h9zHDXajNx6TjKUWCrTAJ9pPNWj z7hlW8A3RPHdurrLwOx8rPNVzTB7uE085pr8EGA4+ZT6SB+GRph1dYb9HMNZrffyaJQv xqz1KrEJI0/wqcqkjoeUc/SEk9hVx/6c2QZVCxTZa9uvlhRzHZDTTqLs0NevPup+uohV GfSQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=4YsmXbJZrgA9KlysuvIxL9L2aT/wmgrin1tjWxSQvBE=; b=J6vxECXMzHbXjhbtOo6EkBroBSbFqHeI10fxfV1gd3Xi9919vRepMD6mRzIsqNRu/r gjElP+/6lHEzMmmzr6NNfala/Wfth1HirriReidB9lUCYquJPGAwWpnVMqJUR4yM7xCT xZ+tTwW+OoJgg4gAScWV0bMbc0II99z3HLdLNgto4nUqHwL6ad8gxHhf39vh9fUkTtvn J4TKJ2GE3vSBlAeAGF/SziZT69tPcr+itadfDerZPpVIPpM5++s8hrvZjOCF/NdoKYnN x/tr8oYchWrrM1rE/4+Dn1ZJdUqXqM9HF9fm4y8rzPwp9VM3w2lMihPaqPLLJanKbUWB Pfmw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=tfJMpQia; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h2si10430242pgq.310.2019.02.11.15.33.34; Mon, 11 Feb 2019 15:33:51 -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=@gmail.com header.s=20161025 header.b=tfJMpQia; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727731AbfBKXd3 (ORCPT + 99 others); Mon, 11 Feb 2019 18:33:29 -0500 Received: from mail-wm1-f68.google.com ([209.85.128.68]:51886 "EHLO mail-wm1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727424AbfBKXd3 (ORCPT ); Mon, 11 Feb 2019 18:33:29 -0500 Received: by mail-wm1-f68.google.com with SMTP id b11so1029749wmj.1; Mon, 11 Feb 2019 15:33:26 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-transfer-encoding:content-language; bh=4YsmXbJZrgA9KlysuvIxL9L2aT/wmgrin1tjWxSQvBE=; b=tfJMpQiazUSzR2qIVuT0xukmGuQjxoqz3KItn52+wHoAjme1fx6romoXUzRZ1SBMvS RLKIyyL4vgaArpImqkRlTjYMJLCPdupolf199NH/Ucx3FGnRKWIo7h/Aahkg7pOz0dm4 BTEmf/K/5ZylkFK+OwbLAda1X/JEcFGOYva7Q4+OdHrxFh8adWEYqmQUldEkv3wZQcOu rH2Wa7ekxk/LSrfrY4dEFqLW2zQzxNiTo9dPwva+75WoSm6KV8qMvIq5rbN7CGMiWcoA bLK0GCGOJhny9IcVb+2lxC51hzyq+GcKMkjtopuk4UkTFU3gKQjaOrk21RvUb3ixZaDY ZUTA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding :content-language; bh=4YsmXbJZrgA9KlysuvIxL9L2aT/wmgrin1tjWxSQvBE=; b=sFcn8V3n6iSsRmYPmqXdPBBGIqsvTqBgxqy0C1lc78nz00BTFPl2pl15c/5f++Y8Fq DXK1sknvF3c5IFk0gzRm2Qhs579A0/D/3byGDOEhwD3bC1qqBWiY1WlSYlSENJIne401 Jv/gbhgzvKQSwIXY3cwgL2oVFf8E376q46lT2qlCHmwIiJ5TG7p3m90si6K1xF8b1rKF mKizLdpxMQpjOH091V5aCpr8CM3cCS6fkdDg1al+7t9IB088f9UOtE3v4aXtn2dwbKn+ nQo/0AMT+my5jgw0Qi07K7pzqqdZkJf5WJ1AgPiy72pKoBVtmi/UeVJAztz2YAI8+sf8 0qow== X-Gm-Message-State: AHQUAubwLrdAnPjTv5+6OQwYub+x8hFMA5K8iJUfc7/RKNLkcZhR78uv 1MKWPzB6aQ+J/zeRrPJjWwLN0TAR X-Received: by 2002:a7b:c854:: with SMTP id c20mr506627wml.153.1549928005622; Mon, 11 Feb 2019 15:33:25 -0800 (PST) Received: from [172.30.89.184] (sjewanfw1-nat.mentorg.com. [139.181.7.34]) by smtp.gmail.com with ESMTPSA id q21sm934970wmc.14.2019.02.11.15.33.23 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 11 Feb 2019 15:33:24 -0800 (PST) Subject: Re: [PATCH v4 1/4] gpu: ipu-v3: ipu-ic: Rename yuv2rgb encoding matrices To: Philipp Zabel , linux-media@vger.kernel.org Cc: Tim Harvey , "open list:DRM DRIVERS FOR FREESCALE IMX" , open list References: <20190209014748.10427-1-slongerbeam@gmail.com> <20190209014748.10427-2-slongerbeam@gmail.com> <1549879117.7687.2.camel@pengutronix.de> From: Steve Longerbeam Message-ID: <8a3a9c63-d466-e328-d49a-1810952d2e9a@gmail.com> Date: Mon, 11 Feb 2019 15:33:20 -0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.4.0 MIME-Version: 1.0 In-Reply-To: <1549879117.7687.2.camel@pengutronix.de> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2/11/19 1:58 AM, Philipp Zabel wrote: > On Fri, 2019-02-08 at 17:47 -0800, Steve Longerbeam wrote: >> The ycbcr2rgb and inverse rgb2ycbcr matrices define the BT.601 encoding >> coefficients, so rename them to indicate that. And add some comments >> to make clear these are BT.601 coefficients encoding between YUV limited >> range and RGB full range. The ic_csc_rgb2rgb matrix is just an identity >> matrix, so rename to ic_csc_identity. No functional changes. >> >> Signed-off-by: Steve Longerbeam >> --- >> Changes in v2: >> - rename ic_csc_rgb2rgb matrix to ic_csc_identity. >> --- >> drivers/gpu/ipu-v3/ipu-ic.c | 21 ++++++++++++++------- >> 1 file changed, 14 insertions(+), 7 deletions(-) >> >> diff --git a/drivers/gpu/ipu-v3/ipu-ic.c b/drivers/gpu/ipu-v3/ipu-ic.c >> index 594c3cbc8291..3ef61f0b509b 100644 >> --- a/drivers/gpu/ipu-v3/ipu-ic.c >> +++ b/drivers/gpu/ipu-v3/ipu-ic.c >> @@ -183,11 +183,13 @@ struct ic_csc_params { >> }; >> >> /* >> + * BT.601 encoding from RGB full range to YUV limited range: >> + * >> * Y = R * .299 + G * .587 + B * .114; >> * U = R * -.169 + G * -.332 + B * .500 + 128.; >> * V = R * .500 + G * -.419 + B * -.0813 + 128.; > Hm, this is a conversion to full range BT.601. For limited range, the > matrix coefficients > > 0.2990  0.5870  0.1140 > -0.1687 -0.3313  0.5000 > 0.5000 -0.4187 -0.0813 > > should be multiplied with 219/255 (Y) and 224/255 (U,V), respectively: > > Y = R * .2568 + G * .5041 + B * .0979 + 16; > U = R * -.1482 + G * -.2910 + B *  .4392 + 128; > V = R * .4392 + G * -.3678 + B * -.0714 + 128; > >> */ >> -static const struct ic_csc_params ic_csc_rgb2ycbcr = { >> +static const struct ic_csc_params ic_csc_rgb2ycbcr_bt601 = { >> .coeff = { >> { 77, 150, 29 }, >> { 469, 427, 128 }, >> @@ -197,8 +199,11 @@ static const struct ic_csc_params ic_csc_rgb2ycbcr = { >> .scale = 1, >> }; >> >> -/* transparent RGB->RGB matrix for graphics combining */ >> -static const struct ic_csc_params ic_csc_rgb2rgb = { >> +/* >> + * identity matrix, used for transparent RGB->RGB graphics >> + * combining. >> + */ >> +static const struct ic_csc_params ic_csc_identity = { >> .coeff = { >> { 128, 0, 0 }, >> { 0, 128, 0 }, >> @@ -208,11 +213,13 @@ static const struct ic_csc_params ic_csc_rgb2rgb = { >> }; >> >> /* >> + * Inverse BT.601 encoding from YUV limited range to RGB full range: >> + * >> * R = (1.164 * (Y - 16)) + (1.596 * (Cr - 128)); >> * G = (1.164 * (Y - 16)) - (0.392 * (Cb - 128)) - (0.813 * (Cr - 128)); >> * B = (1.164 * (Y - 16)) + (2.017 * (Cb - 128); >> */ > This looks correct. Agreed, the coefficients in the comments are correct, but the actual table values were a bit off. I will correct them for v5 (Green offset should be 272 in the table, not 266). Steve > >> -static const struct ic_csc_params ic_csc_ycbcr2rgb = { >> +static const struct ic_csc_params ic_csc_ycbcr2rgb_bt601 = { >> .coeff = { >> { 149, 0, 204 }, >> { 149, 462, 408 }, >> @@ -238,11 +245,11 @@ static int init_csc(struct ipu_ic *ic, >> (priv->tpmem_base + ic->reg->tpmem_csc[csc_index]); >> >> if (inf == IPUV3_COLORSPACE_YUV && outf == IPUV3_COLORSPACE_RGB) >> - params = &ic_csc_ycbcr2rgb; >> + params = &ic_csc_ycbcr2rgb_bt601; >> else if (inf == IPUV3_COLORSPACE_RGB && outf == IPUV3_COLORSPACE_YUV) >> - params = &ic_csc_rgb2ycbcr; >> + params = &ic_csc_rgb2ycbcr_bt601; >> else if (inf == IPUV3_COLORSPACE_RGB && outf == IPUV3_COLORSPACE_RGB) >> - params = &ic_csc_rgb2rgb; >> + params = &ic_csc_identity; >> else { >> dev_err(priv->ipu->dev, "Unsupported color space conversion\n"); >> return -EINVAL; > regards > Philipp