From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-13.7 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,UNPARSEABLE_RELAY,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id B7625C433DB for ; Wed, 24 Feb 2021 20:40:35 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 7547E60202 for ; Wed, 24 Feb 2021 20:40:35 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235480AbhBXUkc (ORCPT ); Wed, 24 Feb 2021 15:40:32 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50554 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235376AbhBXUkb (ORCPT ); Wed, 24 Feb 2021 15:40:31 -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 22047C061574; Wed, 24 Feb 2021 12:39:51 -0800 (PST) Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: ezequiel) with ESMTPSA id 887F61F457DE Message-ID: <807fbefd25e2e91e6d3dd47acfd9a596def9e7ea.camel@collabora.com> Subject: Re: [PATCH v3 2/9] media: hantro: Define HEVC codec profiles and supported features From: Ezequiel Garcia To: Benjamin Gaignard , p.zabel@pengutronix.de, mchehab@kernel.org, robh+dt@kernel.org, shawnguo@kernel.org, s.hauer@pengutronix.de, kernel@pengutronix.de, festevam@gmail.com, linux-imx@nxp.com, gregkh@linuxfoundation.org, mripard@kernel.org, paul.kocialkowski@bootlin.com, wens@csie.org, jernej.skrabec@siol.net, peng.fan@nxp.com, hverkuil-cisco@xs4all.nl, dan.carpenter@oracle.com Cc: linux-media@vger.kernel.org, linux-rockchip@lists.infradead.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, kernel@collabora.com Date: Wed, 24 Feb 2021 17:39:37 -0300 In-Reply-To: <20210222122406.41782-3-benjamin.gaignard@collabora.com> References: <20210222122406.41782-1-benjamin.gaignard@collabora.com> <20210222122406.41782-3-benjamin.gaignard@collabora.com> Organization: Collabora Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.38.2-1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org On Mon, 2021-02-22 at 13:23 +0100, Benjamin Gaignard wrote: > Define which HEVC profiles (up to level 5.1) and features > (no scaling, no 10 bits) are supported by the driver. > > Signed-off-by: Benjamin Gaignard > --- >  drivers/staging/media/hantro/hantro.h     |  2 + >  drivers/staging/media/hantro/hantro_drv.c | 58 +++++++++++++++++++++++ >  2 files changed, 60 insertions(+) > > diff --git a/drivers/staging/media/hantro/hantro.h b/drivers/staging/media/hantro/hantro.h > index 65f9f7ea7dcf..bde65231f22f 100644 > --- a/drivers/staging/media/hantro/hantro.h > +++ b/drivers/staging/media/hantro/hantro.h > @@ -99,6 +99,7 @@ struct hantro_variant { >   * @HANTRO_MODE_H264_DEC: H264 decoder. >   * @HANTRO_MODE_MPEG2_DEC: MPEG-2 decoder. >   * @HANTRO_MODE_VP8_DEC: VP8 decoder. > + * @HANTRO_MODE_HEVC_DEC: HEVC decoder. >   */ >  enum hantro_codec_mode { >         HANTRO_MODE_NONE = -1, > @@ -106,6 +107,7 @@ enum hantro_codec_mode { >         HANTRO_MODE_H264_DEC, >         HANTRO_MODE_MPEG2_DEC, >         HANTRO_MODE_VP8_DEC, > +       HANTRO_MODE_HEVC_DEC, >  }; >   >  /* > diff --git a/drivers/staging/media/hantro/hantro_drv.c b/drivers/staging/media/hantro/hantro_drv.c > index e5f200e64993..d86e322a5980 100644 > --- a/drivers/staging/media/hantro/hantro_drv.c > +++ b/drivers/staging/media/hantro/hantro_drv.c > @@ -243,6 +243,18 @@ static int hantro_try_ctrl(struct v4l2_ctrl *ctrl) >                 if (sps->bit_depth_luma_minus8 != 0) >                         /* Only 8-bit is supported */ >                         return -EINVAL; > +       } else if (ctrl->id == V4L2_CID_MPEG_VIDEO_HEVC_SPS) { > +               const struct v4l2_ctrl_hevc_sps *sps = ctrl->p_new.p_hevc_sps; > + > +               if (sps->bit_depth_luma_minus8 != sps->bit_depth_chroma_minus8) > +                       /* Luma and chroma bit depth mismatch */ > +                       return -EINVAL; > +               if (sps->bit_depth_luma_minus8 != 0) > +                       /* Only 8-bit is supported */ > +                       return -EINVAL; > +               if (sps->flags & V4L2_HEVC_SPS_FLAG_SCALING_LIST_ENABLED) > +                       /* No scaling support */ > +                       return -EINVAL; >         } >         return 0; >  } > @@ -349,6 +361,52 @@ static const struct hantro_ctrl controls[] = { >                         .def = V4L2_MPEG_VIDEO_H264_PROFILE_MAIN, >                 } >         }, { > +               .codec = HANTRO_HEVC_DECODER, Silly nitpick. Looks like this is not defined yet? I'm getting: drivers/staging/media/hantro/hantro_drv.c:364:12: error: ‘HANTRO_HEVC_DECODER’ undeclared here (not in a function); did you mean ‘HANTRO_H264_DECODER’? 364 | .codec = HANTRO_HEVC_DECODER, | ^~~~~~~~~~~~~~~~~~~ | HANTRO_H264_DECODER I'll review the G2 driver soon :-) Thanks, Ezequiel > +               .cfg = { > +                       .id = V4L2_CID_MPEG_VIDEO_HEVC_DECODE_MODE, > +                       .min = V4L2_MPEG_VIDEO_HEVC_DECODE_MODE_FRAME_BASED, > +                       .max = V4L2_MPEG_VIDEO_HEVC_DECODE_MODE_FRAME_BASED, > +                       .def = V4L2_MPEG_VIDEO_HEVC_DECODE_MODE_FRAME_BASED, > +               }, > +       }, { > +               .codec = HANTRO_HEVC_DECODER, > +               .cfg = { > +                       .id = V4L2_CID_MPEG_VIDEO_HEVC_START_CODE, > +                       .min = V4L2_MPEG_VIDEO_HEVC_START_CODE_ANNEX_B, > +                       .max = V4L2_MPEG_VIDEO_HEVC_START_CODE_ANNEX_B, > +                       .def = V4L2_MPEG_VIDEO_HEVC_START_CODE_ANNEX_B, > +               }, > +       }, { > +               .codec = HANTRO_HEVC_DECODER, > +               .cfg = { > +                       .id = V4L2_CID_MPEG_VIDEO_HEVC_PROFILE, > +                       .min = V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, > +                       .max = V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10, > +                       .def = V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, > +               }, > +       }, { > +               .codec = HANTRO_HEVC_DECODER, > +               .cfg = { > +                       .id = V4L2_CID_MPEG_VIDEO_HEVC_LEVEL, > +                       .min = V4L2_MPEG_VIDEO_HEVC_LEVEL_1, > +                       .max = V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1, > +               }, > +       }, { > +               .codec = HANTRO_HEVC_DECODER, > +               .cfg = { > +                       .id = V4L2_CID_MPEG_VIDEO_HEVC_SPS, > +                       .ops = &hantro_ctrl_ops, > +               }, > +       }, { > +               .codec = HANTRO_HEVC_DECODER, > +               .cfg = { > +                       .id = V4L2_CID_MPEG_VIDEO_HEVC_PPS, > +               }, > +       }, { > +               .codec = HANTRO_HEVC_DECODER, > +               .cfg = { > +                       .id = V4L2_CID_MPEG_VIDEO_HEVC_DECODE_PARAMS, > +               }, >         }, >  }; >