summaryrefslogtreecommitdiff
path: root/internal/ior.go
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2025-03-16 10:52:53 +0200
committerPaul Buetow <paul@buetow.org>2025-03-16 10:52:53 +0200
commit4b3026d0571b0e901cdbd2874b7958a2dc58b10c (patch)
tree6c1351c6b3c6f1a8aec465479e3944e94925f756 /internal/ior.go
parent8714956d6a45e65307e36afd57f86961bc7b142c (diff)
can filter for tracepoints
Diffstat (limited to 'internal/ior.go')
-rw-r--r--internal/ior.go16
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)
}