Commit e12a95da authored by Brenden Blanco's avatar Brenden Blanco

Denote auto-loading with k[ret]probe__ prefix

Since kprobe functions will have a different prototype than the kernel
symbols they are attaching to, require that the user prefix the trace
function with a kprobe__ name to denote intent. kretprobe__ prefix is
also supported.
Signed-off-by: default avatarBrenden Blanco <bblanco@plumgrid.com>
parent afea5ed8
...@@ -8,4 +8,4 @@ ...@@ -8,4 +8,4 @@
from bcc import BPF from bcc import BPF
BPF(text='void sys_clone(void *ctx) { bpf_trace_printk("Hello, World!\\n"); }').trace_print() BPF(text='void kprobe__sys_clone(void *ctx) { bpf_trace_printk("Hello, World!\\n"); }').trace_print()
...@@ -609,7 +609,10 @@ class BPF(object): ...@@ -609,7 +609,10 @@ class BPF(object):
if len(open_kprobes) == 0: if len(open_kprobes) == 0:
fns = self.load_funcs(BPF.KPROBE) fns = self.load_funcs(BPF.KPROBE)
for fn in fns: for fn in fns:
self.attach_kprobe(event=fn.name, fn_name=fn.name) if fn.name.startswith("kprobe__"):
self.attach_kprobe(event=fn.name[8:], fn_name=fn.name)
elif fn.name.startswith("kretprobe__"):
self.attach_kprobe(event=fn.name[11:], fn_name=fn.name)
while True: while True:
if fmt: if fmt:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment