You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
61 lines
2.4 KiB
61 lines
2.4 KiB
From 245cc45ad45f8024c602696f58ae163d0dc745d5 Mon Sep 17 00:00:00 2001
|
|
From: Dominique Martinet <asmadeus@codewreck.org>
|
|
Date: Tue, 11 Oct 2022 22:39:28 +0900
|
|
Subject: [PATCH] update gobpf: fix compatibility with bcc v0.25.0
|
|
|
|
bcc v0.25.0 broke compatibility with bcc_func_load and requires updating
|
|
the gobpf wrapper.
|
|
|
|
Fixes: #100
|
|
Signed-off-by: Dominique Martinet <asmadeus@codewreck.org>
|
|
---
|
|
go.mod | 2 +-
|
|
go.sum | 4 +--
|
|
vendor/github.com/iovisor/gobpf/bcc/module.go | 25 ++++++++++++++++++-
|
|
vendor/modules.txt | 2 +-
|
|
4 files changed, 28 insertions(+), 5 deletions(-)
|
|
|
|
diff --git a/vendor/github.com/iovisor/gobpf/bcc/module.go b/vendor/github.com/iovisor/gobpf/bcc/module.go
|
|
index 98a1c93..67d43eb 100644
|
|
--- a/vendor/github.com/iovisor/gobpf/bcc/module.go
|
|
+++ b/vendor/github.com/iovisor/gobpf/bcc/module.go
|
|
@@ -31,6 +31,29 @@ import (
|
|
#cgo LDFLAGS: -lbcc
|
|
#include <bcc/bcc_common.h>
|
|
#include <bcc/libbpf.h>
|
|
+#include <bcc/bcc_version.h>
|
|
+
|
|
+#ifndef LIBBCC_VERSION_GEQ
|
|
+#define LIBBCC_VERSION_GEQ(a, b, c) 0
|
|
+#endif
|
|
+
|
|
+int bcc_func_load_wrapper(void *program, int prog_type, const char *name,
|
|
+ const struct bpf_insn *insns, int prog_len,
|
|
+ const char *license, unsigned kern_version,
|
|
+ int log_level, char *log_buf, unsigned log_buf_size,
|
|
+ const char *dev_name, int attach_type){
|
|
+
|
|
+#if LIBBCC_VERSION_GEQ(0, 25, 0)
|
|
+ return bcc_func_load(program, prog_type, name, insns, prog_len, license,
|
|
+ kern_version, log_level, log_buf, log_buf_size,
|
|
+ dev_name, attach_type);
|
|
+#else
|
|
+ return bcc_func_load(program, prog_type, name, insns, prog_len, license,
|
|
+ kern_version, log_level, log_buf, log_buf_size,
|
|
+ dev_name);
|
|
+#endif
|
|
+}
|
|
+
|
|
*/
|
|
import "C"
|
|
|
|
@@ -227,7 +250,7 @@ func (bpf *Module) load(name string, progType int, logLevel, logSize uint) (int,
|
|
logBuf = make([]byte, logSize)
|
|
logBufP = (*C.char)(unsafe.Pointer(&logBuf[0]))
|
|
}
|
|
- fd, err := C.bcc_func_load(bpf.p, C.int(uint32(progType)), nameCS, start, size, license, version, C.int(logLevel), logBufP, C.uint(len(logBuf)), nil)
|
|
+ fd, err := C.bcc_func_load_wrapper(bpf.p, C.int(uint32(progType)), nameCS, start, size, license, version, C.int(logLevel), logBufP, C.uint(len(logBuf)), nil, C.int(-1))
|
|
if fd < 0 {
|
|
return -1, fmt.Errorf("error loading BPF program: %v", err)
|
|
}
|