[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <e9c77ce7-0bfb-41cf-9034-2d96359a30a8@arm.com>
Date: Thu, 26 Sep 2024 21:12:57 +0100
From: Leo Yan <leo.yan@....com>
To: Ian Rogers <irogers@...gle.com>, Peter Zijlstra <peterz@...radead.org>,
Ingo Molnar <mingo@...hat.com>, Arnaldo Carvalho de Melo <acme@...nel.org>,
Namhyung Kim <namhyung@...nel.org>, Mark Rutland <mark.rutland@....com>,
Alexander Shishkin <alexander.shishkin@...ux.intel.com>,
Jiri Olsa <jolsa@...nel.org>, Adrian Hunter <adrian.hunter@...el.com>,
Kan Liang <kan.liang@...ux.intel.com>, John Garry <john.g.garry@...cle.com>,
linux-kernel@...r.kernel.org, linux-perf-users@...r.kernel.org,
Jing Zhang <renyu.zj@...ux.alibaba.com>,
Thomas Richter <tmricht@...ux.ibm.com>, James Clark <james.clark@....com>,
Leo Yan <leo.yan@...ux.dev>
Subject: Re: [PATCH v4 2/2] perf jevents: Add cycles breakdown metric for
arm64/AMD/Intel
On 9/26/2024 6:57 PM, Ian Rogers wrote:
>
> Breakdown cycles to user, kernel and guest. Add a common_metrics.py
> file for such metrics.
>
> Signed-off-by: Ian Rogers <irogers@...gle.com>
> ---
> tools/perf/pmu-events/Build | 2 +-
> tools/perf/pmu-events/amd_metrics.py | 3 +++
> tools/perf/pmu-events/arm64_metrics.py | 2 ++
> tools/perf/pmu-events/common_metrics.py | 18 ++++++++++++++++++
> tools/perf/pmu-events/intel_metrics.py | 2 ++
> 5 files changed, 26 insertions(+), 1 deletion(-)
> create mode 100644 tools/perf/pmu-events/common_metrics.py
>
> diff --git a/tools/perf/pmu-events/Build b/tools/perf/pmu-events/Build
> index f3bc6c093360..91b6837e32c9 100644
> --- a/tools/perf/pmu-events/Build
> +++ b/tools/perf/pmu-events/Build
> @@ -37,7 +37,7 @@ $(OUTPUT)pmu-events/arch/%: pmu-events/arch/%
> $(call rule_mkdir)
> $(Q)$(call echo-cmd,gen)cp $< $@
>
> -GEN_METRIC_DEPS := pmu-events/metric.py
> +GEN_METRIC_DEPS := pmu-events/metric.py pmu-events/common_metrics.py
>
> # Generate AMD Json
> ZENS = $(shell ls -d pmu-events/arch/x86/amdzen*)
> diff --git a/tools/perf/pmu-events/amd_metrics.py b/tools/perf/pmu-events/amd_metrics.py
> index 422b119553ff..ccc8ebf13e08 100755
> --- a/tools/perf/pmu-events/amd_metrics.py
> +++ b/tools/perf/pmu-events/amd_metrics.py
> @@ -4,6 +4,7 @@ from metric import (d_ratio, has_event, max, Event, JsonEncodeMetric,
> JsonEncodeMetricGroupDescriptions, Literal, LoadEvents,
> Metric, MetricGroup, Select)
> import argparse
> +from common_metrics import Cycles
> import json
> import math
> import os
> @@ -571,6 +572,7 @@ def AmdUpc() -> Metric:
> return Metric("upc", "Micro-ops retired per core cycle (higher is better)",
> upc, "uops/cycle")
>
> +
> def Idle() -> Metric:
> cyc = Event("msr/mperf/")
> tsc = Event("msr/tsc/")
> @@ -652,6 +654,7 @@ def main() -> None:
> AmdHwpf(),
> AmdSwpf(),
> AmdUpc(),
> + Cycles(),
> Idle(),
> Rapl(),
> UncoreL3(),
> diff --git a/tools/perf/pmu-events/arm64_metrics.py b/tools/perf/pmu-events/arm64_metrics.py
> index bfac570600d9..5285a22ff0c8 100755
> --- a/tools/perf/pmu-events/arm64_metrics.py
> +++ b/tools/perf/pmu-events/arm64_metrics.py
> @@ -3,6 +3,7 @@
> from metric import (d_ratio, Event, JsonEncodeMetric, JsonEncodeMetricGroupDescriptions,
> LoadEvents, Metric, MetricGroup)
> import argparse
> +from common_metrics import Cycles
> import json
> import os
> from typing import Optional
> @@ -171,6 +172,7 @@ def main() -> None:
>
> all_metrics = MetricGroup("",[
> Arm64Topdown(),
> + Cycles(),
> ])
>
> if _args.metricgroups:
> diff --git a/tools/perf/pmu-events/common_metrics.py b/tools/perf/pmu-events/common_metrics.py
> new file mode 100644
> index 000000000000..74c58f9ab020
> --- /dev/null
> +++ b/tools/perf/pmu-events/common_metrics.py
> @@ -0,0 +1,18 @@
> +# SPDX-License-Identifier: (LGPL-2.1 OR BSD-2-Clause)
> +from metric import (d_ratio, Event, Metric, MetricGroup)
> +
> +def Cycles() -> MetricGroup:
> + cyc_k = Event("cycles:kHh")
I am confused that these modifiers should be OR operation or AND operation.
Seems to me, 'k' / 'H' modifiers are AND operation for tracing host and
kernel. But for 'h', it is OR operation with rest modifiers, as we want to
trace for both host kernel and hypervisor.
Sorry I might ask a duplicate question which has been discussed before.
The patch itself looks good to me.
Thanks for working on this.
Leo
> + cyc_g = Event("cycles:G")
> + cyc_u = Event("cycles:uH")
> + cyc = cyc_k + cyc_g + cyc_u
> +
> + return MetricGroup("cycles", [
> + Metric("cycles_total", "Total number of cycles", cyc, "cycles"),
> + Metric("cycles_user", "User cycles as a percentage of all cycles",
> + d_ratio(cyc_u, cyc), "100%"),
> + Metric("cycles_kernel", "Kernel cycles as a percentage of all cycles",
> + d_ratio(cyc_k, cyc), "100%"),
> + Metric("cycles_guest", "Hypervisor guest cycles as a percentage of all cycles",
> + d_ratio(cyc_g, cyc), "100%"),
> + ], description = "cycles breakdown per privilege level (users, kernel, guest)")
> diff --git a/tools/perf/pmu-events/intel_metrics.py b/tools/perf/pmu-events/intel_metrics.py
> index a3a317d13841..4b7668e25e54 100755
> --- a/tools/perf/pmu-events/intel_metrics.py
> +++ b/tools/perf/pmu-events/intel_metrics.py
> @@ -5,6 +5,7 @@ from metric import (d_ratio, has_event, max, source_count, CheckPmu, Event,
> Literal, LoadEvents, Metric, MetricConstraint, MetricGroup,
> MetricRef, Select)
> import argparse
> +from common_metrics import Cycles
> import json
> import math
> import os
> @@ -1050,6 +1051,7 @@ def main() -> None:
> LoadEvents(directory)
>
> all_metrics = MetricGroup("", [
> + Cycles(),
> Idle(),
> Rapl(),
> Smi(),
> --
> 2.46.1.824.gd892dcdcdd-goog
>
>
Powered by blists - more mailing lists