From: Nicolas Dufresne <nicolas@ndufresne.ca>
To: Detlev Casanova <detlev.casanova@collabora.com>,
linux-kernel@vger.kernel.org
Cc: Rob Herring <robh@kernel.org>,
Krzysztof Kozlowski <krzk+dt@kernel.org>,
Conor Dooley <conor+dt@kernel.org>,
Heiko Stuebner <heiko@sntech.de>,
Sebastian Reichel <sebastian.reichel@collabora.com>,
Cristian Ciocaltea <cristian.ciocaltea@collabora.com>,
Alexey Charkov <alchark@gmail.com>,
Dragan Simic <dsimic@manjaro.org>,
Jianfeng Liu <liujianfeng1994@gmail.com>,
Nicolas Frattaroli <nicolas.frattaroli@collabora.com>,
Kever Yang <kever.yang@rock-chips.com>,
Andy Yan <andy.yan@rock-chips.com>,
Frank Wang <frank.wang@rock-chips.com>,
devicetree@vger.kernel.org,
linux-arm-kernel@lists.infradead.org,
linux-rockchip@lists.infradead.org,
Ezequiel Garcia <ezequiel@vanguardiasur.com.ar>,
Mauro Carvalho Chehab <mchehab@kernel.org>,
Hans Verkuil <hverkuil@xs4all.nl>,
Ricardo Ribalda <ribalda@chromium.org>,
Hans de Goede <hansg@kernel.org>, Yunke Cao <yunkec@google.com>,
linux-media@vger.kernel.org, kernel@collabora.com
Subject: Re: [PATCH 5/8] media: uapi: HEVC: Add v4l2_ctrl_hevc_ext_sps_rps control
Date: Fri, 11 Jul 2025 15:59:01 -0400 [thread overview]
Message-ID: <9f4a00b3a0b6491b1f50c878cb18569009a4441e.camel@ndufresne.ca> (raw)
In-Reply-To: <20250623160722.55938-6-detlev.casanova@collabora.com>
[-- Attachment #1: Type: text/plain, Size: 5949 bytes --]
Hi,
Le lundi 23 juin 2025 à 12:07 -0400, Detlev Casanova a écrit :
> Some hardware (e.g.: Rockchip's rk3588 hevc decoder) need the parsed
> long and short term reference information for HEVC decoding.
>
> Signed-off-by: Detlev Casanova <detlev.casanova@collabora.com>
> ---
> .../media/v4l/ext-ctrls-codec-stateless.rst | 73 +++++++++++++++++++
> .../media/v4l/vidioc-queryctrl.rst | 6 ++
> 2 files changed, 79 insertions(+)
>
> diff --git a/Documentation/userspace-api/media/v4l/ext-ctrls-codec-stateless.rst b/Documentation/userspace-api/media/v4l/ext-ctrls-codec-stateless.rst
> index 0da635691fdcb..745f38a8fe69c 100644
> --- a/Documentation/userspace-api/media/v4l/ext-ctrls-codec-stateless.rst
> +++ b/Documentation/userspace-api/media/v4l/ext-ctrls-codec-stateless.rst
> @@ -2958,6 +2958,79 @@ This structure contains all loop filter related parameters. See sections
> - 0x00000004
> -
>
> +.. c:type:: v4l2_ctrl_hevc_ext_sps_rps
> +
> +.. cssclass:: longtable
> +
> +.. flat-table:: struct v4l2_ctrl_hevc_ext_sps_rps
> + :header-rows: 0
> + :stub-columns: 0
> + :widths: 1 1 2
Something, somewhere should say this is an array.
> +
> + * - __u16
> + - ``lt_ref_pic_poc_lsb_sps``
> + - Long term reference picture order count as described in section 7.4.3.2.1
> + "General sequence parameter set RBSP semantics" of the specification.
Each LONG term reference have one of these.
> + * - __u8
> + - ``delta_idx_minus1``
> + - Specifies the delta compare to the index. See details in section 7.4.8 "Short-term
> + reference picture set semantics" of the specification.
And each SHORT term have one of these. How can both be int he same control ? For
me this could make a bit more sense with two structures:
v4l2_ctrl_hevc_ext_sps_st_rps[]
v4l2_ctrl_hevc_ext_sps_lt_rps[]
Did I miss something ?
> + * - __u8
> + - ``delta_rps_sign``
> + - Sign of the delta as specified in section 7.4.8 "Short-term reference picture set
> + semantics" of the specification.
> + * - __u16
> + - ``abs_delta_rps_minus1``
> + - Absolute delta RPS as specified in section 7.4.8 "Short-term reference picture set
> + semantics" of the specification.
> + * - __u8
> + - ``num_negative_pics``
> + - Number of short-term RPS entries that have picture order count values less than the
> + picture order count value of the current picture.
> + * - __u8
> + - ``num_positive_pics``
> + - Number of short-term RPS entries that have picture order count values greater than the
> + picture order count value of the current picture.
> + * - __u8
> + - ``used_by_curr_pic_s0[16]``
> + - Specifies if short-term RPS i (that has a negative POC) is used by the current picture.
Use bit field for that, a __u16 works, and one per ST.
>
> + * - __u8
> + - ``used_by_curr_pic_s1[16]``
> + - Specifies if short-term RPS i (that has a positive POC) is used by the current picture.
>
Same.
> + * - __s32
> + - ``delta_poc_s0[16]``
> + - Specifies the negative picture order count delta for the i-th entry in the short-term RPS.
> + See details in section 7.4.8 "Short-term reference picture set semantics" of the
> + specification.
Keep it delta_poc_s0_minus1 like int he spec, and then you can go back so u16.
> + * - __s32
> + - ``delta_poc_s1[16]``
> + - Specifies the positive picture order count delta for the i-th entry in the short-term RPS.
> + See details in section 7.4.8 "Short-term reference picture set semantics" of the
> + specification.
Same.
regards,
Nicolas
> + * - __u8
> + - ``flags``
> + - See :ref:`Extended RPS Flags <hevc_ext_sps_rps_flags>`
> +
> +.. _hevc_ext_sps_rps_flags:
> +
> +``Extended SPS RPS Flags``
> +
> +.. cssclass:: longtable
> +
> +.. flat-table::
> + :header-rows: 0
> + :stub-columns: 0
> + :widths: 1 1 2
> +
> + * - ``V4L2_HEVC_EXT_SPS_RPS_FLAG_USED_LT``
> + - 0x00000001
> + - Specifies if the long-term reference picture is used 7.4.3.2.1 "General sequence parameter
> + set RBSP semantics" of the specification.
> + * - ``V4L2_HEVC_EXT_SPS_RPS_FLAG_INTER_REF_PIC_SET_PRED``
> + - 0x00000002
> + - Specifies if the short-term RPS is predicted from another short term RPS. See details in
> + section 7.4.8 "Short-term reference picture set semantics" of the specification.
> +
> .. _v4l2-codec-stateless-av1:
>
> ``V4L2_CID_STATELESS_AV1_SEQUENCE (struct)``
> diff --git a/Documentation/userspace-api/media/v4l/vidioc-queryctrl.rst b/Documentation/userspace-api/media/v4l/vidioc-queryctrl.rst
> index 3549417c7febb..dc7caf4bf6208 100644
> --- a/Documentation/userspace-api/media/v4l/vidioc-queryctrl.rst
> +++ b/Documentation/userspace-api/media/v4l/vidioc-queryctrl.rst
> @@ -523,6 +523,12 @@ See also the examples in :ref:`control`.
> - n/a
> - A struct :c:type:`v4l2_ctrl_hevc_decode_params`, containing HEVC
> decoding parameters for stateless video decoders.
> + * - ``V4L2_CTRL_TYPE_HEVC_EXT_SPS_RPS``
> + - n/a
> + - n/a
> + - n/a
> + - A struct :c:type:`v4l2_ctrl_hevc_ext_sps_rps`, containing HEVC
> + extended RPS for stateless video decoders.
> * - ``V4L2_CTRL_TYPE_VP9_COMPRESSED_HDR``
> - n/a
> - n/a
[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 228 bytes --]
next prev parent reply other threads:[~2025-07-11 19:59 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-06-23 16:07 [PATCH 0/8] Prepare for new rkvdec variants Detlev Casanova
2025-06-23 16:07 ` [PATCH 1/8] media: dt-bindings: rockchip: Document RK3588 Video Decoder bindings Detlev Casanova
2025-06-23 16:07 ` [PATCH 2/8] media: dt-bindings: rockchip: Add RK3576 " Detlev Casanova
2025-06-27 20:23 ` Rob Herring (Arm)
2025-06-23 16:07 ` [PATCH 3/8] arm64: dts: rockchip: Add the vdpu381 Video Decoders on RK3588 Detlev Casanova
2025-06-23 16:07 ` [PATCH 4/8] arm64: dts: rockchip: Add the vdpu383 Video Decoder on rk3576 Detlev Casanova
2025-06-23 16:07 ` [PATCH 5/8] media: uapi: HEVC: Add v4l2_ctrl_hevc_ext_sps_rps control Detlev Casanova
2025-07-11 19:59 ` Nicolas Dufresne [this message]
2025-06-23 16:07 ` [PATCH 6/8] media: v4l2-ctrls: Add hevc_ext_sps_rps control Detlev Casanova
2025-06-23 16:07 ` [PATCH 7/8] media: rkvdec: Remove TODO file Detlev Casanova
2025-07-11 20:00 ` Nicolas Dufresne
2025-06-23 16:07 ` [PATCH 8/8] media: rkvdec: Unstage the driver Detlev Casanova
2025-07-11 20:02 ` Nicolas Dufresne
2025-07-15 8:34 ` Diederik de Haas
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=9f4a00b3a0b6491b1f50c878cb18569009a4441e.camel@ndufresne.ca \
--to=nicolas@ndufresne.ca \
--cc=alchark@gmail.com \
--cc=andy.yan@rock-chips.com \
--cc=conor+dt@kernel.org \
--cc=cristian.ciocaltea@collabora.com \
--cc=detlev.casanova@collabora.com \
--cc=devicetree@vger.kernel.org \
--cc=dsimic@manjaro.org \
--cc=ezequiel@vanguardiasur.com.ar \
--cc=frank.wang@rock-chips.com \
--cc=hansg@kernel.org \
--cc=heiko@sntech.de \
--cc=hverkuil@xs4all.nl \
--cc=kernel@collabora.com \
--cc=kever.yang@rock-chips.com \
--cc=krzk+dt@kernel.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-media@vger.kernel.org \
--cc=linux-rockchip@lists.infradead.org \
--cc=liujianfeng1994@gmail.com \
--cc=mchehab@kernel.org \
--cc=nicolas.frattaroli@collabora.com \
--cc=ribalda@chromium.org \
--cc=robh@kernel.org \
--cc=sebastian.reichel@collabora.com \
--cc=yunkec@google.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).