linux-perf-users.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: John Garry <john.g.garry@oracle.com>
To: Robin Murphy <robin.murphy@arm.com>,
	Jing Zhang <renyu.zj@linux.alibaba.com>,
	Ian Rogers <irogers@google.com>, Will Deacon <will@kernel.org>,
	James Clark <james.clark@arm.com>,
	Mike Leach <mike.leach@linaro.org>, Leo Yan <leo.yan@linaro.org>,
	Mark Rutland <mark.rutland@arm.com>,
	Alexander Shishkin <alexander.shishkin@linux.intel.com>,
	Jiri Olsa <jolsa@kernel.org>, Namhyung Kim <namhyung@kernel.org>,
	Adrian Hunter <adrian.hunter@intel.com>,
	Ilkka Koskinen <ilkka@os.amperecomputing.com>
Cc: linux-kernel@vger.kernel.org,
	linux-arm-kernel@lists.infradead.org,
	linux-perf-users@vger.kernel.org,
	Shuai Xue <xueshuai@linux.alibaba.com>,
	Zhuo Song <zhuo.song@linux.alibaba.com>
Subject: Re: [PATCH RFC 1/4] driver/perf: Add identifier sysfs file for CMN
Date: Thu, 30 Mar 2023 16:55:36 +0100	[thread overview]
Message-ID: <e6e6e508-bb41-d1c2-384f-1f723c7a36f7@oracle.com> (raw)
In-Reply-To: <091d5b8d-6ea7-e6ff-3421-63612797ac60@arm.com>

On 29/03/2023 18:47, Robin Murphy wrote:
>> Do Illka and Robin know that there is such a register that can 
>> identify different CMN versions? Looking forward to your suggestions.
> 
> In principle the "part number" fields from CFGM_PERIPH_ID_0/1 are 
> supposed to identify the model, but for various reasons I'm suspicious 
> of that being unreliable (not least that no actual values are 
> documented, only "configuration-dependent"). That's why I went down the 
> route of making sure we have explicit ACPI/DT identifiers for every model.
> 
> However, the model alone seems either too specific or not specific 
> enough for a jevents identifier. The defined metrics are pretty trivial 
> and should have no real reason not to be common to *any* CMN PMU where 
> the underlying events are present. On the other hand, if we want to get 
> down to the level of specific events in JSON then we'd need to consider 
> the revision as well, since there are several events which only exist on 
> certain revisions of a given model (but often are also common to later 
> models).
> 
> This actually foreshadows a question I was planning to bring up in the 
> context of another driver I'm working on - for this one I would rather 
> like to try using jevents rather than have to maintain another sprawl of 
> event tables in a driver, but it's still going to have the same thing of 
> wanting model/revision matching along the lines of what 
> arm_cmn_event_attr_is_visible() is doing for CMN events. AFAICS this 
> would need jevents to grow a rather more flexible way of encoding and 
> matching identifiers, since having dozens of almost-identical copies of 
> event definitions for every exact identifier value is clearly 
> unworkable.

This sort of problem has not occurred yet as perf tool only supports 
"system" events for a handful of SoCs so far :)

> Does anyone happen to have any thoughts or preferences 
> around how that might be approached?
> 

Currently the perf tool will just match system events based on the exact 
HW identifier and PMU name.

However, if you consider PMCG PMU support as an example of possible area 
of improvement, it has a number of fixed events and a number of IMPDEF 
events. There should be no reason to need to describe in a separate JSON 
those fixed events for every instance of that PMU.

So a simple change would be to teach perf tool that for certain fixed 
events we only need to match based on the PMU name. For others we need 
to match based on some identifier.

If matching based on an identifier still leads to unwieldy amounts of 
tables, then maybe HW identifier wildcard matching may suit, like what 
is done for CPU events.

Thanks,
John


  reply	other threads:[~2023-03-30 15:56 UTC|newest]

Thread overview: 13+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-03-27  2:46 [PATCH RFC 0/4] Add JSON metrics for arm CMN and Yitian710 DDR Jing Zhang
2023-03-27  2:46 ` [PATCH RFC 1/4] driver/perf: Add identifier sysfs file for CMN Jing Zhang
2023-03-27  7:55   ` John Garry
2023-03-29 11:53     ` Jing Zhang
2023-03-29 17:47       ` Robin Murphy
2023-03-30 15:55         ` John Garry [this message]
2023-03-27  2:46 ` [PATCH RFC 2/4] perf vendor events: Add JSON metrics for cmn700 Jing Zhang
2023-03-27  2:46 ` [PATCH RFC 3/4] driver/perf: Add identifier sysfs file for Yitian 710 DDR Jing Zhang
2023-03-29  7:55   ` Shuai Xue
2023-03-29 12:03     ` Jing Zhang
2023-03-27  2:46 ` [PATCH RFC 4/4] perf vendor events: Add JSON metrics " Jing Zhang
2023-03-27 16:51 ` [PATCH RFC 0/4] Add JSON metrics for arm CMN and Yitian710 DDR Ian Rogers
2023-03-29 11:59   ` Jing Zhang

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=e6e6e508-bb41-d1c2-384f-1f723c7a36f7@oracle.com \
    --to=john.g.garry@oracle.com \
    --cc=adrian.hunter@intel.com \
    --cc=alexander.shishkin@linux.intel.com \
    --cc=ilkka@os.amperecomputing.com \
    --cc=irogers@google.com \
    --cc=james.clark@arm.com \
    --cc=jolsa@kernel.org \
    --cc=leo.yan@linaro.org \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-perf-users@vger.kernel.org \
    --cc=mark.rutland@arm.com \
    --cc=mike.leach@linaro.org \
    --cc=namhyung@kernel.org \
    --cc=renyu.zj@linux.alibaba.com \
    --cc=robin.murphy@arm.com \
    --cc=will@kernel.org \
    --cc=xueshuai@linux.alibaba.com \
    --cc=zhuo.song@linux.alibaba.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).