Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp1690997pxj; Fri, 18 Jun 2021 12:46:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyerDvtTAgxeLFqJBUgvzV2wsS/ghFepyEsuqp5qYrjtt6+9jLyibR0kxMmEm7dWDq+ws/o X-Received: by 2002:a17:907:1609:: with SMTP id hb9mr3408690ejc.368.1624045613389; Fri, 18 Jun 2021 12:46:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1624045613; cv=none; d=google.com; s=arc-20160816; b=hNTTGC03hkr/xETGOVnSUl4qIcFH41SsP0DiuAvW/gas/1s/weKE0sXfqGjqNhOu3F ro/Kgno56+dNQLuTMT7F/vsfmFnVJb3Pl9TlSfOkOGr2rZ6JlKeG4Hg//KW+TSZdTrKz FFPtKgMsra664Ns0FyfuRXhnzmPd2hA6JxjfQQCr67YZBzxM4sHJp7kmUcqbFc3LmasU sWYKjs54OQNWdy4isws1lrQDaDGb2bhG136Uh02az0hXUmrOgJ+xr3QN+JV/ebHjeBe1 PuoLufh51Gba35ULFu48yxIMjrdmBIGmgdoo3ov4tzog+tsx+3I2ri9XQfGX15Ug9rfZ 5jwg== 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=7sSntSpWxFif6YNBjhklc+xesQUDG/erl91bYv712IY=; b=GV6uCTE38R0z7W4flm53vhfNrZXjaPxXZUhA8nSmiUkE6tC6j9d0RKuQpKDhivaKKA TGNnauvf8bjJrNTG7by+EeGmuGHmJgwyRGny/IuTfAi4n9MzWk2T528D4dQeelYFkLYl eUYnFZ3n3IbOYZ9stD/WYZRMaLkFSR/rCeLhDTnYfbC+FviEkk733IJrk5MMInEqQTOG x9kj+7/HZv4o4bewO0pnQ4T55u0jpMWYjmYdCm0IV+o0d2ZbgCfStWgnUsaKuhMtxAYz sKTTahYhLVcr1B/sMj3+bEuvYa7honVD8hAsOIT/StSqyzBueFeIKQIqOa0+Ywp6AFtm Arbg== 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 b26si2577323edw.185.2021.06.18.12.46.29; Fri, 18 Jun 2021 12:46:53 -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 S234788AbhFRTBO (ORCPT + 99 others); Fri, 18 Jun 2021 15:01:14 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50136 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231589AbhFRTBL (ORCPT ); Fri, 18 Jun 2021 15:01:11 -0400 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 389D0C061574; Fri, 18 Jun 2021 11:59:01 -0700 (PDT) Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: ezequiel) with ESMTPSA id C099B1F44BE3 Message-ID: <418311dac48d3a29b4fe9e363f7d4e82c360f586.camel@collabora.com> Subject: Re: [PATCH v3 1/8] media: hantro: Trace hevc hw cycles performance register From: Ezequiel Garcia To: Benjamin Gaignard , hverkuil@xs4all.nl, 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, jernej.skrabec@gmail.com, nicolas@ndufresne.ca 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 Date: Fri, 18 Jun 2021 15:58:46 -0300 In-Reply-To: <20210618131526.566762-2-benjamin.gaignard@collabora.com> References: <20210618131526.566762-1-benjamin.gaignard@collabora.com> <20210618131526.566762-2-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, On Fri, 2021-06-18 at 15:15 +0200, Benjamin Gaignard wrote: > After each hevc decoded frame trace the hardware performance. > It provides the number of hw cycles spend per decoded macroblock. > Please add some documentation about how these are supposed to be used. It will be easier to discuss after seeing things in actiion. A good place for the documentation would be: https://www.kernel.org/doc/html/latest/admin-guide/media/v4l-drivers.html [..] > @@ -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) I'm worried about the runtime cost this would have. I see other drivers (i915, panfrost) seem to have an ioctl to enable the perf counters. Perhaps we don't need an ioctl, but a module param would be enough for now. > +{ > +       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); > +} > + > [..] > + > +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; Tracking performance per minor doesn't seem useful, we'd like to track per-fd (i.e. per context). Thanks, Ezequiel