diff options
| author | Paul Buetow <paul@buetow.org> | 2026-03-12 22:39:06 +0200 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2026-03-12 22:39:06 +0200 |
| commit | 13e7970afb3eeac69f82df833f030711e5cf12ec (patch) | |
| tree | 098c4fb8c5a8c8f27547f03f40c9fee0be63fe35 /internal/bpfembed.go | |
| parent | 1b21e818a69bf73fde3ca60f89d2dc82a79fd605 (diff) | |
internal: embed BPF object into ior binary
Diffstat (limited to 'internal/bpfembed.go')
| -rw-r--r-- | internal/bpfembed.go | 31 |
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 +} |
