Reading time: | 10 min |
Last updated: | 26 Aug 2024 |
Reading time: |
10 min |
Last updated: |
26 Aug 2024 |
This guide is intended to get you up and running with this tool quickly with the most common settings. For a thorough review of all options, refer to the official documentation.
The Arm Telemetry Solution provides tools and data for performance analysis.
The Arm Topdown Methodology specifies a set of metrics and steps to measure them using the Telemetry Solution.
The Telemetry Solution requires Linux Perf to collect metrics.
The Telemetry Solution also includes data for defining PMU events, a test suite to stress CPU resources, and a tool to parse Statistical Profiling Extension (SPE) data for analysis.
Follow the instructions below to install the Telemetry Solution on an Arm Linux system.
uname -m
The output should be:
aarch64
If you see a different result, you are not using an Arm computer running 64-bit Linux.
Install Perf using the Perf for Linux on Arm install guide .
Python 3.7 or later and pip are required.
Install these on your Linux distribution.
For Debian based distributions (including Ubuntu) run:
sudo apt update
sudo apt install python3-pip python-is-python3 -y
git clone https://git.gitlab.arm.com/telemetry-solution/telemetry-solution.git
cd telemetry-solution/tools/topdown_tool
topdown-tool
executable:Install topdown-tool
in /usr/local/bin
using:
pip3 install -e .
If you are getting errors on the environment being externally managed, try creating a virtual environment.
sudo apt install python3-venv
python3 -m venv topdown-venv
source topdown-venv/bin/activate
pip3 install -e .
top-down
using the version
command:
topdown-tool --help
The output will be similar to:
usage: topdown-tool [-h] [--all-cpus] [--pid PIDS] [--perf-path PERF_PATH] [--perf-args PERF_ARGS] [--cpu CPU]
[--list-cpus] [--list-groups] [--list-metrics] [-c {none,metric,group}]
[--max-events MAX_EVENTS] [-m METRIC_GROUPS] [-n NODE] [-s STAGES] [-i INTERVAL]
[--use-event-names] [-d] [--show-sample-events] [--perf-output PERF_OUTPUT] [--csv CSV] [-v]
[--debug]
...
positional arguments:
command command to analyse. Subsequent arguments are passed as program arguments. e.g. "sleep
10"
options:
-h, --help show this help message and exit
--all-cpus, -a System-wide collection for all CPUs.
--pid PIDS, -p PIDS comma separated list of process IDs to monitor.
--perf-path PERF_PATH
path to perf executable
--perf-args PERF_ARGS
additional command line arguments to pass to Perf
--cpu CPU CPU name to use to look up event data (auto-detect by default)
-i INTERVAL, -I INTERVAL, --interval INTERVAL
Collect/output data every <interval> milliseconds
query options:
--list-cpus list available CPUs and exit
--list-groups list available metric groups and exit
--list-metrics list available metrics and exit
collection options:
-c {none,metric,group}, --collect-by {none,metric,group}
when multiplexing, collect events grouped by "none", "metric" (default), or "group".
This can avoid comparing data collected during different time periods.
--max-events MAX_EVENTS
Maximum simultaneous events. If more events are required, <command> will be run multiple
times.
-m METRIC_GROUPS, --metric-group METRIC_GROUPS
comma separated list of metric groups to collect. See --list-groups for available groups
-n NODE, --node NODE name of topdown node as well as its descendants (e.g. "frontend_bound"). See --list-
metrics for available nodes
-s STAGES, --stages STAGES
control which stages to display, separated by a comma. e.g. "topdown,uarch". "all" may
also be specified, or "combined" to display all, but without separated the output in to
stages.
--use-event-names use event names rather than event codes (e.g. "r01") when collecting data from perf.
This can be useful for debugging.
output options:
-d, --descriptions show group/metric descriptions
--show-sample-events show sample events for metrics
--perf-output PERF_OUTPUT
output file for perf event data
--csv CSV output file for metric CSV data
-v, --verbose enable verbose output
--debug enable debug output
topdown-tool
You may need to enable access to the counters. More information about the options is in the Linux Perf install guide .
sudo sh -c "echo -1 > /proc/sys/kernel/perf_event_paranoid"
sudo sh -c "echo 0 > /proc/sys/kernel/kptr_restrict"
Confirm topdown-tool
is able to collect events:
topdown-tool -m Cycle_Accounting -a sleep 5
The output is similar to:
Stage 1 (Topdown metrics)
=========================
[Cycle Accounting]
Frontend Stalled Cycles 57.67% cycles
Backend Stalled Cycles. 21.06% cycles
If you encounter the error Could not detect CPU. Specify via --cpu
, you can check what CPUs are available, and pass it to the command.
topdown-tool --list-cpus
topdown-tool --cpu <cpu-name> -m Cycle_Accounting -a sleep 5
Your output may be different, but if values are printed you are ready to apply the Arm Top Down methodology.
How would you rate the overall quality of this tool quick-install guide?
What is the primary reason for your feedback ?
Thank you. We're grateful for your feedback on how to improve this tool quick-install guide.