This is an example of Process Watch running on an Intel® NUC running the LULESH workload. Note the presence of AVX, AVX2, and VFMA instructions.
Process Watch displays per-process instruction mix in real-time, organizing these instructions into categories. It offers a simple, table-based interface as well as a CSV output.
For the binary releases, the only requirement is that you have BTF metadata in your kernel. If the file
/sys/kernel/btf/vmlinux
exists on your system, then you have it. If not, then your
kernel does not have BTF metadata.
If your kernel does not have this feature, you can enable it by installing or compiling
a kernel with the CONFIG_DEBUG_INFO_BTF
configuration option enabled. Keep in mind that
if you're compiling the kernel yourself, you need to install the pahole
commandline utility
to compile a kernel with this option enabled.
There are two ways to compile Process Watch:
./build.sh
. This executable should work in kernel version5.8.0
and newer../build.sh --legacy
. This executable is for kernels before5.8.0
.
First, clone the repository:
git clone --recursive https://github.com/intel/processwatch.git
If you've already cloned without --recursive
, go into the repository directory and issue:
git submodule init
git submodule update --init --recursive
If you want to compile the tool, there are a few common packages that you'll need to install on your system:
- CMake
- Clang
- LLVM (e.g.
llvm-strip
) - NCURSES
- POSIX Threads
libelf
You can install these on Ubuntu 20.04, 21.10, or 22.04 by issuing the following:
sudo apt-get update
sudo apt-get install libelf-dev cmake clang llvm llvm-dev
Ubuntu 18.04 requires a bit more work; the default LLVM version is too old:
sudo apt-get update
sudo apt-get install libelf-dev cmake clang-10 llvm-10 llvm-10-dev
Then edit build.sh
and append -10
to the values of CLANG
, CLANGXX
, and LLVM_STRIP
.
On CentOS 8.4, CentOS 8 Stream, and CentOS 9 Stream:
sudo yum update
sudo yum install cmake bpftool clang llvm-toolset ncurses-devel
On Amazon Linux 2, you can do:
sudo yum update
sudo yum install bpftool zlib-devel zlib-static \
elfutils-libelf-devel-static clang cmake3 llvm \
glibc-static
Please keep in mind that if you're running a custom kernel, you'll need to compile
and install bpftool
in the tools/bpf/bpftool
directory of your kernel's source tree.
Now, check your kernel version:
uname -a
If you have a kernel older than 5.8.0, compile with:
./build.sh --legacy
If your kernel is 5.8.0 or newer, do:
./build.sh
This is the default mode, so no command-line arguments are necessary to enable it.
Kill it with CTRL-C or send it SIGTERM. You can also do -n <num>
to have it stop
after a number of intervals.
To enable this mode, pass --csv
or -c
on the command-line. Output will go to
stdout
. Send SIGTERM
to kill it.
Long Form | Short Form | Description |
---|---|---|
--interval=[sec] |
-i |
Modifies the interval length. Default is 2. |
--num-intervals |
-n |
Limits runtime to intervals. |
--csv |
-c |
Enables CSV output to stdout . Kill with SIGTERM. |
--pid=[pid] |
-p |
Profiles a specific PID rather than all processes. |
--mnemonics |
-m |
Displays individual instruction mnemonics instead of categories. |
--sample_period=[val] |
-s |
Sets the perf rate at which to sample instructions. |
--filter=[val] |
-f |
Filters instruction mnemonics or categories. Ignores case. Can pass multiple times. |
--list |
-l |
Prints available instruction categories (or mnemonics if -m is specified) and exits. |
--help |
-h |
Help! |
This happens particularly on Ubuntu 20.04, which includes a version of bpftool
that
is too old to read the kernel's BTF information.
Sometimes when you install linux-tools-common
or linux-tools-generic
, you get
a version of bpftool
that is not associated with the kernel that you're currently running.
This happens when there is a kernel package update, but you're still running an older kernel.
Similarly, on Ubuntu 20.04, you may get a bpftool
version that fails to read the BTF
information (which is stored in /sys/kernel/btf/vmlinux
).
Resolving this issue is simple, but depends on your situation.
- If you're on Ubuntu 20.04, install
linux-tools-*
for a newer kernel. I chose thelinux-tools-5.8.0-63-generic
package. - If you're running a newer Ubuntu version, you might just want to install
linux-tools-$(uname -r)
to install the Linux tools for your currently-running kernel. - A longer-term solution is to simply upgrade your system (
sudo apt-get update && sudo apt-get upgrade
), install thelinux-tools-generic
package, and then reboot the machine into the updated kernel.
If you need to tell the build system to use a specific version of bpftool
, simply edit the BPFTOOL
variable
in build.sh
. For example, if you're on Ubuntu 20.04 and have installed ``linux-tools-5.8.0-63-generic`,
you might want to edit that variable to become something like:
export BPFTOOL="/usr/lib/linux-tools/5.8.0-63-generic/bpftool"