summaryrefslogtreecommitdiff
path: root/internal/bpfembed.go
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2026-03-12 22:39:06 +0200
committerPaul Buetow <paul@buetow.org>2026-03-12 22:39:06 +0200
commit13e7970afb3eeac69f82df833f030711e5cf12ec (patch)
tree098c4fb8c5a8c8f27547f03f40c9fee0be63fe35 /internal/bpfembed.go
parent1b21e818a69bf73fde3ca60f89d2dc82a79fd605 (diff)
internal: embed BPF object into ior binary
Diffstat (limited to 'internal/bpfembed.go')
-rw-r--r--internal/bpfembed.go31
1 files changed, 31 insertions, 0 deletions
diff --git a/internal/bpfembed.go b/internal/bpfembed.go
new file mode 100644
index 0000000..fce784c
--- /dev/null
+++ b/internal/bpfembed.go
@@ -0,0 +1,31 @@
+package internal
+
+import (
+ _ "embed"
+ "os"
+
+ bpf "github.com/aquasecurity/libbpfgo"
+)
+
+const (
+ bpfObjectOverrideEnv = "IOR_BPF_OBJECT"
+ embeddedBPFObjectName = "ior.bpf.o"
+)
+
+//go:embed c/ior.bpf.o
+var embeddedBPFObject []byte
+
+var (
+ newBPFModuleFromFile = bpf.NewModuleFromFile
+ newBPFModuleFromBuffer = bpf.NewModuleFromBuffer
+)
+
+func loadBPFModule() (*bpf.Module, string, error) {
+ if path := os.Getenv(bpfObjectOverrideEnv); path != "" {
+ module, err := newBPFModuleFromFile(path)
+ return module, "load module from override file", err
+ }
+
+ module, err := newBPFModuleFromBuffer(embeddedBPFObject, embeddedBPFObjectName)
+ return module, "load embedded module", err
+}