mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-06 02:50:49 +09:00
BACKPORT: media: v4l2-ctrl: Add frame-specific min/max qp controls for hevc
- Adds min/max qp controls for B frame for h264.
- Adds min/max qp controls for I/P/B frames for hevc similar to h264.
- Update valid range of min/max qp for hevc to accommodate 10 bit.
Signed-off-by: Dikshita Agarwal <dikshita@codeaurora.org>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
(cherry picked from commit 99d0cbe4be)
Bug: 175376073
Link: https://lkml.org/lkml/2020/12/24/139
[dikshita : Original change has multiple dependencies, hence
needs manual modifications to pick up the change in
simplified way]
Change-Id: Ifb70c13b23311623d2bf79383adeca0ec0686922
Signed-off-by: Dikshita Agarwal <dikshita@codeaurora.org>
This commit is contained in:
committed by
Alistair Delva
parent
04dc43bd98
commit
ee1fdcb814
@@ -1182,6 +1182,18 @@ enum v4l2_mpeg_video_h264_entropy_mode -
|
||||
V4L2_CID_MPEG_VIDEO_H264_MAX_QP is also set, the quantization parameter
|
||||
should be chosen to meet both requirements.
|
||||
|
||||
``V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MIN_QP (integer)``
|
||||
Minimum quantization parameter for the H264 B frame to limit B frame
|
||||
quality to a range. Valid range: from 0 to 51. If
|
||||
V4L2_CID_MPEG_VIDEO_H264_MIN_QP is also set, the quantization parameter
|
||||
should be chosen to meet both requirements.
|
||||
|
||||
``V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MAX_QP (integer)``
|
||||
Maximum quantization parameter for the H264 B frame to limit B frame
|
||||
quality to a range. Valid range: from 0 to 51. If
|
||||
V4L2_CID_MPEG_VIDEO_H264_MAX_QP is also set, the quantization parameter
|
||||
should be chosen to meet both requirements.
|
||||
|
||||
``V4L2_CID_MPEG_VIDEO_MPEG4_I_FRAME_QP (integer)``
|
||||
Quantization parameter for an I frame for MPEG4. Valid range: from 1
|
||||
to 31.
|
||||
@@ -3441,11 +3453,11 @@ HEVC/H.265 Control IDs
|
||||
|
||||
``V4L2_CID_MPEG_VIDEO_HEVC_MIN_QP (integer)``
|
||||
Minimum quantization parameter for HEVC.
|
||||
Valid range: from 0 to 51.
|
||||
Valid range: from 0 to 51 for 8 bit and from 0 to 63 for 10 bit.
|
||||
|
||||
``V4L2_CID_MPEG_VIDEO_HEVC_MAX_QP (integer)``
|
||||
Maximum quantization parameter for HEVC.
|
||||
Valid range: from 0 to 51.
|
||||
Valid range: from 0 to 51 for 8 bit and from 0 to 63 for 10 bit.
|
||||
|
||||
``V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_QP (integer)``
|
||||
Quantization parameter for an I frame for HEVC.
|
||||
@@ -3462,6 +3474,42 @@ HEVC/H.265 Control IDs
|
||||
Valid range: [V4L2_CID_MPEG_VIDEO_HEVC_MIN_QP,
|
||||
V4L2_CID_MPEG_VIDEO_HEVC_MAX_QP].
|
||||
|
||||
``V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MIN_QP (integer)``
|
||||
Minimum quantization parameter for the HEVC I frame to limit I frame
|
||||
quality to a range. Valid range: from 0 to 51 for 8 bit and from 0 to 63 for 10 bit.
|
||||
If V4L2_CID_MPEG_VIDEO_HEVC_MIN_QP is also set, the quantization parameter
|
||||
should be chosen to meet both requirements.
|
||||
|
||||
``V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MAX_QP (integer)``
|
||||
Maximum quantization parameter for the HEVC I frame to limit I frame
|
||||
quality to a range. Valid range: from 0 to 51 for 8 bit and from 0 to 63 for 10 bit.
|
||||
If V4L2_CID_MPEG_VIDEO_HEVC_MAX_QP is also set, the quantization parameter
|
||||
should be chosen to meet both requirements.
|
||||
|
||||
``V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MIN_QP (integer)``
|
||||
Minimum quantization parameter for the HEVC P frame to limit P frame
|
||||
quality to a range. Valid range: from 0 to 51 for 8 bit and from 0 to 63 for 10 bit.
|
||||
If V4L2_CID_MPEG_VIDEO_HEVC_MIN_QP is also set, the quantization parameter
|
||||
should be chosen to meet both requirements.
|
||||
|
||||
``V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MAX_QP (integer)``
|
||||
Maximum quantization parameter for the HEVC P frame to limit P frame
|
||||
quality to a range. Valid range: from 0 to 51 for 8 bit and from 0 to 63 for 10 bit.
|
||||
If V4L2_CID_MPEG_VIDEO_HEVC_MAX_QP is also set, the quantization parameter
|
||||
should be chosen to meet both requirements.
|
||||
|
||||
``V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MIN_QP (integer)``
|
||||
Minimum quantization parameter for the HEVC B frame to limit B frame
|
||||
quality to a range. Valid range: from 0 to 51 for 8 bit and from 0 to 63 for 10 bit.
|
||||
If V4L2_CID_MPEG_VIDEO_HEVC_MIN_QP is also set, the quantization parameter
|
||||
should be chosen to meet both requirements.
|
||||
|
||||
``V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MAX_QP (integer)``
|
||||
Maximum quantization parameter for the HEVC B frame to limit B frame
|
||||
quality to a range. Valid range: from 0 to 51 for 8 bit and from 0 to 63 for 10 bit.
|
||||
If V4L2_CID_MPEG_VIDEO_HEVC_MAX_QP is also set, the quantization parameter
|
||||
should be chosen to meet both requirements.
|
||||
|
||||
``V4L2_CID_MPEG_VIDEO_HEVC_HIER_QP (boolean)``
|
||||
HIERARCHICAL_QP allows the host to specify the quantization parameter
|
||||
values for each temporal layer through HIERARCHICAL_QP_LAYER. This is
|
||||
|
||||
@@ -920,6 +920,8 @@ const char *v4l2_ctrl_get_name(u32 id)
|
||||
case V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MAX_QP: return "H264 I-Frame Maximum QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MIN_QP: return "H264 P-Frame Minimum QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MAX_QP: return "H264 P-Frame Maximum QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MIN_QP: return "H264 B-Frame Minimum QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MAX_QP: return "H264 B-Frame Maximum QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_H264_SPS: return "H264 Sequence Parameter Set";
|
||||
case V4L2_CID_MPEG_VIDEO_H264_PPS: return "H264 Picture Parameter Set";
|
||||
case V4L2_CID_MPEG_VIDEO_H264_SCALING_MATRIX: return "H264 Scaling Matrix";
|
||||
@@ -978,6 +980,12 @@ const char *v4l2_ctrl_get_name(u32 id)
|
||||
case V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_QP: return "HEVC B-Frame QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_HEVC_MIN_QP: return "HEVC Minimum QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_HEVC_MAX_QP: return "HEVC Maximum QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MIN_QP: return "HEVC I-Frame Minimum QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MAX_QP: return "HEVC I-Frame Maximum QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MIN_QP: return "HEVC P-Frame Minimum QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MAX_QP: return "HEVC P-Frame Maximum QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MIN_QP: return "HEVC B-Frame Minimum QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MAX_QP: return "HEVC B-Frame Maximum QP Value";
|
||||
case V4L2_CID_MPEG_VIDEO_HEVC_PROFILE: return "HEVC Profile";
|
||||
case V4L2_CID_MPEG_VIDEO_HEVC_LEVEL: return "HEVC Level";
|
||||
case V4L2_CID_MPEG_VIDEO_HEVC_TIER: return "HEVC Tier";
|
||||
|
||||
@@ -578,6 +578,8 @@ enum v4l2_mpeg_video_h264_hierarchical_coding_type {
|
||||
#define V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MAX_QP (V4L2_CID_MPEG_BASE+386)
|
||||
#define V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MIN_QP (V4L2_CID_MPEG_BASE+387)
|
||||
#define V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MAX_QP (V4L2_CID_MPEG_BASE+388)
|
||||
#define V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MIN_QP (V4L2_CID_MPEG_BASE+389)
|
||||
#define V4L2_CID_MPEG_VIDEO_H264_B_FRAME_MAX_QP (V4L2_CID_MPEG_BASE+390)
|
||||
#define V4L2_CID_MPEG_VIDEO_MPEG4_I_FRAME_QP (V4L2_CID_MPEG_BASE+400)
|
||||
#define V4L2_CID_MPEG_VIDEO_MPEG4_P_FRAME_QP (V4L2_CID_MPEG_BASE+401)
|
||||
#define V4L2_CID_MPEG_VIDEO_MPEG4_B_FRAME_QP (V4L2_CID_MPEG_BASE+402)
|
||||
@@ -768,6 +770,13 @@ enum v4l2_mpeg_video_frame_skip_mode {
|
||||
V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT = 2,
|
||||
};
|
||||
|
||||
#define V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MIN_QP (V4L2_CID_MPEG_BASE + 647)
|
||||
#define V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_MAX_QP (V4L2_CID_MPEG_BASE + 648)
|
||||
#define V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MIN_QP (V4L2_CID_MPEG_BASE + 649)
|
||||
#define V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_MAX_QP (V4L2_CID_MPEG_BASE + 650)
|
||||
#define V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MIN_QP (V4L2_CID_MPEG_BASE + 651)
|
||||
#define V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_MAX_QP (V4L2_CID_MPEG_BASE + 652)
|
||||
|
||||
/* MPEG-class control IDs specific to the CX2341x driver as defined by V4L2 */
|
||||
#define V4L2_CID_MPEG_CX2341X_BASE (V4L2_CTRL_CLASS_MPEG | 0x1000)
|
||||
#define V4L2_CID_MPEG_CX2341X_VIDEO_SPATIAL_FILTER_MODE (V4L2_CID_MPEG_CX2341X_BASE+0)
|
||||
|
||||
Reference in New Issue
Block a user