Message ID | 20211201013329.15875-2-aford173@gmail.com (mailing list archive) |
---|---|
State | Superseded, archived |
Headers |
Received: from vger.kernel.org ([23.128.96.18]) by www.linuxtv.org with esmtp (Exim 4.92) (envelope-from <linux-media-owner@vger.kernel.org>) id 1msEVW-0013ts-9c; Wed, 01 Dec 2021 01:34:02 +0000 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345076AbhLABhR (ORCPT <rfc822;mkrufky@linuxtv.org> + 1 other); Tue, 30 Nov 2021 20:37:17 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39812 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241240AbhLABhB (ORCPT <rfc822;linux-media@vger.kernel.org>); Tue, 30 Nov 2021 20:37:01 -0500 Received: from mail-io1-xd31.google.com (mail-io1-xd31.google.com [IPv6:2607:f8b0:4864:20::d31]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5F077C061748; Tue, 30 Nov 2021 17:33:41 -0800 (PST) Received: by mail-io1-xd31.google.com with SMTP id z26so28638606iod.10; Tue, 30 Nov 2021 17:33:41 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=dTtlcAd/4wi0l++svlS+iwW32G36swzSrzC7Ae74KpM=; b=Wh2vOhc3g70OZLTOyX4sGyowz0TD109nuF+VGGLuBUk37li6dFph1azPknrhemc0y2 xsJEg/S58uAT9vv1CHRcGEF9lEnSMk6b7WLxVh8G8k8Zjv1doQHfSg+iYNH0Tayz2qi7 XFuIs2vzoXC9pL2OihyXzmx9ftkXtcIcxM4FLE6rjmVIqqNsGPTr3PeqKH9MDuqkCzs7 h0vn5HhOA7JQOzZh7wdFrwa7ElFcWHOHGrKoZlIyLj7WEmgv/pYhjFTMD609yvIxrfU1 6FO764t5rcIQz+HCl5GUPFgSLrh4R8o8P4Y2JEIljJ89BJE+nRlaCemDKJXd9EK4y3Ll v2hQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=dTtlcAd/4wi0l++svlS+iwW32G36swzSrzC7Ae74KpM=; b=FgvWskOOX5aQmUShOocrgMYT1QrAU1rHuWaTkzaHIose+kayGAvDesjVo3b1/7Vrcu orhh33V733yYPgR+cBzHFt7Qk2Q/LMBRxRaps69K6RP0vEBKqU9x2Bbr87shBi25FQ8K EH7wuukS1/WiIj9G3NjN01KPTZldxnEzLVG+VXpRaflkSbzT766lJj8lQ194SDeJLbvG tK0BG34YABck69RKLUk0seyJfZV10t873EbEcXDVukE67UudokwncDJLUBWLb0OCPeBU Hb9h+fICj8Mr5Piq/nh4t0Mu19BsTHhHjRKJmKyB0h0/Zys7NfF2Cg8ttbmbDdvJ2d48 enRg== X-Gm-Message-State: AOAM530T2M/joOlsamK/+NHQ5pDLSdVAG+PSaxhMO2bScELnkrD/eulS yNnvWDLuzc0SVbSzQf58YZYl7UQ8EeT5MT7g X-Google-Smtp-Source: ABdhPJxmPZ5Q5jJc6Ry/3Q4A3LKB9MZwUgjNV73qNsmCkUeaK1WnrYTqmPEbT7N+rTVACgwTDKlvtg== X-Received: by 2002:a6b:7e44:: with SMTP id k4mr4570976ioq.103.1638322420361; Tue, 30 Nov 2021 17:33:40 -0800 (PST) Received: from aford-IdeaCentre-A730.lan ([2601:448:8400:9e8:b7ee:f768:f33c:c028]) by smtp.gmail.com with ESMTPSA id u24sm11856737ior.20.2021.11.30.17.33.39 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 30 Nov 2021 17:33:39 -0800 (PST) From: Adam Ford <aford173@gmail.com> To: linux-media@vger.kernel.org Cc: ezequiel@vanguardiasur.com.ar, hverkuil@xs4all.nl, tharvey@gateworks.com, nicolas@ndufresne.ca, aford@beaconembedded.com, Adam Ford <aford173@gmail.com>, Rob Herring <robh+dt@kernel.org>, Shawn Guo <shawnguo@kernel.org>, Sascha Hauer <s.hauer@pengutronix.de>, Pengutronix Kernel Team <kernel@pengutronix.de>, Fabio Estevam <festevam@gmail.com>, NXP Linux Team <linux-imx@nxp.com>, Philipp Zabel <p.zabel@pengutronix.de>, Mauro Carvalho Chehab <mchehab@kernel.org>, Greg Kroah-Hartman <gregkh@linuxfoundation.org>, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-rockchip@lists.infradead.org, linux-staging@lists.linux.dev Subject: [RFC V2 1/2] media: hantro: Add support for i.MX8M Mini Date: Tue, 30 Nov 2021 19:33:28 -0600 Message-Id: <20211201013329.15875-2-aford173@gmail.com> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20211201013329.15875-1-aford173@gmail.com> References: <20211201013329.15875-1-aford173@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: <linux-media.vger.kernel.org> X-Mailing-List: linux-media@vger.kernel.org X-LSpam-Score: -2.5 (--) X-LSpam-Report: No, score=-2.5 required=5.0 tests=BAYES_00=-1.9,DKIM_SIGNED=0.1,DKIM_VALID=-0.1,DKIM_VALID_AU=-0.1,FREEMAIL_FORGED_FROMDOMAIN=0.001,FREEMAIL_FROM=0.001,HEADER_FROM_DIFFERENT_DOMAINS=0.5,MAILING_LIST_MULTI=-1 autolearn=ham autolearn_force=no |
Series |
arm64: imx8mm: Enable Hantro VPUs
|
|
Commit Message
Adam Ford
Dec. 1, 2021, 1:33 a.m. UTC
The i.MX8M Mini has a similar implementation of the Hantro G1 and
G2 decoders, but the Mini uses the vpu-blk-ctrl for handling the
VPU resets through the power domain system. As such, there are
functions present in the 8MQ that are not applicable to the Mini
which requires the driver to have a different compatible flags.
Signed-off-by: Adam Ford <aford173@gmail.com>
Comments
Hi Adam, On Tue, 30 Nov 2021 at 22:33, Adam Ford <aford173@gmail.com> wrote: > > The i.MX8M Mini has a similar implementation of the Hantro G1 and > h decoders, but the Mini uses the vpu-blk-ctrl for handling the > VPU resets through the power domain system. As such, there are > functions present in the 8MQ that are not applicable to the Mini > which requires the driver to have a different compatible flags. > > Signed-off-by: Adam Ford <aford173@gmail.com> > > diff --git a/drivers/staging/media/hantro/hantro_drv.c b/drivers/staging/media/hantro/hantro_drv.c > index fb82b9297a2b..2aa1c520be50 100644 > --- a/drivers/staging/media/hantro/hantro_drv.c > +++ b/drivers/staging/media/hantro/hantro_drv.c > @@ -592,6 +592,8 @@ static const struct of_device_id of_hantro_match[] = { > { .compatible = "rockchip,rk3399-vpu", .data = &rk3399_vpu_variant, }, > #endif > #ifdef CONFIG_VIDEO_HANTRO_IMX8M > + { .compatible = "nxp,imx8mm-vpu", .data = &imx8mm_vpu_variant, }, > + { .compatible = "nxp,imx8mm-vpu-g2", .data = &imx8mm_vpu_g2_variant }, > { .compatible = "nxp,imx8mq-vpu", .data = &imx8mq_vpu_variant, }, > { .compatible = "nxp,imx8mq-vpu-g2", .data = &imx8mq_vpu_g2_variant }, > #endif > diff --git a/drivers/staging/media/hantro/hantro_hw.h b/drivers/staging/media/hantro/hantro_hw.h > index 267a6d33a47b..ae7c3fff760c 100644 > --- a/drivers/staging/media/hantro/hantro_hw.h > +++ b/drivers/staging/media/hantro/hantro_hw.h > @@ -211,6 +211,8 @@ enum hantro_enc_fmt { > ROCKCHIP_VPU_ENC_FMT_UYVY422 = 3, > }; > > +extern const struct hantro_variant imx8mm_vpu_g2_variant; > +extern const struct hantro_variant imx8mm_vpu_variant; > extern const struct hantro_variant imx8mq_vpu_g2_variant; > extern const struct hantro_variant imx8mq_vpu_variant; > extern const struct hantro_variant px30_vpu_variant; > diff --git a/drivers/staging/media/hantro/imx8m_vpu_hw.c b/drivers/staging/media/hantro/imx8m_vpu_hw.c > index ea919bfb9891..c68516c00c6d 100644 > --- a/drivers/staging/media/hantro/imx8m_vpu_hw.c > +++ b/drivers/staging/media/hantro/imx8m_vpu_hw.c > @@ -242,6 +242,32 @@ static const struct hantro_codec_ops imx8mq_vpu_g2_codec_ops[] = { > }, > }; > > +static const struct hantro_codec_ops imx8mm_vpu_codec_ops[] = { > + [HANTRO_MODE_MPEG2_DEC] = { > + .run = hantro_g1_mpeg2_dec_run, > + .init = hantro_mpeg2_dec_init, > + .exit = hantro_mpeg2_dec_exit, > + }, > + [HANTRO_MODE_VP8_DEC] = { > + .run = hantro_g1_vp8_dec_run, > + .init = hantro_vp8_dec_init, > + .exit = hantro_vp8_dec_exit, > + }, > + [HANTRO_MODE_H264_DEC] = { > + .run = hantro_g1_h264_dec_run, > + .init = hantro_h264_dec_init, > + .exit = hantro_h264_dec_exit, > + }, > +}; > + > +static const struct hantro_codec_ops imx8mm_vpu_g2_codec_ops[] = { > + [HANTRO_MODE_HEVC_DEC] = { > + .run = hantro_g2_hevc_dec_run, > + .init = hantro_hevc_dec_init, > + .exit = hantro_hevc_dec_exit, > + }, > +}; > + I believe you are missing VP9, which explains why you get a zero fluster score. Thanks, Ezequiel
On Wed, Dec 1, 2021 at 6:25 AM Ezequiel Garcia <ezequiel@vanguardiasur.com.ar> wrote: > > Hi Adam, > > On Tue, 30 Nov 2021 at 22:33, Adam Ford <aford173@gmail.com> wrote: > > > > The i.MX8M Mini has a similar implementation of the Hantro G1 and > > h decoders, but the Mini uses the vpu-blk-ctrl for handling the > > VPU resets through the power domain system. As such, there are > > functions present in the 8MQ that are not applicable to the Mini > > which requires the driver to have a different compatible flags. > > > > Signed-off-by: Adam Ford <aford173@gmail.com> > > > > diff --git a/drivers/staging/media/hantro/hantro_drv.c b/drivers/staging/media/hantro/hantro_drv.c > > index fb82b9297a2b..2aa1c520be50 100644 > > --- a/drivers/staging/media/hantro/hantro_drv.c > > +++ b/drivers/staging/media/hantro/hantro_drv.c > > @@ -592,6 +592,8 @@ static const struct of_device_id of_hantro_match[] = { > > { .compatible = "rockchip,rk3399-vpu", .data = &rk3399_vpu_variant, }, > > #endif > > #ifdef CONFIG_VIDEO_HANTRO_IMX8M > > + { .compatible = "nxp,imx8mm-vpu", .data = &imx8mm_vpu_variant, }, > > + { .compatible = "nxp,imx8mm-vpu-g2", .data = &imx8mm_vpu_g2_variant }, > > { .compatible = "nxp,imx8mq-vpu", .data = &imx8mq_vpu_variant, }, > > { .compatible = "nxp,imx8mq-vpu-g2", .data = &imx8mq_vpu_g2_variant }, > > #endif > > diff --git a/drivers/staging/media/hantro/hantro_hw.h b/drivers/staging/media/hantro/hantro_hw.h > > index 267a6d33a47b..ae7c3fff760c 100644 > > --- a/drivers/staging/media/hantro/hantro_hw.h > > +++ b/drivers/staging/media/hantro/hantro_hw.h > > @@ -211,6 +211,8 @@ enum hantro_enc_fmt { > > ROCKCHIP_VPU_ENC_FMT_UYVY422 = 3, > > }; > > > > +extern const struct hantro_variant imx8mm_vpu_g2_variant; > > +extern const struct hantro_variant imx8mm_vpu_variant; > > extern const struct hantro_variant imx8mq_vpu_g2_variant; > > extern const struct hantro_variant imx8mq_vpu_variant; > > extern const struct hantro_variant px30_vpu_variant; > > diff --git a/drivers/staging/media/hantro/imx8m_vpu_hw.c b/drivers/staging/media/hantro/imx8m_vpu_hw.c > > index ea919bfb9891..c68516c00c6d 100644 > > --- a/drivers/staging/media/hantro/imx8m_vpu_hw.c > > +++ b/drivers/staging/media/hantro/imx8m_vpu_hw.c > > @@ -242,6 +242,32 @@ static const struct hantro_codec_ops imx8mq_vpu_g2_codec_ops[] = { > > }, > > }; > > > > +static const struct hantro_codec_ops imx8mm_vpu_codec_ops[] = { > > + [HANTRO_MODE_MPEG2_DEC] = { > > + .run = hantro_g1_mpeg2_dec_run, > > + .init = hantro_mpeg2_dec_init, > > + .exit = hantro_mpeg2_dec_exit, > > + }, > > + [HANTRO_MODE_VP8_DEC] = { > > + .run = hantro_g1_vp8_dec_run, > > + .init = hantro_vp8_dec_init, > > + .exit = hantro_vp8_dec_exit, > > + }, > > + [HANTRO_MODE_H264_DEC] = { > > + .run = hantro_g1_h264_dec_run, > > + .init = hantro_h264_dec_init, > > + .exit = hantro_h264_dec_exit, > > + }, > > +}; > > + > > +static const struct hantro_codec_ops imx8mm_vpu_g2_codec_ops[] = { > > + [HANTRO_MODE_HEVC_DEC] = { > > + .run = hantro_g2_hevc_dec_run, > > + .init = hantro_hevc_dec_init, > > + .exit = hantro_hevc_dec_exit, > > + }, > > +}; > > + > > I believe you are missing VP9, which explains why you get > a zero fluster score. That's what I was thinking too and that's why I was wondering if I should wait on G2 until more of those G2 patches have been finalized and accepted. Is there a way to test the HEVC? I didn't see one in the fluster list. adam > > Thanks, > Ezequiel
On Wed, 1 Dec 2021 at 09:36, Adam Ford <aford173@gmail.com> wrote: > > On Wed, Dec 1, 2021 at 6:25 AM Ezequiel Garcia > <ezequiel@vanguardiasur.com.ar> wrote: > > > > Hi Adam, > > > > On Tue, 30 Nov 2021 at 22:33, Adam Ford <aford173@gmail.com> wrote: > > > > > > The i.MX8M Mini has a similar implementation of the Hantro G1 and > > > h decoders, but the Mini uses the vpu-blk-ctrl for handling the > > > VPU resets through the power domain system. As such, there are > > > functions present in the 8MQ that are not applicable to the Mini > > > which requires the driver to have a different compatible flags. > > > > > > Signed-off-by: Adam Ford <aford173@gmail.com> > > > > > > diff --git a/drivers/staging/media/hantro/hantro_drv.c b/drivers/staging/media/hantro/hantro_drv.c > > > index fb82b9297a2b..2aa1c520be50 100644 > > > --- a/drivers/staging/media/hantro/hantro_drv.c > > > +++ b/drivers/staging/media/hantro/hantro_drv.c > > > @@ -592,6 +592,8 @@ static const struct of_device_id of_hantro_match[] = { > > > { .compatible = "rockchip,rk3399-vpu", .data = &rk3399_vpu_variant, }, > > > #endif > > > #ifdef CONFIG_VIDEO_HANTRO_IMX8M > > > + { .compatible = "nxp,imx8mm-vpu", .data = &imx8mm_vpu_variant, }, > > > + { .compatible = "nxp,imx8mm-vpu-g2", .data = &imx8mm_vpu_g2_variant }, > > > { .compatible = "nxp,imx8mq-vpu", .data = &imx8mq_vpu_variant, }, > > > { .compatible = "nxp,imx8mq-vpu-g2", .data = &imx8mq_vpu_g2_variant }, > > > #endif > > > diff --git a/drivers/staging/media/hantro/hantro_hw.h b/drivers/staging/media/hantro/hantro_hw.h > > > index 267a6d33a47b..ae7c3fff760c 100644 > > > --- a/drivers/staging/media/hantro/hantro_hw.h > > > +++ b/drivers/staging/media/hantro/hantro_hw.h > > > @@ -211,6 +211,8 @@ enum hantro_enc_fmt { > > > ROCKCHIP_VPU_ENC_FMT_UYVY422 = 3, > > > }; > > > > > > +extern const struct hantro_variant imx8mm_vpu_g2_variant; > > > +extern const struct hantro_variant imx8mm_vpu_variant; > > > extern const struct hantro_variant imx8mq_vpu_g2_variant; > > > extern const struct hantro_variant imx8mq_vpu_variant; > > > extern const struct hantro_variant px30_vpu_variant; > > > diff --git a/drivers/staging/media/hantro/imx8m_vpu_hw.c b/drivers/staging/media/hantro/imx8m_vpu_hw.c > > > index ea919bfb9891..c68516c00c6d 100644 > > > --- a/drivers/staging/media/hantro/imx8m_vpu_hw.c > > > +++ b/drivers/staging/media/hantro/imx8m_vpu_hw.c > > > @@ -242,6 +242,32 @@ static const struct hantro_codec_ops imx8mq_vpu_g2_codec_ops[] = { > > > }, > > > }; > > > > > > +static const struct hantro_codec_ops imx8mm_vpu_codec_ops[] = { > > > + [HANTRO_MODE_MPEG2_DEC] = { > > > + .run = hantro_g1_mpeg2_dec_run, > > > + .init = hantro_mpeg2_dec_init, > > > + .exit = hantro_mpeg2_dec_exit, > > > + }, > > > + [HANTRO_MODE_VP8_DEC] = { > > > + .run = hantro_g1_vp8_dec_run, > > > + .init = hantro_vp8_dec_init, > > > + .exit = hantro_vp8_dec_exit, > > > + }, > > > + [HANTRO_MODE_H264_DEC] = { > > > + .run = hantro_g1_h264_dec_run, > > > + .init = hantro_h264_dec_init, > > > + .exit = hantro_h264_dec_exit, > > > + }, > > > +}; > > > + > > > +static const struct hantro_codec_ops imx8mm_vpu_g2_codec_ops[] = { > > > + [HANTRO_MODE_HEVC_DEC] = { > > > + .run = hantro_g2_hevc_dec_run, > > > + .init = hantro_hevc_dec_init, > > > + .exit = hantro_hevc_dec_exit, > > > + }, > > > +}; > > > + > > > > I believe you are missing VP9, which explains why you get > > a zero fluster score. > > That's what I was thinking too and that's why I was wondering if I > should wait on G2 until more of those G2 patches have been finalized > and accepted. Is there a way to test the HEVC? I didn't see one in > the fluster list. > VP9 is on its way to be merged. There is a pull request from Hans already: see https://www.spinics.net/lists/linux-media/msg202448.html which includes the git repository and tag you can merge/rebase to test it. It would be great if you can test G2 on top of that, but it's also fine if you want to just submit G1 for now. Up to you. Regarding HEVC, currently Benjamin is who knows best how to test it. Thinking about it, perhaps we should document this somewhere? Regards, Ezequiel
Le mercredi 01 décembre 2021 à 09:58 -0300, Ezequiel Garcia a écrit : > On Wed, 1 Dec 2021 at 09:36, Adam Ford <aford173@gmail.com> wrote: > > > > On Wed, Dec 1, 2021 at 6:25 AM Ezequiel Garcia > > <ezequiel@vanguardiasur.com.ar> wrote: > > > > > > Hi Adam, > > > > > > On Tue, 30 Nov 2021 at 22:33, Adam Ford <aford173@gmail.com> wrote: > > > > > > > > The i.MX8M Mini has a similar implementation of the Hantro G1 and > > > > h decoders, but the Mini uses the vpu-blk-ctrl for handling the > > > > VPU resets through the power domain system. As such, there are > > > > functions present in the 8MQ that are not applicable to the Mini > > > > which requires the driver to have a different compatible flags. > > > > > > > > Signed-off-by: Adam Ford <aford173@gmail.com> > > > > > > > > diff --git a/drivers/staging/media/hantro/hantro_drv.c b/drivers/staging/media/hantro/hantro_drv.c > > > > index fb82b9297a2b..2aa1c520be50 100644 > > > > --- a/drivers/staging/media/hantro/hantro_drv.c > > > > +++ b/drivers/staging/media/hantro/hantro_drv.c > > > > @@ -592,6 +592,8 @@ static const struct of_device_id of_hantro_match[] = { > > > > { .compatible = "rockchip,rk3399-vpu", .data = &rk3399_vpu_variant, }, > > > > #endif > > > > #ifdef CONFIG_VIDEO_HANTRO_IMX8M > > > > + { .compatible = "nxp,imx8mm-vpu", .data = &imx8mm_vpu_variant, }, > > > > + { .compatible = "nxp,imx8mm-vpu-g2", .data = &imx8mm_vpu_g2_variant }, > > > > { .compatible = "nxp,imx8mq-vpu", .data = &imx8mq_vpu_variant, }, > > > > { .compatible = "nxp,imx8mq-vpu-g2", .data = &imx8mq_vpu_g2_variant }, > > > > #endif > > > > diff --git a/drivers/staging/media/hantro/hantro_hw.h b/drivers/staging/media/hantro/hantro_hw.h > > > > index 267a6d33a47b..ae7c3fff760c 100644 > > > > --- a/drivers/staging/media/hantro/hantro_hw.h > > > > +++ b/drivers/staging/media/hantro/hantro_hw.h > > > > @@ -211,6 +211,8 @@ enum hantro_enc_fmt { > > > > ROCKCHIP_VPU_ENC_FMT_UYVY422 = 3, > > > > }; > > > > > > > > +extern const struct hantro_variant imx8mm_vpu_g2_variant; > > > > +extern const struct hantro_variant imx8mm_vpu_variant; > > > > extern const struct hantro_variant imx8mq_vpu_g2_variant; > > > > extern const struct hantro_variant imx8mq_vpu_variant; > > > > extern const struct hantro_variant px30_vpu_variant; > > > > diff --git a/drivers/staging/media/hantro/imx8m_vpu_hw.c b/drivers/staging/media/hantro/imx8m_vpu_hw.c > > > > index ea919bfb9891..c68516c00c6d 100644 > > > > --- a/drivers/staging/media/hantro/imx8m_vpu_hw.c > > > > +++ b/drivers/staging/media/hantro/imx8m_vpu_hw.c > > > > @@ -242,6 +242,32 @@ static const struct hantro_codec_ops imx8mq_vpu_g2_codec_ops[] = { > > > > }, > > > > }; > > > > > > > > +static const struct hantro_codec_ops imx8mm_vpu_codec_ops[] = { > > > > + [HANTRO_MODE_MPEG2_DEC] = { > > > > + .run = hantro_g1_mpeg2_dec_run, > > > > + .init = hantro_mpeg2_dec_init, > > > > + .exit = hantro_mpeg2_dec_exit, > > > > + }, > > > > + [HANTRO_MODE_VP8_DEC] = { > > > > + .run = hantro_g1_vp8_dec_run, > > > > + .init = hantro_vp8_dec_init, > > > > + .exit = hantro_vp8_dec_exit, > > > > + }, > > > > + [HANTRO_MODE_H264_DEC] = { > > > > + .run = hantro_g1_h264_dec_run, > > > > + .init = hantro_h264_dec_init, > > > > + .exit = hantro_h264_dec_exit, > > > > + }, > > > > +}; > > > > + > > > > +static const struct hantro_codec_ops imx8mm_vpu_g2_codec_ops[] = { > > > > + [HANTRO_MODE_HEVC_DEC] = { > > > > + .run = hantro_g2_hevc_dec_run, > > > > + .init = hantro_hevc_dec_init, > > > > + .exit = hantro_hevc_dec_exit, > > > > + }, > > > > +}; > > > > + > > > > > > I believe you are missing VP9, which explains why you get > > > a zero fluster score. > > > > That's what I was thinking too and that's why I was wondering if I > > should wait on G2 until more of those G2 patches have been finalized > > and accepted. Is there a way to test the HEVC? I didn't see one in > > the fluster list. > > > > VP9 is on its way to be merged. There is a pull request from Hans > already: see https://www.spinics.net/lists/linux-media/msg202448.html > which includes the git repository and tag you can merge/rebase to test > it. > > It would be great if you can test G2 on top of that, but it's also fine > if you want to just submit G1 for now. Up to you. > > Regarding HEVC, currently Benjamin is who knows best how to test it. > Thinking about it, perhaps we should document this somewhere? There is GStreamer-H.265-V4L2SL-Gst1.0 decoder already in fluster. And GStreamer support is still WIP. https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/1079 We had put on hold the HEVC work in order to focus on VP9. Now that VP9 is on its way (I've sent another MR today to GStreamer to fix some more tests). I haven't tested myself imx8mq recently, will likely do soon, so I can give you the expected score. Your VP8 and H264 score matches the result I got. Note that H264 driver is missing interlace support, which is half the tests. We will can resume this work. Help is welcome of course. The HEVC staging API is by was the worst, so there is quite some work to move this API to stable and then port all the drivers to the require changes that will be needed. > > Regards, > Ezequiel
On Wed, Dec 1, 2021 at 3:03 PM Nicolas Dufresne <nicolas@ndufresne.ca> wrote: > > Le mercredi 01 décembre 2021 à 09:58 -0300, Ezequiel Garcia a écrit : > > On Wed, 1 Dec 2021 at 09:36, Adam Ford <aford173@gmail.com> wrote: > > > > > > On Wed, Dec 1, 2021 at 6:25 AM Ezequiel Garcia > > > <ezequiel@vanguardiasur.com.ar> wrote: > > > > > > > > Hi Adam, > > > > > > > > On Tue, 30 Nov 2021 at 22:33, Adam Ford <aford173@gmail.com> wrote: > > > > > > > > > > The i.MX8M Mini has a similar implementation of the Hantro G1 and > > > > > h decoders, but the Mini uses the vpu-blk-ctrl for handling the > > > > > VPU resets through the power domain system. As such, there are > > > > > functions present in the 8MQ that are not applicable to the Mini > > > > > which requires the driver to have a different compatible flags. > > > > > > > > > > Signed-off-by: Adam Ford <aford173@gmail.com> > > > > > > > > > > diff --git a/drivers/staging/media/hantro/hantro_drv.c b/drivers/staging/media/hantro/hantro_drv.c > > > > > index fb82b9297a2b..2aa1c520be50 100644 > > > > > --- a/drivers/staging/media/hantro/hantro_drv.c > > > > > +++ b/drivers/staging/media/hantro/hantro_drv.c > > > > > @@ -592,6 +592,8 @@ static const struct of_device_id of_hantro_match[] = { > > > > > { .compatible = "rockchip,rk3399-vpu", .data = &rk3399_vpu_variant, }, > > > > > #endif > > > > > #ifdef CONFIG_VIDEO_HANTRO_IMX8M > > > > > + { .compatible = "nxp,imx8mm-vpu", .data = &imx8mm_vpu_variant, }, > > > > > + { .compatible = "nxp,imx8mm-vpu-g2", .data = &imx8mm_vpu_g2_variant }, > > > > > { .compatible = "nxp,imx8mq-vpu", .data = &imx8mq_vpu_variant, }, > > > > > { .compatible = "nxp,imx8mq-vpu-g2", .data = &imx8mq_vpu_g2_variant }, > > > > > #endif > > > > > diff --git a/drivers/staging/media/hantro/hantro_hw.h b/drivers/staging/media/hantro/hantro_hw.h > > > > > index 267a6d33a47b..ae7c3fff760c 100644 > > > > > --- a/drivers/staging/media/hantro/hantro_hw.h > > > > > +++ b/drivers/staging/media/hantro/hantro_hw.h > > > > > @@ -211,6 +211,8 @@ enum hantro_enc_fmt { > > > > > ROCKCHIP_VPU_ENC_FMT_UYVY422 = 3, > > > > > }; > > > > > > > > > > +extern const struct hantro_variant imx8mm_vpu_g2_variant; > > > > > +extern const struct hantro_variant imx8mm_vpu_variant; > > > > > extern const struct hantro_variant imx8mq_vpu_g2_variant; > > > > > extern const struct hantro_variant imx8mq_vpu_variant; > > > > > extern const struct hantro_variant px30_vpu_variant; > > > > > diff --git a/drivers/staging/media/hantro/imx8m_vpu_hw.c b/drivers/staging/media/hantro/imx8m_vpu_hw.c > > > > > index ea919bfb9891..c68516c00c6d 100644 > > > > > --- a/drivers/staging/media/hantro/imx8m_vpu_hw.c > > > > > +++ b/drivers/staging/media/hantro/imx8m_vpu_hw.c > > > > > @@ -242,6 +242,32 @@ static const struct hantro_codec_ops imx8mq_vpu_g2_codec_ops[] = { > > > > > }, > > > > > }; > > > > > > > > > > +static const struct hantro_codec_ops imx8mm_vpu_codec_ops[] = { > > > > > + [HANTRO_MODE_MPEG2_DEC] = { > > > > > + .run = hantro_g1_mpeg2_dec_run, > > > > > + .init = hantro_mpeg2_dec_init, > > > > > + .exit = hantro_mpeg2_dec_exit, > > > > > + }, > > > > > + [HANTRO_MODE_VP8_DEC] = { > > > > > + .run = hantro_g1_vp8_dec_run, > > > > > + .init = hantro_vp8_dec_init, > > > > > + .exit = hantro_vp8_dec_exit, > > > > > + }, > > > > > + [HANTRO_MODE_H264_DEC] = { > > > > > + .run = hantro_g1_h264_dec_run, > > > > > + .init = hantro_h264_dec_init, > > > > > + .exit = hantro_h264_dec_exit, > > > > > + }, > > > > > +}; > > > > > + > > > > > +static const struct hantro_codec_ops imx8mm_vpu_g2_codec_ops[] = { > > > > > + [HANTRO_MODE_HEVC_DEC] = { > > > > > + .run = hantro_g2_hevc_dec_run, > > > > > + .init = hantro_hevc_dec_init, > > > > > + .exit = hantro_hevc_dec_exit, > > > > > + }, > > > > > +}; > > > > > + > > > > > > > > I believe you are missing VP9, which explains why you get > > > > a zero fluster score. > > > > > > That's what I was thinking too and that's why I was wondering if I > > > should wait on G2 until more of those G2 patches have been finalized > > > and accepted. Is there a way to test the HEVC? I didn't see one in > > > the fluster list. > > > > > > > VP9 is on its way to be merged. There is a pull request from Hans > > already: see https://www.spinics.net/lists/linux-media/msg202448.html > > which includes the git repository and tag you can merge/rebase to test > > it. > > Thanks for that. I rebased my work and found some bugs, so I'll be posting an RFC V3 later tonight. > > It would be great if you can test G2 on top of that, but it's also fine > > if you want to just submit G1 for now. Up to you. > > > > Regarding HEVC, currently Benjamin is who knows best how to test it. > > Thinking about it, perhaps we should document this somewhere? > > There is GStreamer-H.265-V4L2SL-Gst1.0 decoder already in fluster. And GStreamer > support is still WIP. > > https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/1079 > > We had put on hold the HEVC work in order to focus on VP9. Now that VP9 is on > its way (I've sent another MR today to GStreamer to fix some more tests). I > haven't tested myself imx8mq recently, will likely do soon, so I can give you > the expected score. Your VP8 and H264 score matches the result I got. Note that > H264 driver is missing interlace support, which is half the tests. > > We will can resume this work. Help is welcome of course. The HEVC staging API is > by was the worst, so there is quite some work to move this API to stable and > then port all the drivers to the require changes that will be needed. With the latest gstreamer and the rebase off Hans' work along with some improvements to my code, fluster now runs the VP9...at least for a while. It doesn't technically finish because the power domain appears to choke which causes a hang. This was reported by Tim Harvey, and with some of my updates, I can reproduce it now too. :-( At least I know I'm off to the right start on the VP9. adam > > > > > Regards, > > Ezequiel >
diff --git a/drivers/staging/media/hantro/hantro_drv.c b/drivers/staging/media/hantro/hantro_drv.c index fb82b9297a2b..2aa1c520be50 100644 --- a/drivers/staging/media/hantro/hantro_drv.c +++ b/drivers/staging/media/hantro/hantro_drv.c @@ -592,6 +592,8 @@ static const struct of_device_id of_hantro_match[] = { { .compatible = "rockchip,rk3399-vpu", .data = &rk3399_vpu_variant, }, #endif #ifdef CONFIG_VIDEO_HANTRO_IMX8M + { .compatible = "nxp,imx8mm-vpu", .data = &imx8mm_vpu_variant, }, + { .compatible = "nxp,imx8mm-vpu-g2", .data = &imx8mm_vpu_g2_variant }, { .compatible = "nxp,imx8mq-vpu", .data = &imx8mq_vpu_variant, }, { .compatible = "nxp,imx8mq-vpu-g2", .data = &imx8mq_vpu_g2_variant }, #endif diff --git a/drivers/staging/media/hantro/hantro_hw.h b/drivers/staging/media/hantro/hantro_hw.h index 267a6d33a47b..ae7c3fff760c 100644 --- a/drivers/staging/media/hantro/hantro_hw.h +++ b/drivers/staging/media/hantro/hantro_hw.h @@ -211,6 +211,8 @@ enum hantro_enc_fmt { ROCKCHIP_VPU_ENC_FMT_UYVY422 = 3, }; +extern const struct hantro_variant imx8mm_vpu_g2_variant; +extern const struct hantro_variant imx8mm_vpu_variant; extern const struct hantro_variant imx8mq_vpu_g2_variant; extern const struct hantro_variant imx8mq_vpu_variant; extern const struct hantro_variant px30_vpu_variant; diff --git a/drivers/staging/media/hantro/imx8m_vpu_hw.c b/drivers/staging/media/hantro/imx8m_vpu_hw.c index ea919bfb9891..c68516c00c6d 100644 --- a/drivers/staging/media/hantro/imx8m_vpu_hw.c +++ b/drivers/staging/media/hantro/imx8m_vpu_hw.c @@ -242,6 +242,32 @@ static const struct hantro_codec_ops imx8mq_vpu_g2_codec_ops[] = { }, }; +static const struct hantro_codec_ops imx8mm_vpu_codec_ops[] = { + [HANTRO_MODE_MPEG2_DEC] = { + .run = hantro_g1_mpeg2_dec_run, + .init = hantro_mpeg2_dec_init, + .exit = hantro_mpeg2_dec_exit, + }, + [HANTRO_MODE_VP8_DEC] = { + .run = hantro_g1_vp8_dec_run, + .init = hantro_vp8_dec_init, + .exit = hantro_vp8_dec_exit, + }, + [HANTRO_MODE_H264_DEC] = { + .run = hantro_g1_h264_dec_run, + .init = hantro_h264_dec_init, + .exit = hantro_h264_dec_exit, + }, +}; + +static const struct hantro_codec_ops imx8mm_vpu_g2_codec_ops[] = { + [HANTRO_MODE_HEVC_DEC] = { + .run = hantro_g2_hevc_dec_run, + .init = hantro_hevc_dec_init, + .exit = hantro_hevc_dec_exit, + }, +}; + /* * VPU variants. */ @@ -257,6 +283,11 @@ static const struct hantro_irq imx8mq_g2_irqs[] = { static const char * const imx8mq_clk_names[] = { "g1", "g2", "bus" }; static const char * const imx8mq_reg_names[] = { "g1", "g2", "ctrl" }; +static const char * const imx8mm_g1_clk_names[] = { "g1", "bus" }; +static const char * const imx8mm_g1_reg_names[] = { "g1" }; +static const char * const imx8mm_g2_clk_names[] = { "g2", "bus" }; +static const char * const imx8mm_g2_reg_names[] = { "g2" }; + const struct hantro_variant imx8mq_vpu_variant = { .dec_fmts = imx8m_vpu_dec_fmts, .num_dec_fmts = ARRAY_SIZE(imx8m_vpu_dec_fmts), @@ -289,3 +320,29 @@ const struct hantro_variant imx8mq_vpu_g2_variant = { .clk_names = imx8mq_clk_names, .num_clocks = ARRAY_SIZE(imx8mq_clk_names), }; + +const struct hantro_variant imx8mm_vpu_variant = { + .dec_fmts = imx8m_vpu_dec_fmts, + .num_dec_fmts = ARRAY_SIZE(imx8m_vpu_dec_fmts), + .codec = HANTRO_MPEG2_DECODER | HANTRO_VP8_DECODER | + HANTRO_H264_DECODER, + .codec_ops = imx8mm_vpu_codec_ops, + .irqs = imx8mq_irqs, + .num_irqs = ARRAY_SIZE(imx8mq_irqs), + .clk_names = imx8mm_g1_clk_names, + .num_clocks = ARRAY_SIZE(imx8mm_g1_clk_names), + .reg_names = imx8mm_g1_reg_names, + .num_regs = ARRAY_SIZE(imx8mm_g1_reg_names) +}; + +const struct hantro_variant imx8mm_vpu_g2_variant = { + .dec_offset = 0x0, + .dec_fmts = imx8m_vpu_g2_dec_fmts, + .num_dec_fmts = ARRAY_SIZE(imx8m_vpu_g2_dec_fmts), + .codec = HANTRO_HEVC_DECODER, + .codec_ops = imx8mm_vpu_g2_codec_ops, + .irqs = imx8mq_g2_irqs, + .num_irqs = ARRAY_SIZE(imx8mq_g2_irqs), + .clk_names = imx8mm_g2_clk_names, + .num_clocks = ARRAY_SIZE(imx8mm_g2_reg_names), +};