Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp2659077pxb; Mon, 17 Jan 2022 03:08:13 -0800 (PST) X-Google-Smtp-Source: ABdhPJzmgIYjHZzAj03/Dju2FtJ4bnL8Lf4bb3N/xkAOTIZSt7mP+fbSjaiTZM7r7aSc42xRfTc0 X-Received: by 2002:a63:92:: with SMTP id 140mr18758189pga.255.1642417693351; Mon, 17 Jan 2022 03:08:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642417693; cv=none; d=google.com; s=arc-20160816; b=adx3zAOyFpuvGO2adnhjDIOBpJf/R3+sZyP+U7qY0tfE0NlEkjUopXE0333AyGh48O iMwgJHvBwgckeaZ0iwph/0JKzsVXu1emK5LQlHPbUPLGOpyyFVKWBR8Vz3gT49Vf/QTQ IeL1UgQDTLgpiZpbW8tIk/vREpbVChAJjYGnWzSvq5QTmp7zTXpDZ1NE//iUgssmo7VC 1gIKcPBPgujDvXONXLQ+kU66ns3UqBnVhtChNgVDnqdZkazgbh9Mat04DxCSxJ6s5d2S bSkQ3VOm2+AEBGLbYhflf8B/1KRorgJLzuaHSIYTmdiFT9kYxIQuqQti2pmcvUt/ulCV N6Ng== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:to:content-language:subject:user-agent:mime-version:date :message-id; bh=Mn8oBnryy/WfChPZxwZ4riSc3EW417cyTQgwfE/LBDE=; b=vpS0QWNV4l1zqfBv4YkubuoL2nU9YkYGP5ikzx5YPUFzitAYcLbIpSbA/cUJkw4RqP 0DXK58TNnoFb9zO/QlItzvPuj7DPvCz6L6i1tbsQACQOz7SVuQ/PMaPh+BvHyiGASL3N movAaaXaQIlW4mAmuQT8Y9ag5qSUcI+QqMOwoHRhUrXL+apbYBgzA7fjy7cSgqJQI936 WgS411QyhLyZj+tEXzce2J8QqG5mrWxh33HuZO7bAR649PPZL96i+WUuQLARLL0+i+1D ghlvT+NvvR7wmLWe8olI15xdpTkpV3UFN3xx0me8I7/38Q55Ioo5M1IU9fsdnCK3mSFc DacQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u6si12219678pfi.362.2022.01.17.03.07.58; Mon, 17 Jan 2022 03:08:13 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235700AbiAQCBZ (ORCPT + 99 others); Sun, 16 Jan 2022 21:01:25 -0500 Received: from twspam01.aspeedtech.com ([211.20.114.71]:62930 "EHLO twspam01.aspeedtech.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233986AbiAQCBZ (ORCPT ); Sun, 16 Jan 2022 21:01:25 -0500 Received: from mail.aspeedtech.com ([192.168.0.24]) by twspam01.aspeedtech.com with ESMTP id 20H1rPTO046430; Mon, 17 Jan 2022 09:53:25 +0800 (GMT-8) (envelope-from jammy_huang@aspeedtech.com) Received: from [192.168.2.115] (192.168.2.115) by TWMBX02.aspeed.com (192.168.0.24) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Mon, 17 Jan 2022 10:00:17 +0800 Message-ID: <609cfe9e-2fd8-b31a-9d71-b83d61693f84@aspeedtech.com> Date: Mon, 17 Jan 2022 09:59:58 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.4.1 Subject: Re: [PATCH v8 1/4] media: v4l: Add definition for the Aspeed JPEG format Content-Language: en-US To: Hans Verkuil , "sakari.ailus@linux.intel.com" , "gregkh@linuxfoundation.org" , "eajames@linux.ibm.com" , "mchehab@kernel.org" , "joel@jms.id.au" , "andrew@aj.id.au" , "linux-media@vger.kernel.org" , "openbmc@lists.ozlabs.org" , "linux-arm-kernel@lists.infradead.org" , "linux-aspeed@lists.ozlabs.org" , "linux-kernel@vger.kernel.org" References: <20211224012738.1551-1-jammy_huang@aspeedtech.com> <20211224012738.1551-2-jammy_huang@aspeedtech.com> <703ff71e-c76a-9df1-c644-04efed0199ca@xs4all.nl> From: Jammy Huang In-Reply-To: <703ff71e-c76a-9df1-c644-04efed0199ca@xs4all.nl> Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 8bit X-Originating-IP: [192.168.2.115] X-ClientProxiedBy: TWMBX02.aspeed.com (192.168.0.24) To TWMBX02.aspeed.com (192.168.0.24) X-DNSRBL: X-MAIL: twspam01.aspeedtech.com 20H1rPTO046430 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Hans, On 2022/1/14 下午 04:11, Hans Verkuil wrote: > On 24/12/2021 02:27, Jammy Huang wrote: >> This introduces support for the Aspeed JPEG format, where the new frame >> can refer to previous frame to reduce the amount of compressed data. The >> concept is similar to I/P frame of video compression. It will compare the >> new frame with previous one to decide which macroblock's data is >> changed, and only the changed macroblocks will be compressed. >> >> This Aspeed JPEG format is used by the video engine on Aspeed platforms, >> which is generally adapted for remote KVM. >> >> Signed-off-by: Jammy Huang >> --- >> v8: >> - Add decoder information for aspeed-jpeg >> v7: >> - Add more information for aspeed-jpeg >> v6: >> - Update description for new format, aspeed-jpeg, in Documentation. >> v5: >> - no update >> v4: >> - new >> --- >> .../media/uapi/v4l/pixfmt-reserved.rst | 17 +++++++++++++++++ >> drivers/media/v4l2-core/v4l2-ioctl.c | 1 + >> include/uapi/linux/videodev2.h | 1 + >> 3 files changed, 19 insertions(+) >> >> diff --git a/Documentation/media/uapi/v4l/pixfmt-reserved.rst b/Documentation/media/uapi/v4l/pixfmt-reserved.rst > This is the wrong file! It should be: > > Documentation/userspace-api/media/v4l/pixfmt-reserved.rst Thanks, I just used git format-patch to generate the cover-letter and didn't notice this. It looks like the file, pixfmt-reserved.rst, has different path in different Linux kernel, * 5.4:           Documentation/media/uapi/v4l/pixfmt-reserved.rst * 5.10/5.15: Documentation/userspace-api/media/v4l/pixfmt-reserved.rst 5.4 is the one I based to submit the patches. Could you suggest the kernel that I should based to submit these patches?? I will need to change the number of V4L2_CID_USER_ASPEED_BASE per different linux kernel as well. > > Regards, > > Hans > >> index b2cd155e691b..1d0dc8d86ed7 100644 >> --- a/Documentation/media/uapi/v4l/pixfmt-reserved.rst >> +++ b/Documentation/media/uapi/v4l/pixfmt-reserved.rst >> @@ -264,6 +264,23 @@ please make a proposal on the linux-media mailing list. >> of tiles, resulting in 32-aligned resolutions for the luminance plane >> and 16-aligned resolutions for the chrominance plane (with 2x2 >> subsampling). >> + * .. _V4L2-PIX-FMT-AJPG: >> + >> + - ``V4L2_PIX_FMT_AJPG`` >> + - 'AJPG' >> + - ASPEED JPEG format used by the aspeed-video driver on Aspeed platforms, >> + which is generally adapted for remote KVM. >> + On each frame compression, I will compare the new frame with previous >> + one to decide which macroblock's data is changed, and only the changed >> + macroblocks will be compressed. >> + >> + The implementation is based on AST2600 A3 datasheet, revision 0.9, which >> + is not publicly available. Or you can reference Video stream data format >> + – ASPEED mode compression of SDK_User_Guide which available on >> + AspeedTech-BMC/openbmc/releases. >> + >> + Decoder's implementation can be found here, >> + `https://github.com/AspeedTech-BMC/aspeed_codec/ `__ >> >> .. tabularcolumns:: |p{6.6cm}|p{2.2cm}|p{8.7cm}| >> >> diff --git a/drivers/media/v4l2-core/v4l2-ioctl.c b/drivers/media/v4l2-core/v4l2-ioctl.c >> index 24db33f803c0..00dde01d2f97 100644 >> --- a/drivers/media/v4l2-core/v4l2-ioctl.c >> +++ b/drivers/media/v4l2-core/v4l2-ioctl.c >> @@ -1378,6 +1378,7 @@ static void v4l_fill_fmtdesc(struct v4l2_fmtdesc *fmt) >> case V4L2_PIX_FMT_S5C_UYVY_JPG: descr = "S5C73MX interleaved UYVY/JPEG"; break; >> case V4L2_PIX_FMT_MT21C: descr = "Mediatek Compressed Format"; break; >> case V4L2_PIX_FMT_SUNXI_TILED_NV12: descr = "Sunxi Tiled NV12 Format"; break; >> + case V4L2_PIX_FMT_AJPG: descr = "Aspeed JPEG"; break; >> default: >> if (fmt->description[0]) >> return; >> diff --git a/include/uapi/linux/videodev2.h b/include/uapi/linux/videodev2.h >> index 3210b3c82a4a..994eb6155ea9 100644 >> --- a/include/uapi/linux/videodev2.h >> +++ b/include/uapi/linux/videodev2.h >> @@ -726,6 +726,7 @@ struct v4l2_pix_format { >> #define V4L2_PIX_FMT_INZI v4l2_fourcc('I', 'N', 'Z', 'I') /* Intel Planar Greyscale 10-bit and Depth 16-bit */ >> #define V4L2_PIX_FMT_SUNXI_TILED_NV12 v4l2_fourcc('S', 'T', '1', '2') /* Sunxi Tiled NV12 Format */ >> #define V4L2_PIX_FMT_CNF4 v4l2_fourcc('C', 'N', 'F', '4') /* Intel 4-bit packed depth confidence information */ >> +#define V4L2_PIX_FMT_AJPG v4l2_fourcc('A', 'J', 'P', 'G') /* Aspeed JPEG */ >> >> /* 10bit raw bayer packed, 32 bytes for every 25 pixels, last LSB 6 bits unused */ >> #define V4L2_PIX_FMT_IPU3_SBGGR10 v4l2_fourcc('i', 'p', '3', 'b') /* IPU3 packed 10-bit BGGR bayer */ -- Best Regards Jammy