diff options
| author | Paul Buetow <paul@buetow.org> | 2025-03-16 10:52:53 +0200 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2025-03-16 10:52:53 +0200 |
| commit | 4b3026d0571b0e901cdbd2874b7958a2dc58b10c (patch) | |
| tree | 6c1351c6b3c6f1a8aec465479e3944e94925f756 /internal/ior.go | |
| parent | 8714956d6a45e65307e36afd57f86961bc7b142c (diff) | |
can filter for tracepoints
Diffstat (limited to 'internal/ior.go')
| -rw-r--r-- | internal/ior.go | 16 |
1 files changed, 7 insertions, 9 deletions
diff --git a/internal/ior.go b/internal/ior.go index f9635e5..361c8b6 100644 --- a/internal/ior.go +++ b/internal/ior.go @@ -17,27 +17,25 @@ import ( bpf "github.com/aquasecurity/libbpfgo" ) -func attachTracepoints(bpfModule *bpf.Module, tracepointNames map[string]struct{}) error { - attachAll := len(tracepointNames) == 0 - +func attachTracepoints(flags flags.Flags, bpfModule *bpf.Module) error { for _, name := range tracepoints.List { - if _, ok := tracepointNames[name]; !ok && !attachAll { - // Not attaching tracepoint + if !flags.AttachTracepoint(name) { continue } + fmt.Println("Attaching tracepoint", name) prog, err := bpfModule.GetProgram(fmt.Sprintf("handle_%s", name)) if err != nil { return fmt.Errorf("Failed to get BPF program handle_%s: %v", name, err) } - fmt.Println("Attached prog handle_" + name) + fmt.Println("Attached prog handle_", name) if _, err = prog.AttachTracepoint("syscalls", name); err != nil { // OK, older Kernel versions may not have this tracepoint! - fmt.Println(fmt.Errorf("Failed to attach to %s tracepoint: %v", name, err)) + fmt.Printf("Failed to attach to %s tracepoint: %v, kernel version may be too old, skipping", name, err) continue } - fmt.Println("Attached tracepoint " + name) + fmt.Println("Attached tracepoint ", name) } return nil @@ -62,7 +60,7 @@ func Run(flags flags.Flags) { panic(err) } - if err := attachTracepoints(bpfModule, flags.TracepointNames); err != nil { + if err := attachTracepoints(flags, bpfModule); err != nil { panic(err) } |
