Received: by 2002:ab2:620c:0:b0:1ef:ffd0:ce49 with SMTP id o12csp237755lqt; Mon, 18 Mar 2024 06:42:07 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWlP1ETPvKy4YzaJVtkM5MQbXsbkqEjIsbZy8CLZ1EdE6oSQsXTAXvyOrEPzM7mXbxBkosBY+gMGYEiE2ge2k1bC/9ZjOLwG+TYP0cNBg== X-Google-Smtp-Source: AGHT+IGMXJbqgtMj3811iW5cOJTeJXGaFopk7mGDCNB6Zqy9wb25SSkOSuDqrtzjIhg8GLncFKNR X-Received: by 2002:a17:90a:f18d:b0:29f:96ac:9dd7 with SMTP id bv13-20020a17090af18d00b0029f96ac9dd7mr2339523pjb.41.1710769326697; Mon, 18 Mar 2024 06:42:06 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1710769326; cv=pass; d=google.com; s=arc-20160816; b=IIPAQE4EHLyQiaCb05KzmgszV1hUzjwVM/vec5aZA9mhPrwVU5fmbl/MC3zTU/RBS4 bwd2Tm+ZcFLzueoJvVlAsKQ6s59ovWmx+ZuNMr8xfR5grBImnx0fy8d1JWb3/DKxhglU 6sTLsaQ3hMcuSbH6P7nZlZQs+kRtL+nciBZ73nXeErzVp2VgzF+1XfNIzbH0yJju3fOC vNIragGSnGpwS7arir5AeVCl6c68/pcqy995diACLD1ZYx9ZSg+1HLIj91vcmM+5b66T fuTFqaP5XU3hGG/26Pk4BiRnSsA2m88lwBs6ny0LGkTGyRNG5f1s5UgtQQ3wqZBsF4nO RfWA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id; bh=+ZTtz2uYsb9ierf6BilktCz+Mp6pgeaaX3WrApGaljg=; fh=NSOnOasoYUPfcieX0xlh94IeF8DO/7s3qgTMGxqpzxQ=; b=pW4VGyjbMlb4eJP4b3s40WijJQEAHrdoV384vm/1RzKrQnNOWHbusoz1dbvxzALRDY gqQx1tu3w/9+Fl/m0zHztkKHLXb9DEjs8S6dKBzEtFgHUdoEiDPF18XsqUixXf+OcvHr qoFWMWWkS1wgZzRn/GcMXaWmXQZJeLVIdp4v93Rt2jc5ZHfeGm3Jzi7RgyggqJ/6mz6Y bFlGyDrQ77MzYdzTj5atqQJjI68o+2UMO5/hhetWHQGwwoTGWJCYRwbAxKoJthrfCtix D5TB7aV2IMB4LydDQ18A9Ia7lUSaqZPUFKYL3EPL/Dis7iOW1nCsrFRg0M5BrOezq1GP 6bfA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1); spf=pass (google.com: domain of linux-kernel+bounces-106173-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-106173-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=xs4all.nl Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [2604:1380:40f1:3f00::1]) by mx.google.com with ESMTPS id m5-20020a17090a4d8500b0029b948f63f8si8184254pjh.56.2024.03.18.06.42.06 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 Mar 2024 06:42:06 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-106173-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) client-ip=2604:1380:40f1:3f00::1; Authentication-Results: mx.google.com; arc=pass (i=1); spf=pass (google.com: domain of linux-kernel+bounces-106173-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-106173-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=xs4all.nl Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id 1353DB225C4 for ; Mon, 18 Mar 2024 13:40:15 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 2E2E9495CC; Mon, 18 Mar 2024 13:40:03 +0000 (UTC) Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 66D412D605; Mon, 18 Mar 2024 13:40:02 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710769202; cv=none; b=ACPU0m/7bpOpXMxfXyfZ8BVZrTxD+ZCvaliO/MyRBdUrHLBRrfPkD+2aKxcM3Y5/R0Uik8mjFBEFpHFIkBQBwliWOaCvIncCrPh7g2bxsleTbbCdQpfnMo/V3MDE1CaQHlYqqydGRk8HuI5ZhmwAQekh7lDgNSFKVS1i+Qu1r+s= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710769202; c=relaxed/simple; bh=vhSJTJYhTUx4X/vWqYjr3eEChl1T/JO76AeykxljURM=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=ru/YKwV7zfwfrNLAo6GiB7dapIRDMI38+LclIdOL0o3QAobBZd+hh//b681Rm897t+4XJqPzin6K6PbXFEwDr2K0hcREnUrw3xUyuIoUdMsmYRcXB3eKbYUt+PZgLY+UujoI3cfg2CThKkU0XBrMGQrpJ+hqk2JJqZ23aEIfsF4= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 6FF74C433F1; Mon, 18 Mar 2024 13:39:57 +0000 (UTC) Message-ID: Date: Mon, 18 Mar 2024 14:39:55 +0100 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v6 2/3] media: jpeg: Add reference quantization and huffman tables Content-Language: en-US, nl To: Devarsh Thakkar , mchehab@kernel.org, robh@kernel.org, krzysztof.kozlowski+dt@linaro.org, conor+dt@kernel.org, linux-media@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, benjamin.gaignard@collabora.com, sebastian.fricke@collabora.com Cc: laurent.pinchart@ideasonboard.com, praneeth@ti.com, nm@ti.com, vigneshr@ti.com, a-bhatia1@ti.com, j-luthra@ti.com, b-brnich@ti.com, detheridge@ti.com, p-mantena@ti.com, vijayp@ti.com, andrzej.p@collabora.com, nicolas@ndufresne.ca, afd@ti.com, milkfafa@gmail.com References: <20240228141140.3530612-1-devarsht@ti.com> <20240228141140.3530612-3-devarsht@ti.com> From: Hans Verkuil In-Reply-To: <20240228141140.3530612-3-devarsht@ti.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit Hi Devarsh, I was reviewing the pull request for this driver, but I have some concerns about this patch. First of all, it is generally bad practice to put data in a header, that really belongs in a source. Why not just put this in drivers/media/v4l2-core/v4l2-jpeg.c? On 28/02/2024 3:11 pm, Devarsh Thakkar wrote: > Add reference quantization and huffman tables to a global header file so > that they can be re-used by other JPEG drivers. > > These are example tables provided in ITU-T.81 as reference. The JPEG > encoders are free to use either these or their own proprietary tables. > > These tables are being used already by verisilicon driver [1]. If the same tables are in use by another driver, then please convert that driver to use the same tables defined in this patch. Bonus points if you can check for other encoder JPEG drivers that might use the same tables :-) Some more notes below: > > Also add necessary prefixes to be used for huffman tables in global header > file. > > [1] : > https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/drivers/media/platform/verisilicon/hantro_jpeg.c?h=v6.7#n30 > > Signed-off-by: Devarsh Thakkar > --- > V1->V4 : No change (Introduced in v4) > V5 : Rename from jpeg_enc_reftables to jpeg-enc-reftables.h > V6 : No change > > include/media/jpeg-enc-reftables.h | 112 +++++++++++++++++++++++++++++ > include/media/jpeg.h | 4 ++ > 2 files changed, 116 insertions(+) > create mode 100644 include/media/jpeg-enc-reftables.h > > diff --git a/include/media/jpeg-enc-reftables.h b/include/media/jpeg-enc-reftables.h > new file mode 100644 > index 000000000000..91959907113f > --- /dev/null > +++ b/include/media/jpeg-enc-reftables.h > @@ -0,0 +1,112 @@ > +/* SPDX-License-Identifier: GPL-2.0-only */ > +/* Reference quantization, zig-zag scan and huffman tables as shared in ITU-T.81 */ > + > +#ifndef _MEDIA_JPEG_ENC_REF_H_ > +#define _MEDIA_JPEG_ENC_REF_H_ > + > +/* Luma and chroma qp table to acheive 50% compression quality table -> tables acheive -> achieve > + * This is as per example in Annex K.1 of ITU-T.81 > + */ > +static const u8 luma_q_table[64] = { > + 16, 11, 10, 16, 24, 40, 51, 61, > + 12, 12, 14, 19, 26, 58, 60, 55, > + 14, 13, 16, 24, 40, 57, 69, 56, > + 14, 17, 22, 29, 51, 87, 80, 62, > + 18, 22, 37, 56, 68, 109, 103, 77, > + 24, 35, 55, 64, 81, 104, 113, 92, > + 49, 64, 78, 87, 103, 121, 120, 101, > + 72, 92, 95, 98, 112, 100, 103, 99 > +}; > + > +static const u8 chroma_q_table[64] = { > + 17, 18, 24, 47, 99, 99, 99, 99, > + 18, 21, 26, 66, 99, 99, 99, 99, > + 24, 26, 56, 99, 99, 99, 99, 99, > + 47, 66, 99, 99, 99, 99, 99, 99, > + 99, 99, 99, 99, 99, 99, 99, 99, > + 99, 99, 99, 99, 99, 99, 99, 99, > + 99, 99, 99, 99, 99, 99, 99, 99, > + 99, 99, 99, 99, 99, 99, 99, 99 > +}; > + > +/* Zigzag scan pattern */ > +static const u8 zigzag[64] = { > + 0, 1, 8, 16, 9, 2, 3, 10, > + 17, 24, 32, 25, 18, 11, 4, 5, > + 12, 19, 26, 33, 40, 48, 41, 34, > + 27, 20, 13, 6, 7, 14, 21, 28, > + 35, 42, 49, 56, 57, 50, 43, 36, > + 29, 22, 15, 23, 30, 37, 44, 51, > + 58, 59, 52, 45, 38, 31, 39, 46, > + 53, 60, 61, 54, 47, 55, 62, 63 > +}; > + > +/* > + * Contains the data that needs to be sent in the marker segment of an interchange format JPEG > + * stream or an abbreviated format table specification data stream. > + * Specifies the huffman table used for encoding the luminance DC coefficient differences. > + * The table represents Table K.3 of ITU-T.81 Please keep the line length in this source within 80 chars max. Sometimes it is OK to go with longer line lengths, but that is really not needed here. > + */ > +static const u8 luma_dc_table[] = { > + 0x00, 0x01, 0x05, 0x01, 0x01, 0x01, 0x01, 0x01, > + 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, > + 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B > +}; > + > +/* > + * Contains the data that needs to be sent in the marker segment of an interchange format JPEG > + * stream or an abbreviated format table specification data stream. > + * Specifies the huffman table used for encoding the luminance AC coefficients. > + * The table represents Table K.5 of ITU-T.81 > + */ > +static const u8 luma_ac_table[] = { > + 0x00, 0x02, 0x01, 0x03, 0x03, 0x02, 0x04, 0x03, > + 0x05, 0x05, 0x04, 0x04, 0x00, 0x00, 0x01, 0x7D, > + 0x01, 0x02, 0x03, 0x00, 0x04, 0x11, 0x05, 0x12, 0x21, 0x31, 0x41, 0x06, 0x13, 0x51, 0x61, > + 0x07, 0x22, 0x71, 0x14, 0x32, 0x81, 0x91, 0xA1, 0x08, 0x23, 0x42, 0xB1, 0xC1, 0x15, 0x52, > + 0xD1, 0xF0, 0x24, 0x33, 0x62, 0x72, 0x82, 0x09, 0x0A, 0x16, 0x17, 0x18, 0x19, 0x1A, 0x25, > + 0x26, 0x27, 0x28, 0x29, 0x2A, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39, 0x3A, 0x43, 0x44, 0x45, > + 0x46, 0x47, 0x48, 0x49, 0x4A, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58, 0x59, 0x5A, 0x63, 0x64, > + 0x65, 0x66, 0x67, 0x68, 0x69, 0x6A, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78, 0x79, 0x7A, 0x83, > + 0x84, 0x85, 0x86, 0x87, 0x88, 0x89, 0x8A, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97, 0x98, 0x99, > + 0x9A, 0xA2, 0xA3, 0xA4, 0xA5, 0xA6, 0xA7, 0xA8, 0xA9, 0xAA, 0xB2, 0xB3, 0xB4, 0xB5, 0xB6, > + 0xB7, 0xB8, 0xB9, 0xBA, 0xC2, 0xC3, 0xC4, 0xC5, 0xC6, 0xC7, 0xC8, 0xC9, 0xCA, 0xD2, 0xD3, > + 0xD4, 0xD5, 0xD6, 0xD7, 0xD8, 0xD9, 0xDA, 0xE1, 0xE2, 0xE3, 0xE4, 0xE5, 0xE6, 0xE7, 0xE8, > + 0xE9, 0xEA, 0xF1, 0xF2, 0xF3, 0xF4, 0xF5, 0xF6, 0xF7, 0xF8, 0xF9, 0xFA > +}; > + > +/* > + * Contains the data that needs to be sent in the marker segment of an interchange format JPEG > + * stream or an abbreviated format table specification data stream. > + * Specifies the huffman table used for encoding the chrominance DC coefficient differences. > + * The table represents Table K.4 of ITU-T.81 > + */ > +static const u8 chroma_dc_table[] = { > + 0x00, 0x03, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, > + 0x01, 0x01, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, > + 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B > +}; > + > +/* > + * Contains the data that needs to be sent in the marker segment of an interchange format JPEG > + * stream or an abbreviated format table specification data stream. > + * Specifies the huffman table used for encoding the chrominance AC coefficients. > + * The table represents Table K.6 of ITU-T.81 > + */ > +static const u8 chroma_ac_table[] = { > + 0x00, 0x02, 0x01, 0x02, 0x04, 0x04, 0x03, 0x04, > + 0x07, 0x05, 0x04, 0x04, 0x00, 0x01, 0x02, 0x77, > + 0x00, 0x01, 0x02, 0x03, 0x11, 0x04, 0x05, 0x21, 0x31, 0x06, 0x12, 0x41, 0x51, 0x07, 0x61, > + 0x71, 0x13, 0x22, 0x32, 0x81, 0x08, 0x14, 0x42, 0x91, 0xA1, 0xB1, 0xC1, 0x09, 0x23, 0x33, > + 0x52, 0xF0, 0x15, 0x62, 0x72, 0xD1, 0x0A, 0x16, 0x24, 0x34, 0xE1, 0x25, 0xF1, 0x17, 0x18, > + 0x19, 0x1A, 0x26, 0x27, 0x28, 0x29, 0x2A, 0x35, 0x36, 0x37, 0x38, 0x39, 0x3A, 0x43, 0x44, > + 0x45, 0x46, 0x47, 0x48, 0x49, 0x4A, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58, 0x59, 0x5A, 0x63, > + 0x64, 0x65, 0x66, 0x67, 0x68, 0x69, 0x6A, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78, 0x79, 0x7A, > + 0x82, 0x83, 0x84, 0x85, 0x86, 0x87, 0x88, 0x89, 0x8A, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97, > + 0x98, 0x99, 0x9A, 0xA2, 0xA3, 0xA4, 0xA5, 0xA6, 0xA7, 0xA8, 0xA9, 0xAA, 0xB2, 0xB3, 0xB4, > + 0xB5, 0xB6, 0xB7, 0xB8, 0xB9, 0xBA, 0xC2, 0xC3, 0xC4, 0xC5, 0xC6, 0xC7, 0xC8, 0xC9, 0xCA, > + 0xD2, 0xD3, 0xD4, 0xD5, 0xD6, 0xD7, 0xD8, 0xD9, 0xDA, 0xE2, 0xE3, 0xE4, 0xE5, 0xE6, 0xE7, > + 0xE8, 0xE9, 0xEA, 0xF2, 0xF3, 0xF4, 0xF5, 0xF6, 0xF7, 0xF8, 0xF9, 0xFA > +}; > + > +#endif /* _MEDIA_JPEG_ENC_REF_H_ */ > diff --git a/include/media/jpeg.h b/include/media/jpeg.h > index a01e142e99a7..e07b20ef8665 100644 > --- a/include/media/jpeg.h > +++ b/include/media/jpeg.h > @@ -16,5 +16,9 @@ > #define JPEG_MARKER_DHP 0xde > #define JPEG_MARKER_APP0 0xe0 > #define JPEG_MARKER_COM 0xfe > +#define JPEG_LUM_HT 0x00 > +#define JPEG_CHR_HT 0x01 > +#define JPEG_DC_HT 0x00 > +#define JPEG_AC_HT 0x10 These are added without documentation. They are grouped as part of the markers, which they are really not AFAICT. When the arrays are moved to v4l2-jpeg.c, then these defines should be moved to media/v4l2-jpeg.h as well. Actually, looking at the media/jpeg.h and media/v4l2-jpeg.h headers, I wonder if it wouldn't make much more sense to first move the contents of jpeg.h to v4l2-jpeg.h and drop the old jpeg.h header completely. It makes no sense that we have two jpeg media headers. And that is also another reason for not adding a third (jpeg-enc-reftables.h). > > #endif /* _MEDIA_JPEG_H_ */ Regards, Hans