Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp684325pxu; Mon, 23 Nov 2020 01:04:06 -0800 (PST) X-Google-Smtp-Source: ABdhPJzgn2SL0OoTkLgfcw1tbuAHiQnCzYJJ/apK89JDnbecuwBCsSK7Tg6CmF4sx62BTAbFOd7T X-Received: by 2002:a17:906:cd0f:: with SMTP id oz15mr43634814ejb.228.1606122246701; Mon, 23 Nov 2020 01:04:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1606122246; cv=none; d=google.com; s=arc-20160816; b=fXv9iRX3RcORVb2Z9x2KZwgrubwf9iV1+iNIUYwpSZRJCBPPQu3dJsmKejVMTY3mwW DggQQcuWFiepgSsbyceKVw3iQPwK1BCKDZCMMPGpPmcoUfm+WgNrQsTHECRb6g9Wciyr kwyPtf1Jy4FKOB+jLC3WUAtWZ8A3iwYlPu0o47Ksi362Jz7l4unYqukRzKZlhes0EQgI d78CvEysU8IMMBdVX/jbEkYO/peX8bE1ff4wBEelf5o5j2y/DYm920NOCTd/mI0Wm5HX //uZEYzRHx7/4XXJtbN6CovRyNTUK8o+ET3POqPyZhVTnFTRcpMTa1ccgpELAgBEX9bf tTqg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from; bh=ctOFl5Q3wds5u3YkWbtQsoWMCoZUE6aVL2AbfqW9VGo=; b=w0FzATIasIhy38Za3l1pbkpXPnEp9G/2DLWEOAOpu6D3CtXF5fOteFD+/v2c825xBT sCs/k9fRDp65lPK3MKq6znp7nax4nh08oDT9JPWJku4eEfwQBN2sYrNC8iWSan00S7pF /rhXrWfLA55LuXwKHE5Qqxjhoz39Ifs5+WRXxema4g4BPAA4AHZweEQiFmlhXtC9prtl U8l1WoCzlAW+ZjTR5i9gki5rgQyRZcvUqJdyaewCru3IM3QgdPsd8EhohxYPWpSdHIgF jX1naTEPa8aPYlKO/cLOgqQQxdg0T8ectee4bx1ppOZi8ZvhvsDdz3dZaPxiUKlRToyQ 01HQ== 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 e18si6065409eje.132.2020.11.23.01.03.43; Mon, 23 Nov 2020 01:04:06 -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 S1726326AbgKWIvN (ORCPT + 99 others); Mon, 23 Nov 2020 03:51:13 -0500 Received: from alexa-out.qualcomm.com ([129.46.98.28]:21293 "EHLO alexa-out.qualcomm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725275AbgKWIvN (ORCPT ); Mon, 23 Nov 2020 03:51:13 -0500 Received: from ironmsg08-lv.qualcomm.com ([10.47.202.152]) by alexa-out.qualcomm.com with ESMTP; 23 Nov 2020 00:51:12 -0800 X-QCInternal: smtphost Received: from ironmsg02-blr.qualcomm.com ([10.86.208.131]) by ironmsg08-lv.qualcomm.com with ESMTP/TLS/AES256-SHA; 23 Nov 2020 00:51:11 -0800 X-QCInternal: smtphost Received: from dikshita-linux.qualcomm.com ([10.204.65.237]) by ironmsg02-blr.qualcomm.com with ESMTP; 23 Nov 2020 14:20:57 +0530 Received: by dikshita-linux.qualcomm.com (Postfix, from userid 347544) id 0020B21220; Mon, 23 Nov 2020 14:20:55 +0530 (IST) From: Dikshita Agarwal To: linux-media@vger.kernel.org, hverkuil-cisco@xs4all.nl, nicolas@ndufresne.ca, stanimir.varbanov@linaro.org Cc: linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, vgarodia@codeaurora.org, Dikshita Agarwal Subject: [PATCH v3] media: v4l2-ctrl: Add base layer priority id control. Date: Mon, 23 Nov 2020 14:20:42 +0530 Message-Id: <1606121442-31074-1-git-send-email-dikshita@codeaurora.org> X-Mailer: git-send-email 2.7.4 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This control indicates the priority id to be applied to base layer. Signed-off-by: Dikshita Agarwal --- Documentation/userspace-api/media/v4l/ext-ctrls-codec.rst | 9 +++++++++ drivers/media/v4l2-core/v4l2-ctrls.c | 1 + include/uapi/linux/v4l2-controls.h | 1 + 3 files changed, 11 insertions(+) diff --git a/Documentation/userspace-api/media/v4l/ext-ctrls-codec.rst b/Documentation/userspace-api/media/v4l/ext-ctrls-codec.rst index 22222ce..a518d4f 100644 --- a/Documentation/userspace-api/media/v4l/ext-ctrls-codec.rst +++ b/Documentation/userspace-api/media/v4l/ext-ctrls-codec.rst @@ -4467,3 +4467,12 @@ enum v4l2_mpeg_video_hevc_size_of_length_field - This provides a bitmask which consists of bits [0, LTR_COUNT-1]. This is applicable to H264 and HEVC encoder and can be applied using Request Api. + +``V4L2_CID_MPEG_VIDEO_BASELAYER_PRIORITY_ID (integer)`` + Specifies a priority identifier for the NAL unit, which will be applied to + the base layer. By default this value is set to 0 for the base layer, + and the next layer will have the priority ID assigned as 1, 2, 3 and so on. + The video encoder can't decide the priority id to be applied to a layer, + so this has to come from client. + This is applicable to H264 and valid Range is from 0 to 63. + Source Rec. ITU-T H.264 (06/2019); G.7.4.1.1, G.8.8.1 diff --git a/drivers/media/v4l2-core/v4l2-ctrls.c b/drivers/media/v4l2-core/v4l2-ctrls.c index 0b81b39..799ab85 100644 --- a/drivers/media/v4l2-core/v4l2-ctrls.c +++ b/drivers/media/v4l2-core/v4l2-ctrls.c @@ -961,6 +961,7 @@ const char *v4l2_ctrl_get_name(u32 id) case V4L2_CID_MPEG_VIDEO_LTR_COUNT: return "LTR Count"; case V4L2_CID_MPEG_VIDEO_FRAME_LTR_INDEX: return "frame LTR index"; case V4L2_CID_MPEG_VIDEO_USE_LTR_FRAMES: return "Use LTR Frame(s)"; + case V4L2_CID_MPEG_VIDEO_BASELAYER_PRIORITY_ID: return "Base Layer Priority ID"; case V4L2_CID_MPEG_VIDEO_MPEG2_SLICE_PARAMS: return "MPEG-2 Slice Parameters"; case V4L2_CID_MPEG_VIDEO_MPEG2_QUANTIZATION: return "MPEG-2 Quantization Matrices"; case V4L2_CID_MPEG_VIDEO_FWHT_PARAMS: return "FWHT Stateless Parameters"; diff --git a/include/uapi/linux/v4l2-controls.h b/include/uapi/linux/v4l2-controls.h index b77fa7d..3c4fdc1 100644 --- a/include/uapi/linux/v4l2-controls.h +++ b/include/uapi/linux/v4l2-controls.h @@ -424,6 +424,7 @@ enum v4l2_mpeg_video_multi_slice_mode { #define V4L2_CID_MPEG_VIDEO_LTR_COUNT (V4L2_CID_MPEG_BASE+230) #define V4L2_CID_MPEG_VIDEO_FRAME_LTR_INDEX (V4L2_CID_MPEG_BASE+231) #define V4L2_CID_MPEG_VIDEO_USE_LTR_FRAMES (V4L2_CID_MPEG_BASE+232) +#define V4L2_CID_MPEG_VIDEO_BASELAYER_PRIORITY_ID (V4L2_CID_MPEG_BASE + 233) /* CIDs for the MPEG-2 Part 2 (H.262) codec */ #define V4L2_CID_MPEG_VIDEO_MPEG2_LEVEL (V4L2_CID_MPEG_BASE+270) -- 2.7.4