Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp1921623pxj; Sun, 13 Jun 2021 02:57:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzz9nzXxYEB8U0JA4O/eR2xOvhLbJJxFxvEgUDwu9K6LgUNSVmMT1tJ5g1UJdsqieuUddO2 X-Received: by 2002:a17:906:1f11:: with SMTP id w17mr7385824ejj.33.1623578269773; Sun, 13 Jun 2021 02:57:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623578269; cv=none; d=google.com; s=arc-20160816; b=x6U8MaIze/hh1gpM2R1sb/Zc7ugr7mw9TnpAwxENdbwNqAIgxJ0L4vo+kVtjrSUNQv mTRXslY8pd3o1gSIoa8cZpkx9FEgd92Exd+XxI3dT1PupwG7n5KmQeeFarq8kzQWmRCL f3f327DrzbxR1UUC8d4wjjkrASLHjZzUmXTF3YrzJGo4j9klW0OdOeSyTcpdVG4xEuBh 8iES4bu9eSJf73u/bmqSfaKPT2qNtJw/gru6mxJPW0jUT8QWyz42bKSDUTN2Kf5ZRZbZ aWtVk6ubclSQQk0kr3ibE5A9XCQQwIkAw6Gao5eQ1NJWBE2NOfe9tQMKnbvDOdvKkg/b NlsA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:references:cc :to:from:subject:dkim-signature; bh=fU8Ot0pWCiMdpCEERBQAaol5IDljg932bwWs+DnoffM=; b=EK0SiT4iykw/MNA6Fh7+IEEU/FScrTjMMaBAWKfzK8SO2uh0L2B8dHcXPwjZ4J4Rt+ vcpcBhfc1RQvedvDiXf22tjZwhmVJICoKKGXB6fPqDmBW2Dro2mafvDKwvFjaQzbQd16 Izivv4tGDEsRfUsrymdpkRJtWZmF4Aq9kHbzYKV+UjQUI+zLN2XMKSSb+mXCPB10/pN5 mRCj8JmYzF5suDgtp/VvAPRJWTgvqCqoQToHnngE9BAy/dxeuIPasWmnjS4e/IUd3Zz7 pcpl6/PJecbQX/Pea/8DkmzN69USeEPdutJvbej1EnnZckkFE4qQfo4MnDEVmfNbfBDh 7L1A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@xs4all.nl header.s=s2 header.b=HGCpEjT3; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n21si8494679edy.22.2021.06.13.02.57.27; Sun, 13 Jun 2021 02:57:49 -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; dkim=pass header.i=@xs4all.nl header.s=s2 header.b=HGCpEjT3; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231621AbhFMJ5g (ORCPT + 99 others); Sun, 13 Jun 2021 05:57:36 -0400 Received: from lb2-smtp-cloud8.xs4all.net ([194.109.24.25]:48121 "EHLO lb2-smtp-cloud8.xs4all.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230255AbhFMJ5f (ORCPT ); Sun, 13 Jun 2021 05:57:35 -0400 Received: from cust-b5b5937f ([IPv6:fc0c:c16d:66b8:757f:c639:739b:9d66:799d]) by smtp-cloud8.xs4all.net with ESMTPA id sMq2lTzcLhqltsMq5liv08; Sun, 13 Jun 2021 11:55:34 +0200 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=xs4all.nl; s=s2; t=1623578134; bh=fU8Ot0pWCiMdpCEERBQAaol5IDljg932bwWs+DnoffM=; h=Subject:From:To:Message-ID:Date:MIME-Version:Content-Type:From: Subject; b=HGCpEjT3M89/xZX8fIyiE1WRi2rsi/soZn1Wwgr2sgw3OvcL2gbHMaSC81fWVzQHS GIPTebClviw32DYc8VFkmPql0Cu5RSdjbevUzlod7L/sOiZWw4arOWobW7QfnP+wnF NMMlbsE870vranxaJ8XudPfNKGThCcJDdMdNlQrpSOU9oDBsMKdmvCcuxfUG+nuRps agy6iIFnKzdcSaWXWYrfC2LKuLUhhe5Nv5xO1A6xrk5HrwQOjSEGmQLCwm9ArSneEH /SoNsM97ufoIfrdc6uuV6oeg/oEN1VFuxadCQklY/ncOHkIRQQ+vvuQxNYIslJ38x0 N+2MoaMMk1P5g== Subject: Re: [PATCH 1/8] media: hantro: Trace hevc hw cycles performance register From: Hans Verkuil To: Benjamin Gaignard , ezequiel@collabora.com, 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.p@collabora.com, jc@kynesim.co.uk 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 References: <20210604130619.491200-1-benjamin.gaignard@collabora.com> <20210604130619.491200-2-benjamin.gaignard@collabora.com> Message-ID: <4066d940-4337-0b3d-5329-72c72bc5b623@xs4all.nl> Date: Sun, 13 Jun 2021 11:55:30 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Firefox/78.0 Thunderbird/78.10.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit X-CMAE-Envelope: MS4xfMjIiihHdO2Qf9nYOiVqZxLKyH3O1UDw/ZPS1CzvLnmWRT7bnH94h0TrskliOdd/PtXSXvaW54EQgmnbDek8D4Ne+v9BewrJ8UMNebIz+TzFmnIBu7dl 8t+y5wLIUew/nkC3bhIRrBO//Al/Ebk8osO1XA2o+9qkoq1OHAQ7uSDBy/GbC24wE9dYYhbVBg38ld5hUYtEKpIHhNddIch7hl8ks4ySFUa/0TS5er77dF0o DmEM3ef9qv2TgQ2Rii1/jlkp7E2I63INHg40t3MhWBneMpDIpkUK6tJeDnnn5kHySdiH2ViOhywuMcXwAywPkYFyH/SFjWcgRK8OSkNQAEphgqN9vbXfr99K daWaUM/B0jwG7/HaRbhDJ1UiH+L6TrSzJrKTzoRkT/KtCyHIEsvsJRj1YyXD7Y5bqcPlMKpqpeDn7oyY4wniS3879tzgcbLrANESql91FvmKz65/L9YFZVPp XeFZ9xds75DevZBnc2H1+61PVymPSfbgvEy6f7QWbyomh3Lr1CEtdh7fSF+RLO7XZLVvuLU2hpzouggRLauC7l1e9FeW3+sHXgHk5bk85VIYHsvw06rxQowQ BqS6OvxOcQcC/k7/oNd2qk6JbmkMk42YRlIXCEvDmipQ6sGvv/iAHriwiPWrsA7ss+DhLWmXvLXqBLPx6cuXzulIksgyAtrhiXXNNRseK/+7C0Qt/48f2o0K +Cd7vtFSD86h1RpCWp5Qsz993F5yMkUkrpKUihQbpbXM3xXSWSO8oRPe7briqGnTm2qoIRLtdNW6xxOWHZq3BakSmPPGuS0/SSs8kkaKS2mjrTtGbUfty9ah 4TzQ2hmyK8AnbCZMa9Zm/y23YXxg2vvXZ0Kw4kX/YFGzouzts43lY9bWhwPjWAZv3eQaAGj70zVA7+ENvFqGKTRyyqWHKBjHOPZH0SRl Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 13/06/2021 11:53, Hans Verkuil wrote: > On 04/06/2021 15:06, Benjamin Gaignard wrote: >> After each hevc decoded frame trace the hardware performance. >> It provides the number of hw cycles spend per decoded macroblock. >> >> Signed-off-by: Benjamin Gaignard >> --- >> drivers/staging/media/hantro/hantro_drv.c | 3 ++ >> .../staging/media/hantro/hantro_g2_hevc_dec.c | 16 ++++++++ >> drivers/staging/media/hantro/hantro_g2_regs.h | 1 + >> drivers/staging/media/hantro/hantro_hw.h | 1 + >> drivers/staging/media/hantro/imx8m_vpu_hw.c | 1 + >> drivers/staging/media/hantro/trace.h | 40 +++++++++++++++++++ > > Can you rename this to hantro_trace.h? I prefer to have the driver prefix in the name. Ah, I accidentally replied to the v1, but the same comment applies to v2. Regards, Hans > > Regards, > > Hans > >> 6 files changed, 62 insertions(+) >> create mode 100644 drivers/staging/media/hantro/trace.h >> >> diff --git a/drivers/staging/media/hantro/hantro_drv.c b/drivers/staging/media/hantro/hantro_drv.c >> index dbc69ee0b562..6053c86b1c3f 100644 >> --- a/drivers/staging/media/hantro/hantro_drv.c >> +++ b/drivers/staging/media/hantro/hantro_drv.c >> @@ -28,6 +28,9 @@ >> #include "hantro.h" >> #include "hantro_hw.h" >> >> +#define CREATE_TRACE_POINTS >> +#include "trace.h" >> + >> #define DRIVER_NAME "hantro-vpu" >> >> int hantro_debug; >> diff --git a/drivers/staging/media/hantro/hantro_g2_hevc_dec.c b/drivers/staging/media/hantro/hantro_g2_hevc_dec.c >> index 340efb57fd18..89fac5146433 100644 >> --- a/drivers/staging/media/hantro/hantro_g2_hevc_dec.c >> +++ b/drivers/staging/media/hantro/hantro_g2_hevc_dec.c >> @@ -7,6 +7,7 @@ >> >> #include "hantro_hw.h" >> #include "hantro_g2_regs.h" >> +#include "trace.h" >> >> #define HEVC_DEC_MODE 0xC >> >> @@ -22,6 +23,21 @@ static inline void hantro_write_addr(struct hantro_dev *vpu, >> vdpu_write(vpu, addr & 0xffffffff, offset); >> } >> >> +void hantro_g2_hevc_dec_done(struct hantro_ctx *ctx) >> +{ >> + const struct hantro_hevc_dec_ctrls *ctrls = &ctx->hevc_dec.ctrls; >> + const struct v4l2_ctrl_hevc_sps *sps = ctrls->sps; >> + struct hantro_dev *vpu = ctx->dev; >> + u32 hw_cycles = 0; >> + u32 mbs = (sps->pic_width_in_luma_samples * >> + sps->pic_height_in_luma_samples) >> 8; >> + >> + if (mbs) >> + hw_cycles = vdpu_read(vpu, G2_HW_PERFORMANCE) / mbs; >> + >> + trace_hantro_hevc_perf(ctx, hw_cycles); >> +} >> + >> static void prepare_tile_info_buffer(struct hantro_ctx *ctx) >> { >> struct hantro_dev *vpu = ctx->dev; >> diff --git a/drivers/staging/media/hantro/hantro_g2_regs.h b/drivers/staging/media/hantro/hantro_g2_regs.h >> index bb22fa921914..17d84ec9c5c2 100644 >> --- a/drivers/staging/media/hantro/hantro_g2_regs.h >> +++ b/drivers/staging/media/hantro/hantro_g2_regs.h >> @@ -177,6 +177,7 @@ >> #define G2_REG_CONFIG_DEC_CLK_GATE_E BIT(16) >> #define G2_REG_CONFIG_DEC_CLK_GATE_IDLE_E BIT(17) >> >> +#define G2_HW_PERFORMANCE (G2_SWREG(63)) >> #define G2_ADDR_DST (G2_SWREG(65)) >> #define G2_REG_ADDR_REF(i) (G2_SWREG(67) + ((i) * 0x8)) >> #define G2_ADDR_DST_CHR (G2_SWREG(99)) >> diff --git a/drivers/staging/media/hantro/hantro_hw.h b/drivers/staging/media/hantro/hantro_hw.h >> index 5737a7707944..8fa0aacb61cd 100644 >> --- a/drivers/staging/media/hantro/hantro_hw.h >> +++ b/drivers/staging/media/hantro/hantro_hw.h >> @@ -240,6 +240,7 @@ void hantro_h264_dec_exit(struct hantro_ctx *ctx); >> int hantro_hevc_dec_init(struct hantro_ctx *ctx); >> void hantro_hevc_dec_exit(struct hantro_ctx *ctx); >> int hantro_g2_hevc_dec_run(struct hantro_ctx *ctx); >> +void hantro_g2_hevc_dec_done(struct hantro_ctx *ctx); >> int hantro_hevc_dec_prepare_run(struct hantro_ctx *ctx); >> dma_addr_t hantro_hevc_get_ref_buf(struct hantro_ctx *ctx, int poc); >> void hantro_hevc_ref_remove_unused(struct hantro_ctx *ctx); >> diff --git a/drivers/staging/media/hantro/imx8m_vpu_hw.c b/drivers/staging/media/hantro/imx8m_vpu_hw.c >> index ea919bfb9891..7e9e24bb5057 100644 >> --- a/drivers/staging/media/hantro/imx8m_vpu_hw.c >> +++ b/drivers/staging/media/hantro/imx8m_vpu_hw.c >> @@ -239,6 +239,7 @@ static const struct hantro_codec_ops imx8mq_vpu_g2_codec_ops[] = { >> .reset = imx8m_vpu_g2_reset, >> .init = hantro_hevc_dec_init, >> .exit = hantro_hevc_dec_exit, >> + .done = hantro_g2_hevc_dec_done, >> }, >> }; >> >> diff --git a/drivers/staging/media/hantro/trace.h b/drivers/staging/media/hantro/trace.h >> new file mode 100644 >> index 000000000000..8abe5ddb4814 >> --- /dev/null >> +++ b/drivers/staging/media/hantro/trace.h >> @@ -0,0 +1,40 @@ >> +/* SPDX-License-Identifier: GPL-2.0 */ >> +#undef TRACE_SYSTEM >> +#define TRACE_SYSTEM hantro >> + >> +#if !defined(__HANTRO_TRACE_H__) || defined(TRACE_HEADER_MULTI_READ) >> +#define __HANTRO_TRACE_H__ >> + >> +#include >> +#include >> + >> +#include "hantro.h" >> + >> +TRACE_EVENT(hantro_hevc_perf, >> + TP_PROTO(struct hantro_ctx *ctx, u32 hw_cycles), >> + >> + TP_ARGS(ctx, hw_cycles), >> + >> + TP_STRUCT__entry( >> + __field(int, minor) >> + __field(u32, hw_cycles) >> + ), >> + >> + TP_fast_assign( >> + __entry->minor = ctx->fh.vdev->minor; >> + __entry->hw_cycles = hw_cycles; >> + ), >> + >> + TP_printk("minor = %d, %8d cycles / mb", >> + __entry->minor, __entry->hw_cycles) >> +); >> + >> +#endif /* __HANTRO_TRACE_H__ */ >> + >> +#undef TRACE_INCLUDE_PATH >> +#define TRACE_INCLUDE_PATH ../../drivers/staging/media/hantro >> +#undef TRACE_INCLUDE_FILE >> +#define TRACE_INCLUDE_FILE trace >> + >> +/* This part must be outside protection */ >> +#include >> >