Received: by 2002:a05:6a10:2726:0:0:0:0 with SMTP id ib38csp1131429pxb; Wed, 6 Apr 2022 09:25:47 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz8aNWuSiPl4dWW3Iwz+RoIkVaevJadJqYEVi8sZaYjeBaUasg44vqNT+I3guiDSmYuEczx X-Received: by 2002:a63:6d0e:0:b0:398:677c:d8c with SMTP id i14-20020a636d0e000000b00398677c0d8cmr7664546pgc.157.1649262347647; Wed, 06 Apr 2022 09:25:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649262347; cv=none; d=google.com; s=arc-20160816; b=l1geDoUrMXISQUOS4U52u/KpOGvcdW1CUboWOb62F86N+Ngk0oYtp+RoXB+jCGKpvb ZZpv/4I0Vnb75IO59BO5/0cO/c1q7r2XCGHciUxG4KJus9gwbDVvdEG35X48WTin0lk0 fxkucL7pTZqJpDUg7W6kw9ScoEtUMw5tCcOiXVf6YTLVNzwQyRqKQ4sxQZbS3lfWxGJ+ MbPpPx3yUClq7MT3hwXI0xF9+ZbVblk6jZgZYXQqpZ8NpMIWpgRSdLminR+9LykOjPVA lEEwtq/nogsbBTwb5d2FgU2WNHuyUVL//tT7TSPoUOQXVb4H3NmGmyke33WfD13i7IPC Drgw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:cc:to:subject :message-id:date:from:in-reply-to:references:mime-version :dkim-signature; bh=6PmyYFhtPjFVTd16qXwOxtke+LItJSb1q/vFkxE5NlY=; b=1K8xWvnOtNdE9tgqDwebM63DiPqXoPaZY711XA/oXeqtIOX7Ibtsl+RofXmcQMoJMP cyFf19TuVglb0MgQUK7FHlJxX8eVKD8WO7GfYZ1+11s5yXMd8lqeFEghgKS1Ht8M8062 NtziQnp6qLNbVcDGOxNxgesA0tT9mxnzDyn1KSQnNmfPpWNoZMJJsu2ZapKC0Wiz8DSl ZAWKilvqbpGuXbeZE8bfO9jgNPAq+Yi9E56WvcIqrxvFOl/3F+TiZWQtfoTh32E4wd91 p8Jllu8QfycCCU1bWUfR04qMNZJp0jvZo3ol8F060sguOQ42LkDuOb3F6mK9YiO8SZOJ GbbQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=cbOGwazT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id nu3-20020a17090b1b0300b001bd14e03034si5678403pjb.12.2022.04.06.09.25.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 06 Apr 2022 09:25:47 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=cbOGwazT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 6C57D236910; Wed, 6 Apr 2022 08:28:14 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236178AbiDFP3h (ORCPT + 99 others); Wed, 6 Apr 2022 11:29:37 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57566 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236131AbiDFP3P (ORCPT ); Wed, 6 Apr 2022 11:29:15 -0400 Received: from mail-ed1-x52c.google.com (mail-ed1-x52c.google.com [IPv6:2a00:1450:4864:20::52c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 043F0561211; Wed, 6 Apr 2022 05:29:05 -0700 (PDT) Received: by mail-ed1-x52c.google.com with SMTP id q26so2407330edc.7; Wed, 06 Apr 2022 05:29:05 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc:content-transfer-encoding; bh=6PmyYFhtPjFVTd16qXwOxtke+LItJSb1q/vFkxE5NlY=; b=cbOGwazT1XQieUqK0bdMqB19kjqhOiD2MxvoqQWqh4n1QZxLU8tPNe8yIHXOjAeZgE tGjloGg4slazB0TfvRp071QmfK0HGOFBU8qporeV37Q5Uq7WOegEwVr0CXEBFoBPrA1z 8O8i99M3DD6rxiczUChpc52UUUg5lLnaAB4bav9Vr3Jy9p4QXbf0ApsJ+iU329YeZf5N 6PALqtfRpf8cAn39J8/9MzuvBMnEwlAU8Z7GU1iUFKsW7LPhqzbqNZSSHAbR5VrjEzHW onrZ+FMIr+0OZZNfUcwb1Eqr0uUsdJ7zFV5savBNiMUUFi1OEIdXQgbWWDZhuP1bO+gC n7tQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc:content-transfer-encoding; bh=6PmyYFhtPjFVTd16qXwOxtke+LItJSb1q/vFkxE5NlY=; b=dj1Balb00hRBz0jyM3cnVfiQGCOfFlfKTUFd+oNcUoX7tKoAOKa7WQMjHYxBrkXRdf Gr7NQTsgzkXU5SDNEWbcMmF1pr3vUgm1gXqjy223yTeWcwQckam1O+tGQYQxrUID33Kz K+oxbkWazQ9QG1H/8o8eUEHeivkV6HaTXKKJbypzQaObIf7jM2w88oNCrK7ceDNJaTMT UxXNe0dvjlef/JvKiEmoQWFHSlA5MoFnJfjWGVHMJQnd98bC6nM1HiexfFnfqdkQSZ3t 52O8QxihTLno3TqNYeru2uQaMAyrhFpxG6BsCSYmoSRl44jXB0BqBubHASkHAziXv6EQ r3gQ== X-Gm-Message-State: AOAM530rB65ODrSe+6MvWF27xepG7gtOKGGzFGfOelfklXUC1rd4FGJv RKbBCMNb/ARCnwZ+psh8jxs79odyD7MMvXvEytAXcoistueRUw== X-Received: by 2002:a05:6402:2142:b0:413:6531:bd9e with SMTP id bq2-20020a056402214200b004136531bd9emr8476195edb.5.1649248143700; Wed, 06 Apr 2022 05:29:03 -0700 (PDT) MIME-Version: 1.0 References: <20220228140838.622021-1-benjamin.gaignard@collabora.com> <79a9c925-d930-ad23-dc53-9ebc16d1328a@collabora.com> <3f778844-f655-74a7-0a00-05caa84eca35@collabora.com> <163202bd-ea51-e80a-1481-568fae25b045@collabora.com> In-Reply-To: From: Adam Ford Date: Wed, 6 Apr 2022 07:28:52 -0500 Message-ID: Subject: Re: [PATCH v4 00/15] Move HEVC stateless controls out of staging To: Benjamin Gaignard Cc: Mauro Carvalho Chehab , Ezequiel Garcia , Philipp Zabel , Greg Kroah-Hartman , mripard@kernel.org, paul.kocialkowski@bootlin.com, Chen-Yu Tsai , "jernej.skrabec" , Jonas Karlman , Nicolas Dufresne , linux-media , Linux Kernel Mailing List , "open list:STAGING SUBSYSTEM" , arm-soc , linux-sunxi@lists.linux.dev, kernel , knaerzche@gmail.com, jc@kynesim.co.uk Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable X-Spam-Status: No, score=-1.7 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,RDNS_NONE, SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no 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 On Wed, Apr 6, 2022 at 1:56 AM Benjamin Gaignard wrote: > > > Le 05/04/2022 =C3=A0 23:27, Adam Ford a =C3=A9crit : > > On Mon, Apr 4, 2022 at 10:56 AM Benjamin Gaignard > > wrote: > >> > >> Le 02/04/2022 =C3=A0 18:59, Adam Ford a =C3=A9crit : > >>> On Sat, Apr 2, 2022 at 11:22 AM Adam Ford wrote: > >>>> On Fri, Apr 1, 2022 at 8:18 AM Benjamin Gaignard > >>>> wrote: > >>>>> Le 31/03/2022 =C3=A0 08:53, Benjamin Gaignard a =C3=A9crit : > >>>>>> Le 30/03/2022 =C3=A0 20:52, Adam Ford a =C3=A9crit : > >>>>>>> On Wed, Mar 30, 2022 at 2:53 AM Benjamin Gaignard > >>>>>>> wrote: > >>>>>>>> Le 28/02/2022 =C3=A0 15:08, Benjamin Gaignard a =C3=A9crit : > >>>>>>>>> This series aims to make HEVC uapi stable and usable for hardwa= re > >>>>>>>>> decoder. HEVC uapi is used by 2 mainlined drivers (Cedrus and H= antro) > >>>>>>>>> and 2 out of the tree drivers (rkvdec and RPI). > >>>>>>>>> > >>>>>>>>> After the remarks done on version 2, I have completely reworked= to > >>>>>>>>> patches > >>>>>>>>> split so changelogs are meaningless. I have also drop "RFC" fro= m the > >>>>>>>>> titles. > >>>>>>>>> > >>>>>>>>> Version 4: > >>>>>>>>> - Add num_entry_point_offsets field in struct > >>>>>>>>> v4l2_ctrl_hevc_slice_params > >>>>>>>>> - Fix V4L2_CID_STATELESS_HEVC_ENTRY_POINT_OFFSETS name > >>>>>>>>> - Initialize control V4L2_CID_STATELESS_HEVC_ENTRY_POINT_OFFSET= S > >>>>>>>>> - Fix space/tab issue in kernel-doc > >>>>>>>>> - Add patch to change data_bit_offset definition > >>>>>>>>> - Fix hantro-media SPDX license > >>>>>>>>> - put controls under stateless section in v4l2-ctrls-defs.c > >>>>>>>>> > >>>>>>>>> At the end fluster tests results on IMX8MQ is 77/147 for HEVC c= odec. > >>>>>>>> Dear reviewers, > >>>>>>>> > >>>>>>>> This series is waiting for your feedback, > >>>>>>> I tried several times with the suggested repos for both the kerne= l and > >>>>>>> g-streamer without success getting Fluster to pass any tests on t= he > >>>>>>> imx8mq. I can try again but I likely won't get to it until this > >>>>>>> weekend. If I can get it working, I'll test both the 8mq and 8mm= . > >>>>>> Thanks a lot for that. > >>>>>> > >>>>>> Benjamin > >>>>> Adam, > >>>>> > >>>>> You may need to check if h265parse and v4l2slh265dec are available = on your board. > >>>> I ran gst-inspect to see what showed up with 265 in the name. > >>>> > >>>> # gst-inspect-1.0 |grep 265 > >>>> libav: avdec_h265: libav HEVC (High Efficiency Video Coding) decode= r > >>>> rtp: rtph265depay: RTP H265 depayloader > >>>> rtp: rtph265pay: RTP H265 payloader > >>>> typefindfunctions: video/x-h265: h265, x265, 265 > >>>> v4l2codecs: v4l2slh265dec: V4L2 Stateless H.265 Video Decoder > >>>> videoparsersbad: h265parse: H.265 parser > >>>> > >>>> It appears I have both h265parse and v4l2slh265dec. > >>>> > >>>>> fluster check if v4l2slh265dec is working fine with this command li= ne: > >>>>> > >>>>> gst-launch-1.0 appsrc num-buffers=3D0 ! h265parse ! v4l2slh265dec != fakesink > >>>>> > >>>>> so if one of them is missing it won't work. > >>>> gst-launch-1.0 appsrc num-buffers=3D0 ! h265parse ! v4l2slh265dec ! = fakesink > >>>> Setting pipeline to PAUSED ... > >>>> 0:00:00.098389938 526 0xaaaaf9d86ac0 ERROR v4l2codecs-decoder > >>>> gstv4l2decoder.c:725:gst_v4l2_decoder_get_controls: > >>>> VIDIOC_G_EXT_CTRLS failed: Invalid argument > >>>> ERROR: from element > >>>> /GstPipeline:pipeline0/v4l2slh265dec:v4l2slh265dec0: Driver did not > >>>> report framing and start code method. > >>>> Additional debug info: > >>>> ../subprojects/gst-plugins-bad/sys/v4l2codecs/gstv4l2codech265dec.c(= 155): > >>>> gst_v4l2_codec_h265_dec_open (): > >>>> /GstPipeline:pipeline0/v4l2slh265dec:v4l2slh265dec0: > >>>> gst_v4l2_decoder_get_controls() failed: Invalid argument > >>>> ERROR: pipeline doesn't want to preroll. > >>>> ERROR: from element > >>>> /GstPipeline:pipeline0/v4l2slh265dec:v4l2slh265dec0: Could not > >>>> initialize supporting library. > >>>> Additional debug info: > >>>> ../subprojects/gst-plugins-base/gst-libs/gst/video/gstvideodecoder.c= (2909): > >>>> gst_video_decoder_change_state (): > >>>> /GstPipeline:pipeline0/v4l2slh265dec:v4l2slh265dec0: > >>>> Failed to open decoder > >>>> ERROR: pipeline doesn't want to preroll. > >>>> Failed to set pipeline to PAUSED. > >>>> Setting pipeline to NULL ... > >>>> Freeing pipeline ... > >>>> > >>>> Does this mean I have a wrong version of the kernel and/or incomplet= e patches? > >>> I double checked the branches. > >>> > >>> Kernel: > >>> https://gitlab.collabora.com/benjamin.gaignard/for-upstream.git > >>> branch: origin/HEVC_UAPI_V4 > >>> > >>> Gstreamer: > >>> https://gitlab.freedesktop.org/benjamin.gaignard1/gstreamer.git > >>> branch: origin/benjamin.gaignard1/gstreamer-HEVC_aligned_with_kernel= _5.15 > >>> > >>> > >>> I am still not able to run h.265/HEVC tests. > >> Hello Adam, > >> > >> I have updated the following branches with the versions I have used to= day: > >> > >> Kernel: > >> https://gitlab.collabora.com/benjamin.gaignard/for-upstream.git > >> branch: origin/HEVC_UAPI_V5 only one change in documentation vs versio= n 4 but rebased in v5.18-rc1 > >> > >> Gstreamer: > >> https://gitlab.freedesktop.org/benjamin.gaignard1/gstreamer.git > >> branch: origin/benjamin.gaignard1/gstreamer-HEVC_aligned_with_kernel_= 5.15 updated on the latest GST main branch > >> > >> I hope this will work fine this time. > > I wish I had better news for you: > > > > dmesg shows the hantro driver is being loaded: > > > > [ 38.612243] hantro-vpu 38300000.video-codec: registered > > nxp,imx8mq-vpu-g1-dec as /dev/video0 > > [ 38.612618] hantro-vpu 38310000.video-codec: registered > > nxp,imx8mq-vpu-g2-dec as /dev/video1 > > > > # gst-inspect-1.0 |grep 265 > > libav: avdec_h265: libav HEVC (High Efficiency Video Coding) decoder > > rtp: rtph265depay: RTP H265 depayloader > > rtp: rtph265pay: RTP H265 payloader > > typefindfunctions: video/x-h265: h265, x265, 265 > > v4l2codecs: v4l2slh265dec: V4L2 Stateless H.265 Video Decoder > > videoparsersbad: h265parse: H.265 parser > > > > Fluster reports: > > GStreamer-H.265-V4L2SL-Gst1.0: GStreamer H.265 V4L2SL decoder for > > GStreamer 1.0... =E2=9D=8C > > Still the same error about non supported control ? # gst-lagst-launch-1.0 appsrc num-buffers=3D0 ! h265parse ! v4l2slh265dec ! fakesink Setting pipeline to PAUSED ... 0:00:01.704385508 420 0xaaaaec0a76c0 ERROR v4l2codecs-decoder gstv4l2decoder.c:725:gst_v4l2_decoder_get_controls: VIDIOC_G_EXT_CTRLS failed: Invalid argument ERROR: from element /GstPipeline:pipeline0/v4l2slh265dec:v4l2slh265dec0: Driver did not report framing and start code method. Additional debug info: ../subprojects/gst-plugins-bad/sys/v4l2codecs/gstv4l2codech265dec.c(155): gst_v4l2_codec_h265_dec_open (): /GstPipeline:pipeline0/v4l2slh265dec:v4l2slh265dec0: gst_v4l2_decoder_get_controls() failed: Invalid argument ERROR: pipeline doesn't want to preroll. ERROR: from element /GstPipeline:pipeline0/v4l2slh265dec:v4l2slh265dec0: Could not initialize supporting library. Additional debug info: ../subprojects/gst-plugins-base/gst-libs/gst/video/gstvideodecoder.c(2909): gst_video_decoder_change_state (): /GstPipeline:pipeline0/v4l2slh265dec:v4l2slh265dec0: Failed to open decoder ERROR: pipeline doesn't want to preroll. Failed to set pipeline to PAUSED. Setting pipeline to NULL ... Freeing pipeline ... > > Benjamin > > > adam > >> Benjamin > >> > >>> adam > >>>> adam > >>>>> Regards, > >>>>> Benjamin > >>>>> > >>>>>>> adam > >>>>>>>> Thanks, > >>>>>>>> Benjamin > >>>>>>>> > >>>>>>>>> Benjamin > >>>>>>>>> > >>>>>>>>> > >>>>>>>>> Benjamin Gaignard (12): > >>>>>>>>> media: uapi: HEVC: Add missing fields in HEVC controls > >>>>>>>>> media: uapi: HEVC: Rename HEVC stateless controls with ST= ATELESS > >>>>>>>>> prefix > >>>>>>>>> media: uapi: HEVC: Add document uAPI structure > >>>>>>>>> media: uapi: HEVC: Define V4L2_CID_STATELESS_HEVC_SLICE_P= ARAMS > >>>>>>>>> as a > >>>>>>>>> dynamic array > >>>>>>>>> media: uapi: Move parsed HEVC pixel format out of staging > >>>>>>>>> media: uapi: Add V4L2_CID_STATELESS_HEVC_ENTRY_POINT_OFFS= ETS > >>>>>>>>> control > >>>>>>>>> media: uapi: Move the HEVC stateless control type out of = staging > >>>>>>>>> media: controls: Log HEVC stateless control in .std_log > >>>>>>>>> media: uapi: Create a dedicated header for Hantro control > >>>>>>>>> media: uapi: HEVC: fix padding in v4l2 control structures > >>>>>>>>> media: uapi: Change data_bit_offset definition > >>>>>>>>> media: uapi: move HEVC stateless controls out of staging > >>>>>>>>> > >>>>>>>>> Hans Verkuil (3): > >>>>>>>>> videodev2.h: add V4L2_CTRL_FLAG_DYNAMIC_ARRAY > >>>>>>>>> v4l2-ctrls: add support for dynamically allocated arrays. > >>>>>>>>> vivid: add dynamic array test control > >>>>>>>>> > >>>>>>>>> .../userspace-api/media/drivers/hantro.rst | 5 - > >>>>>>>>> .../media/v4l/ext-ctrls-codec-stateless.rst | 833 > >>>>>>>>> ++++++++++++++++++ > >>>>>>>>> .../media/v4l/ext-ctrls-codec.rst | 780 > >>>>>>>>> ---------------- > >>>>>>>>> .../media/v4l/pixfmt-compressed.rst | 7 +- > >>>>>>>>> .../media/v4l/vidioc-g-ext-ctrls.rst | 20 + > >>>>>>>>> .../media/v4l/vidioc-queryctrl.rst | 8 + > >>>>>>>>> .../media/videodev2.h.rst.exceptions | 5 + > >>>>>>>>> .../media/test-drivers/vivid/vivid-ctrls.c | 15 + > >>>>>>>>> drivers/media/v4l2-core/v4l2-ctrls-api.c | 103 ++- > >>>>>>>>> drivers/media/v4l2-core/v4l2-ctrls-core.c | 198 ++++- > >>>>>>>>> drivers/media/v4l2-core/v4l2-ctrls-defs.c | 37 +- > >>>>>>>>> drivers/media/v4l2-core/v4l2-ctrls-priv.h | 3 +- > >>>>>>>>> drivers/media/v4l2-core/v4l2-ctrls-request.c | 13 +- > >>>>>>>>> drivers/staging/media/hantro/hantro_drv.c | 27 +- > >>>>>>>>> drivers/staging/media/hantro/hantro_hevc.c | 8 +- > >>>>>>>>> drivers/staging/media/sunxi/cedrus/cedrus.c | 24 +- > >>>>>>>>> .../staging/media/sunxi/cedrus/cedrus_dec.c | 10 +- > >>>>>>>>> .../staging/media/sunxi/cedrus/cedrus_h265.c | 2 +- > >>>>>>>>> include/media/hevc-ctrls.h | 250 ------ > >>>>>>>>> include/media/v4l2-ctrls.h | 48 +- > >>>>>>>>> include/uapi/linux/hantro-media.h | 19 + > >>>>>>>>> include/uapi/linux/v4l2-controls.h | 439 ++++++= +++ > >>>>>>>>> include/uapi/linux/videodev2.h | 13 + > >>>>>>>>> 23 files changed, 1697 insertions(+), 1170 deletions(-) > >>>>>>>>> delete mode 100644 include/media/hevc-ctrls.h > >>>>>>>>> create mode 100644 include/uapi/linux/hantro-media.h > >>>>>>>>>