Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp5194429pxj; Wed, 26 May 2021 05:14:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxd4Fh+9foov4c5uHSpny11uCGfeaE//OtrdG+mH4cc9+zM9ITnVQmktRQywkEFfDK7Lf6Y X-Received: by 2002:a05:6602:8d0:: with SMTP id h16mr25492307ioz.145.1622031248818; Wed, 26 May 2021 05:14:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1622031248; cv=none; d=google.com; s=arc-20160816; b=Xq+DBNRhpeQEzctvQvMPEzULLt4c5QMcQTnh8YtX4QewpLJbVSJWFyxAlT/GDOJC3E 8T+wkRDAIr8yOfECur+QTiqlh+PG85BB6HWR/wEGpnTH8HMEXQbOSolsRQ9VVe9CpFYP T9viF/Xb8MTWjwk0rogKcID/74fm/qQQ552WECSo9mlYw3cENS3UkrjRYBfGAemkkH3U Kx+kKMMiZ0Of9DTgURv+71ppJlt0EnC6qdyd/GmibCNylJ14n2/np84UuS9EsInHlVBQ yWmuapFFipii9gIhb9gKXF49VMk3LII4+U8Xh6o2GGfFgnlQNidTYfrKdvF1e61c8J20 gRYA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:organization:references:in-reply-to:date:cc:to:from :subject:message-id; bh=M1TFlJhZbKZyAYGLDyuB9u+R9nHwkrj9YfnM3B+Qnrw=; b=jgfRh9dqUwD8G5Y14CPc07/Rfg3fDeNtuB4FXHvN1TCUDdV0CUleXBPb5Y+LJszbhP HnSthGWq4a3fwdumNqT18lRxxY9Qyu89BwCIwT6SsnWxS+cliI8a6EenFTBRNyT9iEMf kl0Uz2fL5wOUZN5/j7f7kTATf/aec/kE7Gb7krNptYwVtVEwYlUiV/zx/0+848ZpH7Y7 0aettGruXbVCdBq8It8MsEQ6pbXEA5wNtTjyA1SjF31DSBDc8+BwoIUGMgIyW7rNVuuP Y1viYwj73iPaAutwGRe59Nswg97h0j2e74303aQgTuZ/DORi3JzWVYJad7r1lBXqO15C kJyg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x6si9258236ilv.59.2021.05.26.05.13.53; Wed, 26 May 2021 05:14:08 -0700 (PDT) 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233836AbhEZKNs (ORCPT + 99 others); Wed, 26 May 2021 06:13:48 -0400 Received: from bhuna.collabora.co.uk ([46.235.227.227]:59462 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233700AbhEZKNn (ORCPT ); Wed, 26 May 2021 06:13:43 -0400 Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: ezequiel) with ESMTPSA id 2B35B1F40AFD Message-ID: <06d5432c44d3b4d6129891c46cc62f0edf735cf7.camel@collabora.com> Subject: Re: [PATCH v11 8/9] media: hantro: Introduce G2/HEVC decoder From: Ezequiel Garcia To: Benjamin Gaignard , p.zabel@pengutronix.de, mchehab@kernel.org, shawnguo@kernel.org, s.hauer@pengutronix.de, festevam@gmail.com, gregkh@linuxfoundation.org, mripard@kernel.org, paul.kocialkowski@bootlin.com, wens@csie.org, jernej.skrabec@siol.net, emil.l.velikov@gmail.com, Andrzej Pietrasiewicz Cc: kernel@pengutronix.de, linux-imx@nxp.com, linux-media@vger.kernel.org, linux-rockchip@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Adrian Ratiu Date: Wed, 26 May 2021 07:12:00 -0300 In-Reply-To: <20210525161238.1191168-9-benjamin.gaignard@collabora.com> References: <20210525161238.1191168-1-benjamin.gaignard@collabora.com> <20210525161238.1191168-9-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: linux-kernel@vger.kernel.org Hi Benjamin, (Adding Andrzej) On Tue, 2021-05-25 at 18:12 +0200, Benjamin Gaignard wrote: > Implement all the logic to get G2 hardware decoding HEVC frames. > It supports up level 5.1 HEVC stream. > It doesn't support yet 10 bits formats or the scaling feature. > > Add HANTRO HEVC dedicated control to skip some bits at the beginning > of the slice header. That is very specific to this hardware so can't > go into uapi structures. Computing the needed value is complex and requires > information from the stream that only the userland knows so let it > provide the correct value to the driver. > > Signed-off-by: Benjamin Gaignard > Co-developed-by: Adrian Ratiu > Signed-off-by: Adrian Ratiu > Co-developed-by: Ezequiel Garcia > Signed-off-by: Ezequiel Garcia > --- [..] > diff --git a/drivers/staging/media/hantro/hantro_g2_regs.h b/drivers/staging/media/hantro/hantro_g2_regs.h > new file mode 100644 > index 000000000000..2477573f7163 > --- /dev/null > +++ b/drivers/staging/media/hantro/hantro_g2_regs.h > @@ -0,0 +1,198 @@ > +/* SPDX-License-Identifier: GPL-2.0-only */ > +/* > + * Copyright (c) 2021, Collabora > + * > + * Author: Benjamin Gaignard > + */ > + > +#ifndef HANTRO_G2_REGS_H_ > +#define HANTRO_G2_REGS_H_ > + > +#include "hantro.h" > + > +#define G2_SWREG(nr)   ((nr) * 4) > + > +#define HEVC_DEC_REG(name, base, shift, mask) \ > +       static const struct hantro_reg _hevc_##name[] = { \ > +               { G2_SWREG(base), (shift), (mask) } \ > +       }; \ > +       static const struct hantro_reg __maybe_unused *hevc_##name = &_hevc_##name[0]; > + > +#define HEVC_REG_VERSION               G2_SWREG(0) > + > +#define HEVC_REG_INTERRUPT             G2_SWREG(1) These definitions seem valid across G2 and not something specific to HEVC, so can we rename (the ones that make sense) to G2_ ? That would allow to reuse them for VP9 with a smaller gap. Thanks, Ezequiel