diff options
author | 2016-04-06 18:43:31 -0700 | |
---|---|---|
committer | 2016-04-07 21:04:27 -0400 | |
commit | e3edfdec04d43aa6276db639d3721e073161d2c2 (patch) | |
tree | c7516296b2081373659aa0dfe39e61fe7598b56e /tools/perf/scripts/python/export-to-postgresql.py | |
parent | samples/bpf: tracepoint example (diff) | |
download | linux-dev-e3edfdec04d43aa6276db639d3721e073161d2c2.tar.xz linux-dev-e3edfdec04d43aa6276db639d3721e073161d2c2.zip |
samples/bpf: add tracepoint vs kprobe performance tests
the first microbenchmark does
fd=open("/proc/self/comm");
for() {
write(fd, "test");
}
and on 4 cpus in parallel:
writes per sec
base (no tracepoints, no kprobes) 930k
with kprobe at __set_task_comm() 420k
with tracepoint at task:task_rename 730k
For kprobe + full bpf program manully fetches oldcomm, newcomm via bpf_probe_read.
For tracepint bpf program does nothing, since arguments are copied by tracepoint.
2nd microbenchmark does:
fd=open("/dev/urandom");
for() {
read(fd, buf);
}
and on 4 cpus in parallel:
reads per sec
base (no tracepoints, no kprobes) 300k
with kprobe at urandom_read() 279k
with tracepoint at random:urandom_read 290k
bpf progs attached to kprobe and tracepoint are noop.
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'tools/perf/scripts/python/export-to-postgresql.py')
0 files changed, 0 insertions, 0 deletions