BPFtrace is a high-level tracing language for Linux enhanced Berkeley Packet Filter (eBPF) available in recent Linux kernels (4.x). BPFtrace uses LLVM as a backend to compile scripts to BPF-bytecode and makes use of [BCC](https://github.com/iovisor/bcc) for interacting with the Linux BPF system, as well as existing Linux tracing capabilities: kernel dynamic tracing (kprobes), user-level dynamic tracing (uprobes), and tracepoints. The BPFtrace language is inspired by awk and C, and predecessor tracers such as DTrace and SystemTap. BPFtrace was created by [Alastair Robertson](https://github.com/ajor).
BPFtrace is a high-level tracing language for Linux enhanced Berkeley Packet Filter (eBPF) available in recent Linux kernels (4.x). BPFtrace uses LLVM as a backend to compile scripts to BPF-bytecode and makes use of [BCC](https://github.com/iovisor/bcc) for interacting with the Linux BPF system, as well as existing Linux tracing capabilities: kernel dynamic tracing (kprobes), user-level dynamic tracing (uprobes), and tracepoints. The BPFtrace language is inspired by awk and C, and predecessor tracers such as DTrace and SystemTap. BPFtrace was created by [Alastair Robertson](https://github.com/ajor).
To learn more about BPFtrace, see the [Reference Guide](docs/reference_guide.md) and [One-Liner Tutorial](docs/tutorial_one_liners.md).
To learn more about BPFtrace, see the [Reference Guide](docs/reference_guide.md) and [One-Liner Tutorial](docs/tutorial_one_liners.md).
## Install
## Install
...
@@ -12,7 +12,7 @@ For build and install instructions, see [INSTALL.md](INSTALL.md).
...
@@ -12,7 +12,7 @@ For build and install instructions, see [INSTALL.md](INSTALL.md).
@@ -258,7 +258,7 @@ This counts stack traces that led to context switching (off-CPU) events. The abo
...
@@ -258,7 +258,7 @@ This counts stack traces that led to context switching (off-CPU) events. The abo
Attaching 1 probe...
Attaching 1 probe...
^C
^C
@:
@:
[0, 1] 1 |@@ |
[0, 1] 1 |@@ |
[2, 4) 0 | |
[2, 4) 0 | |
[4, 8) 0 | |
[4, 8) 0 | |
...
@@ -310,7 +310,7 @@ open path: retrans_time_ms
...
@@ -310,7 +310,7 @@ open path: retrans_time_ms
This uses kernel dynamic tracing of the vfs_open() function, which has a (struct path *) as the first argument.
This uses kernel dynamic tracing of the vfs_open() function, which has a (struct path *) as the first argument.
- kprobe: As mentioned earlier, this is the kernel dynamic tracing probe type, which traces the entry of kernel functions (use kretprobe to trace their returns).
- kprobe: As mentioned earlier, this is the kernel dynamic tracing probe type, which traces the entry of kernel functions (use kretprobe to trace their returns).
- ((path *)arg0)->dentry->d_name.name: this casts arg0 as path *, then dereferences dentry, etc.
- ((path *)arg0)->dentry->d_name.name: this casts arg0 as path *, then dereferences dentry, etc.
- #include: these were necessary to include struct definitions for path and dentry.
- #include: these were necessary to include struct definitions for path and dentry.