[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <6b8004e2-57df-4760-a59d-77a712e9ca4d@xs4all.nl>
Date: Mon, 28 Oct 2024 08:57:32 +0100
From: Hans Verkuil <hverkuil-cisco@...all.nl>
To: Ming Qian <ming.qian@....com>, mchehab@...nel.org
Cc: yunkec@...gle.com, nicolas@...fresne.ca, s.hauer@...gutronix.de,
kernel@...gutronix.de, festevam@...il.com, linux-imx@....com,
xiahong.bao@....com, ming.zhou@....com, eagle.zhou@....com,
tao.jiang_2@....com, ming.qian@....nxp.com, imx@...ts.linux.dev,
linux-media@...r.kernel.org, linux-kernel@...r.kernel.org,
linux-arm-kernel@...ts.infradead.org
Subject: Re: [RFC v3 0/4] Add video encoder ROI ctrls
On 22/10/2024 10:40, Ming Qian wrote:
> Hi,
>
> This patch set implements region of interest (ROI) ctrls for video
> encoder.
>
> One video encoder IP may support the following two ROI configurations or
> one of them:
> 1. configure ROI as a rectangular region, and set a delta QP parameter.
> 2. configure ROI as a rectangular region, and set a priority parameter.
> 3. configure ROI as a QP map as an array. Each value represents the delta QP
> of a block in raster scan order. The block size is determined by
> the specific IP.
> 4. configure ROI as a QP map as an array. Each value represents the absolute QP
> of a block in raster scan order. The block size is determined by
> the specific IP.
>
> To achieve this, I made the following change:
> 1. I reuse the type V4L2_CTRL_TYPE_RECT that is defined in the UVC ROI patchset
> 2. Define a ctrl V4L2_CID_MPEG_VIDEO_ROI_MODE to choose ROI configuration
> 3. Define some ctrl to configure ROI
> 4. Define a ctrl V4L2_CID_MPEG_VIDEO_ROI_BLOCK_SIZE to query block size
>
> I referred the patchset "Implement UVC v1.5 ROI" (https://lwn.net/Articles/953532/)
> and pick some patches from it.
Please note that since this introduces the new TYPE_RECT and WHICH_MIN/MAX flags,
you also need to update v4l-utils.
This was done last year:
https://lore.kernel.org/linux-media/20230817072537.2837504-1-yunkec@google.com/
Can you pick this up and post a v2 for these v4l-utils changes? Note that I had some
comments at the time, so please fix those before posting v2.
Regards,
Hans
>
> changelog:
>
> v3
> - Drop the type V4L2_CTRL_TYPE_REGION
> - Split the compound control into 2 ctrls
> - Define 4 ROI mode
>
> v2
> - export symbol of v4l2_ctrl_type_op_minimum
> - export symbol of v4l2_ctrl_type_op_maximum
>
> Hans Verkuil (1):
> media: v4l2-ctrls: add support for V4L2_CTRL_WHICH_MIN/MAX_VAL
>
> Ming Qian (1):
> media: v4l2-ctrls: Add video encoder ROI ctrls
>
> Yunke Cao (2):
> media: v4l2_ctrl: Add V4L2_CTRL_TYPE_RECT
> media: vivid: Add an rectangle control
>
> .../media/v4l/ext-ctrls-codec.rst | 95 ++++++++++
> .../media/v4l/vidioc-g-ext-ctrls.rst | 26 ++-
> .../media/v4l/vidioc-queryctrl.rst | 14 ++
> .../media/videodev2.h.rst.exceptions | 4 +
> drivers/media/i2c/imx214.c | 4 +-
> .../media/platform/qcom/venus/venc_ctrls.c | 9 +-
> .../media/test-drivers/vivid/vivid-ctrls.c | 34 ++++
> drivers/media/v4l2-core/v4l2-ctrls-api.c | 54 ++++--
> drivers/media/v4l2-core/v4l2-ctrls-core.c | 169 +++++++++++++++---
> drivers/media/v4l2-core/v4l2-ctrls-defs.c | 46 +++++
> drivers/media/v4l2-core/v4l2-ioctl.c | 4 +-
> include/media/v4l2-ctrls.h | 62 ++++++-
> include/uapi/linux/v4l2-controls.h | 16 ++
> include/uapi/linux/videodev2.h | 5 +
> 14 files changed, 493 insertions(+), 49 deletions(-)
>
Powered by blists - more mailing lists