Received: by 2002:a05:6512:23a5:0:0:0:0 with SMTP id c37csp500526lfv; Tue, 15 Feb 2022 07:30:03 -0800 (PST) X-Google-Smtp-Source: ABdhPJy83mXQsFSEVz8hkP/IwP5ZLOYfwc43/1mjUz6MxGh57LKqF9CUTT/W5ovVfGPpeVgpgh8o X-Received: by 2002:a17:906:4781:: with SMTP id cw1mr3437207ejc.264.1644939003421; Tue, 15 Feb 2022 07:30:03 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1644939003; cv=none; d=google.com; s=arc-20160816; b=srWCvTuD4dRDsRzma4NkYIQ7fBltOo4NVCx+VerpLfWZm1ddSMFgATOGMfPn2uQNLH P57f3ueM67pDvvLPMNfGdfY29RrpzeiWjfbm/J2vZfIRbUQWza0pjx8mys4p349iEajs uB8zEUo3pNxu0kkuEo+gP/1cFfTnNt1hcd8bK4EyODJkCwsW91Nlr/l0V5fMrJDSwFog pig5fP7s3SwF45x1hEqggPDnXRAvbQne6tPCh7Wlgxare1wh61n79escqSwvgKt4Jlqt COAObBQmMphKRspq0J/YGXEqa8e0UdlcStZC4bpUEiezThmUw9b0sGknzxADTqj0Xpmg Qc9w== 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:dkim-signature; bh=YTfF3JOFDkxU8NXmdwjZudL6fqTS6ba74J5UvvhtNR8=; b=Sl8Zkb5okRgfeVtgDPWZylsqPoc1msQsb/elZy8HT0n+WPlEQZukeD12SqWgeUXYsQ BPED29QXa04zeaaJ937ccIQ60Cp9iH8Qi4d6r21R4bVlXihk+L+EpnLFGwoK98lZpuri 5jhZg6vrKkn4QiX6HdAVj+6P52GqZ/LddQqyCDWHWZQXdGlI7HU7pIgyf7nF0EC9rBwI yeCpTP20xJeCFfbN4jCahtYByhBW3YuhgFif/yZrL+e94jf8+K1F76cccd/uklTS6gYg MTgeRk8UZWE5ba05t29dOIjOKzdr/pY8lbXmNZkfCcJuD43uaz1wJwWMQUBF+s5eSo/D 50yA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=SXLAJI1N; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id he17si1241162ejc.477.2022.02.15.07.29.40; Tue, 15 Feb 2022 07:30:03 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=SXLAJI1N; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238670AbiBOOf2 (ORCPT + 99 others); Tue, 15 Feb 2022 09:35:28 -0500 Received: from mxb-00190b01.gslb.pphosted.com ([23.128.96.19]:40950 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229631AbiBOOf1 (ORCPT ); Tue, 15 Feb 2022 09:35:27 -0500 Received: from bhuna.collabora.co.uk (bhuna.collabora.co.uk [IPv6:2a00:1098:0:82:1000:25:2eeb:e3e3]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 119F3102404; Tue, 15 Feb 2022 06:35:17 -0800 (PST) Received: from [IPV6:2a01:e0a:120:3210:6d7b:ae43:289b:7e7c] (unknown [IPv6:2a01:e0a:120:3210:6d7b:ae43:289b:7e7c]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: benjamin.gaignard) by bhuna.collabora.co.uk (Postfix) with ESMTPSA id 043A01F44AD7; Tue, 15 Feb 2022 14:35:14 +0000 (GMT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=collabora.com; s=mail; t=1644935715; bh=dl6hh/l2mWUPuGmafkZGaL7Spv4+jTER1VoaGqQ9F+g=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=SXLAJI1NO8CaeSVO7X9Db934N7O3Na5ZzfgqeS6gp1nuZ1W4SksT4FYS0VYHdcXoY tBucCY3lSRZMkfGfv4P0BImXKNy/0nUJTcUM1hDJLfEB95gX+3CRQxfInYWb+/on2y Hp/CGrkePE7ZezFcfPIY4ZlnyokhTHZhZIMHdyZWc46ABcKjQwrSLEwU5BccMbe6UZ vvYHPMcxvLHYhdXe0E0FqhNssh3XFQZOMZdey5Jd3485OPgvA05egRAX752LGjaNaW xzz7KS0E7HsGBBSJL3TWu7uUp1RRie6QQp/dvJQjjB5IDbF7liYizzg6QdWZXv2rr/ TUAplqRrc5VOQ== Message-ID: <99062279-a3c4-96f7-4c4b-f39e7f812e68@collabora.com> Date: Tue, 15 Feb 2022 15:35:12 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.5.0 Subject: Re: [RFC v2 6/8] media: uapi: Remove bit_size field from v4l2_ctrl_hevc_slice_params Content-Language: en-US To: John Cox Cc: mchehab@kernel.org, ezequiel@vanguardiasur.com.ar, p.zabel@pengutronix.de, gregkh@linuxfoundation.org, mripard@kernel.org, paul.kocialkowski@bootlin.com, wens@csie.org, jernej.skrabec@gmail.com, hverkuil-cisco@xs4all.nl, jonas@kwiboo.se, nicolas@ndufresne.ca, linux-media@vger.kernel.org, linux-kernel@vger.kernel.org, linux-staging@lists.linux.dev, linux-arm-kernel@lists.infradead.org, linux-sunxi@lists.linux.dev, kernel@collabora.com, knaerzche@gmail.com References: <20220215110103.241297-1-benjamin.gaignard@collabora.com> <20220215110103.241297-7-benjamin.gaignard@collabora.com> From: Benjamin Gaignard In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,SPF_HELO_PASS, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Le 15/02/2022 à 15:17, John Cox a écrit : > Hi > >> The bit size of the slice could be deduced from the buffer payload >> so remove bit_size field to avoid duplicated the information. > I think this is a bad idea. In the future we are (I hope) going to want > to have an array (variable) of slice headers all referring to the same > bit buffer. When we do that we will need this field. I wonder if that could be considering like another decode mode and so use an other control ? > >> Signed-off-by: Benjamin Gaignard >> --- >> .../userspace-api/media/v4l/ext-ctrls-codec.rst | 3 --- >> drivers/staging/media/sunxi/cedrus/cedrus_h265.c | 11 ++++------- >> include/uapi/linux/v4l2-controls.h | 3 +-- >> 3 files changed, 5 insertions(+), 12 deletions(-) >> >> diff --git a/Documentation/userspace-api/media/v4l/ext-ctrls-codec.rst b/Documentation/userspace-api/media/v4l/ext-ctrls-codec.rst >> index 3296ac3b9fca..c3ae97657fa7 100644 >> --- a/Documentation/userspace-api/media/v4l/ext-ctrls-codec.rst >> +++ b/Documentation/userspace-api/media/v4l/ext-ctrls-codec.rst >> @@ -2965,9 +2965,6 @@ enum v4l2_mpeg_video_hevc_size_of_length_field - >> :stub-columns: 0 >> :widths: 1 1 2 >> >> - * - __u32 >> - - ``bit_size`` >> - - Size (in bits) of the current slice data. >> * - __u32 >> - ``data_bit_offset`` >> - Offset (in bits) to the video data in the current slice data. >> diff --git a/drivers/staging/media/sunxi/cedrus/cedrus_h265.c b/drivers/staging/media/sunxi/cedrus/cedrus_h265.c >> index 8ab2d9c6f048..db8c7475eeb8 100644 >> --- a/drivers/staging/media/sunxi/cedrus/cedrus_h265.c >> +++ b/drivers/staging/media/sunxi/cedrus/cedrus_h265.c >> @@ -312,8 +312,8 @@ static void cedrus_h265_setup(struct cedrus_ctx *ctx, >> const struct v4l2_hevc_pred_weight_table *pred_weight_table; >> unsigned int width_in_ctb_luma, ctb_size_luma; >> unsigned int log2_max_luma_coding_block_size; >> + size_t slice_bytes; >> dma_addr_t src_buf_addr; >> - dma_addr_t src_buf_end_addr; >> u32 chroma_log2_weight_denom; >> u32 output_pic_list_index; >> u32 pic_order_cnt[2]; >> @@ -370,8 +370,8 @@ static void cedrus_h265_setup(struct cedrus_ctx *ctx, >> >> cedrus_write(dev, VE_DEC_H265_BITS_OFFSET, 0); >> >> - reg = slice_params->bit_size; >> - cedrus_write(dev, VE_DEC_H265_BITS_LEN, reg); >> + slice_bytes = vb2_get_plane_payload(&run->src->vb2_buf, 0); >> + cedrus_write(dev, VE_DEC_H265_BITS_LEN, slice_bytes); > I think one of these must be wrong. bit_size is in bits, > vb2_get_plane_payload is in bytes? You are right it should be vb2_get_plane_payload() * 8 to get the size in bits. I will change that in v3. > > Regards > > John Cox > >> /* Source beginning and end addresses. */ >> >> @@ -384,10 +384,7 @@ static void cedrus_h265_setup(struct cedrus_ctx *ctx, >> >> cedrus_write(dev, VE_DEC_H265_BITS_ADDR, reg); >> >> - src_buf_end_addr = src_buf_addr + >> - DIV_ROUND_UP(slice_params->bit_size, 8); >> - >> - reg = VE_DEC_H265_BITS_END_ADDR_BASE(src_buf_end_addr); >> + reg = VE_DEC_H265_BITS_END_ADDR_BASE(src_buf_addr + slice_bytes); >> cedrus_write(dev, VE_DEC_H265_BITS_END_ADDR, reg); >> >> /* Coding tree block address */ >> diff --git a/include/uapi/linux/v4l2-controls.h b/include/uapi/linux/v4l2-controls.h >> index b1a3dc05f02f..27f5d272dc43 100644 >> --- a/include/uapi/linux/v4l2-controls.h >> +++ b/include/uapi/linux/v4l2-controls.h >> @@ -2457,7 +2457,6 @@ struct v4l2_hevc_pred_weight_table { >> #define V4L2_HEVC_SLICE_PARAMS_FLAG_DEPENDENT_SLICE_SEGMENT (1ULL << 9) >> >> struct v4l2_ctrl_hevc_slice_params { >> - __u32 bit_size; >> __u32 data_bit_offset; >> >> /* ISO/IEC 23008-2, ITU-T Rec. H.265: NAL unit header */ >> @@ -2484,7 +2483,7 @@ struct v4l2_ctrl_hevc_slice_params { >> /* ISO/IEC 23008-2, ITU-T Rec. H.265: Picture timing SEI message */ >> __u8 pic_struct; >> >> - __u8 reserved; >> + __u8 reserved[5]; >> >> /* ISO/IEC 23008-2, ITU-T Rec. H.265: General slice segment header */ >> __u32 slice_segment_addr;