Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp2963278pxb; Mon, 17 Jan 2022 09:05:21 -0800 (PST) X-Google-Smtp-Source: ABdhPJzXFX9Fa7Mx7K3EfUIR0L8Cdg349xp0Zbz+FrimjlBAzoJMIek8XSppwcLP3BWUU9ib73h5 X-Received: by 2002:a63:3d8e:: with SMTP id k136mr19551966pga.262.1642439121363; Mon, 17 Jan 2022 09:05:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642439121; cv=none; d=google.com; s=arc-20160816; b=OMMWqo/tTi0N4YKlYBbHPITZ4lSlrT5zF9isXos0Sfq1ymvLFf0z6z0nYl/sfgqwp7 YUN19AYVMqNUW+WUe1MlVWSUWYW6Pdq2msYr7rpeNy2eKEOzeWNNN7shAVRITYvHL3iS 94M7HYZYJZZ88hwjd0juOVVLtaeGzCT8m+PRu2t225iqY5hAop6YlVcNDtBzuZLfBXed A5MRVaRVKEeSZhmPqzp11BPvjZLzy+oHFOoPwwfck3959S58IsHNYdjY7inFEbChOZ6p 5zoalBRJ+Fdnm0MT6AKJzfdC+KkSjBX4kTVL7QKdVZD0INb3l4PUPWgRCXkNSh+5mGO/ mC2w== 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:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=is7sVZkcR/8KQO+WXWjDY41wXST8oqKp06vTCB6SOr0=; b=rsaYesgVFNxIU4FN5lPmWG9oHCEeX1Qu8XALV089OTgYMoT3s+Zx//vXkLG9wA8+XZ QnaUEFg2A9VuMl2HNyCy5VtpS8ZS4gOPbQ59dnWer2lt5g2EuCR/qolmJSI8oJ28cBhC O03/9x/IbetEuq4/kRaqZbnrzQt4IYE6ZSjfopVPjthFWXVKjcOfR/Qa6dbjd3DjhDzG K28fbtE4y7F5J4dcFwcaLN3PaAdCMhMtC83AoqAjZm3gfLEawYHQXo2fOVb6OlUVlHK3 F0xNgPhevN4wmEARefTpDbYkdH8Y89q/FJ7KhlDTkRwQBv8LRyIlpjTFXp1uUJ6na9t5 UTLw== 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 np2si14459947pjb.173.2022.01.17.09.05.09; Mon, 17 Jan 2022 09:05:21 -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 S235939AbiAQJia (ORCPT + 99 others); Mon, 17 Jan 2022 04:38:30 -0500 Received: from twspam01.aspeedtech.com ([211.20.114.71]:52175 "EHLO twspam01.aspeedtech.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235812AbiAQJi3 (ORCPT ); Mon, 17 Jan 2022 04:38:29 -0500 Received: from mail.aspeedtech.com ([192.168.0.24]) by twspam01.aspeedtech.com with ESMTP id 20H9UkAT086347; Mon, 17 Jan 2022 17:30:46 +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 17:37:40 +0800 Message-ID: Date: Mon, 17 Jan 2022 17:37:41 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.5.0 Subject: Re: [PATCH v8 1/4] media: v4l: Add definition for the Aspeed JPEG format Content-Language: en-US To: Hans Verkuil , Joel Stanley CC: "sakari.ailus@linux.intel.com" , "gregkh@linuxfoundation.org" , "eajames@linux.ibm.com" , "mchehab@kernel.org" , "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> <609cfe9e-2fd8-b31a-9d71-b83d61693f84@aspeedtech.com> <98096e97-68cc-18fd-d2b6-3477f57f05bd@aspeedtech.com> From: Jammy Huang In-Reply-To: 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 20H9UkAT086347 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Hans, On 2022/1/17 下午 05:28, Hans Verkuil wrote: > Hi Jammy, > > On 1/17/22 08:18, Jammy Huang wrote: >> On 2022/1/17 上午 10:24, Joel Stanley wrote: >>> On Mon, 17 Jan 2022 at 02:00, Jammy Huang wrote: >>>> 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?? >>> You should always submit based on the latest release. >>> >>> There are sometimes exceptions where you will base your patches on >>> something even newer, but generally you should grab the latest. >>> >>> Be sure to re-test on the latest kernel before submitting. >> OK, thank you. > I recommend waiting until later this week. I hope to have a PR for other outstanding > aspeed patches ready in a few days. It is easiest if you base your v9 on top of that > series, this to avoid merge conflicts. Sure, no problem. Thanks for your help. Regards, Jammy > > Regards, > > Hans > >>> Cheers, >>> >>> Joel >>> >>>> 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 >>>>