This project calculates utilization statistics:
- What percentage of time is each process/task running, divided into "user", "system", "interrupt", "hcall" time
- Idle time is broken down into sleep, wait, blocked, and I/O wait
- System time is further divided among syscalls, with an invocation count, elapsed time, running (system) time, idle time, minimum, maximum, and average call duration
- Interrupt time is further divided among IRQs, with a per-IRQ count, elapsed time, running time, idle time, minimum, maximum, and average interrupt duration
- Task migrations
- Hypervisor calls are tracked per task, per process, and system wide, with invocation count, elapsed time, running time, minimum, maximum, and average call duration
Usage is a two-step process (described in more detail below):
- Collect trace data using
perf
. - Process collected data.
or:
Record and report in one step.
We welcome contributions to the curt project in many forms. There's always plenty to do! Full details of how to contribute to this project are documented in the CONTRIBUTING.md file.
The project's maintainers are responsible for reviewing and merging all pull requests and they guide the over-all technical direction of the project.
We use SDK Tools for Power Slack for communication.
Currently, the only project file used in processing is curt.py
. One could download that directly from the curt GitHub repository, or clone the git repository and use it from there:
$ git clone /~https://github.com/open-power-sdk/curt.git
$ ls curt/curt.py
curt/curt.py
-
If you wish to run perf as a non-root user, you'll need superuser authority to set some things up:
-
Make sure you have read/write access to
/sys/kernel/debug/tracing
:/usr/bin/sudo /usr/bin/mount -o remount,mode=755 /sys/kernel/debug
-
Enable any user to be able to collect system-wide events:
echo -1 | /usr/bin/sudo /usr/bin/tee /proc/sys/kernel/perf_event_paranoid
-
Install Linux audit's python bindings:
/usr/bin/sudo /usr/bin/yum install audit-libs-python
or
/usr/bin/sudo apt-get install python-audit
-
- ./curt.py --record all command --args
A subset of events can be specified to limit the size of the trace file, or because some statistics are not needed.
The --record
option can take any combination of the following event groups in a comma-separated list:
group name | events | statistics |
---|---|---|
sched | sched:sched_switch , sched:sched_process_exec , sched:sched_process_fork , sched:sched_process_exit |
per-task user, system, hypervisor, idle time |
sched | sched:sched_migrate_task |
accurate migrations and per-cpu statistics |
stat | sched:sched_stat_runtime , sched:sched_stat_wait , sched:sched_stat_sleep , sched:sched_stat_blocked , sched:sched_stat_iowait |
per-task idle-time classification |
syscalls | raw_syscalls:sys_enter , raw_syscalls:sys_exit |
system call statistics |
irqs | irq:irq_handler_entry , irq:irq_handler_exit |
interrupt statistics |
hcalls | powerpc:hcall_entry , powerpc:hcall_exit |
hypervisor call statistics (POWER architecture only) |
- Simple!
perf record -e '{raw_syscalls:*,sched:sched_switch,sched:sched_migrate_task,sched:sched_process_exec,sched:sched_process_fork,sched:sched_process_exit,sched:sched_stat_runtime,sched:sched_stat_wait,sched:sched_stat_sleep,sched:sched_stat_blocked,sched:sched_stat_iowait,powerpc:hcall_entry,powerpc:hcall_exit}' -a *command --args*
If some statistics are not needed, not all events need be traced. This can be helpful to reduce the trace file size. The following are subsets of the trace events, and the statistics for which those events are required:
events | statistics |
---|---|
sched:sched_switch , sched:sched_process_exec , sched:sched_process_fork , sched:sched_process_exit |
per-task user, system, hypervisor, idle time |
sched:sched_migrate_task |
accurate migrations and per-cpu statistics |
sched:sched_stat_runtime , sched:sched_stat_wait , sched:sched_stat_sleep , sched:sched_stat_blocked , sched:sched_stat_iowait |
per-task idle-time classification |
raw_syscalls:sys_enter , raw_syscalls:sys_exit |
system call statistics |
irq:irq_handler_entry , irq:irq_handler_exit |
interrupt statistics |
powerpc:hcall_entry , powerpc:hcall_exit |
hypervisor call statistics (POWER architecture only) |
- Simple!
perf script -s ./curt.py
Or, even simpler, curt.py
can be used directly (it will execute perf
itself):
./curt.py
Like perf
, curt.py
will operate on perf.data
by default. To operate on a different file:
./curt.py my-trace-file.data
The full command help can be displayed:
./curt.py --help
As of this writing, there are two versions of the Python APIs for perf
:
- An older API, which is currently found in all major Linux distributions
- A newer API, which is found in newer kernels
The most significant difference between the two APIs, with respect to curt
, is that the older API does not provide sufficient information to determine the process IDs for tasks.
curt
is able to use either API by using the --api
command option. --api=1
selects the older API, and is the default API selection (so --api=1
is not required). --api=2
selects the newer API.
When using the older API, all tasks will be grouped under an unknown
process ID. One may use the older API on any kernel.
When using the new API on newer kernels, tasks will be grouped under their respective process IDs.
When attempting to use the new API on older kernels, curt
will fail with an error like the following:
TypeError: powerpc__hcall_entry_new() takes exactly 10 arguments (9 given)
curt.py
keeps track of task states as it parses the perf
data file. This naturally depends on the events in the file being ordered in time. Unfortunately, perf
does not guarantee that the events in a trace file are in time order. curt.py
attempts to process the events in any trace file in time order by looking ahead and reordering if needed. To keep the process of looking ahead from taking too much memory, it is limited in the number of events. By default, this limit is 20 events. This limit can be changed by using the --window
option with curt.py
.
Regardless of success for curt.py
looking ahead, the perf
command will still report that it detected out-of-order events:
Warning:
2 out of order events recorded.
These warnings can be ignored.
If, however, the look-ahead window for curt.py
is too small, curt.py
will report an error:
Error: OUT OF ORDER events detected.
Try increasing the size of the look-ahead window with --window=<n>
As suggested, increasing the look-ahead window size sufficiently will address this issue.
For general purpose questions, please use StackOverflow.
The curt project uses the GPL License Version 2.0 software license.
The curt project is inspired by the AIX curt tool