当我尝试执行sudo ./mineonlyret时,我在ubuntu19.04上得到了这个错误消息,这是一个用户空间程序,它加载了一个ebpf程序,并在后面进行了描述。我在ubuntu18.04上尝试了同样的配置,并且没有出错。哪个可能是造成这个错误的原因?如果你需要更多的细节,请告诉我。
libbpf: Error loading ELF section .BTF: 0.mineonlyret_user.c
// SPDX-License-Identifier: GPL-2.0
#include <stdio.h>
#include <assert.h>
#include <linux/bpf.h>
#include "libbpf.h"
#include <unistd.h>
#include <arpa/inet.h>
#include <linux/if_ether.h>
int main(int ac, char **argv)
{
int sock, prog_fd;
struct bpf_object *obj;
char filename[256];
if (bpf_prog_load("mineonlyret_kern.o", BPF_PROG_TYPE_SOCKET_FILTER,
&obj, &prog_fd))
return 1;
/* open up a packet socket */
sock = socket(AF_PACKET, SOCK_RAW, htons(ETH_P_ALL));
if(sock < 0){
printf("socket");
return -1;
}
/* attach the filter */
assert(setsockopt(sock, SOL_SOCKET, SO_ATTACH_BPF, &prog_fd,
sizeof(prog_fd)) == 0);
int i;
char buf[65535];
for (i = 0; i < 5; i++) {
printf("ci\n");
int res = recvfrom(sock, buf, sizeof(buf), 0, NULL, 0);
printf("res=%d\n", res);
sleep(5);
}
return 0;
}mineonlyret_kern.c
#include <linux/bpf.h>
#include <linux/if_ether.h>
#include <linux/if_packet.h>
#include <linux/ip.h>
#include <linux/udp.h>
#include <linux/in.h>
#include "bpf_helpers.h"
#include <stddef.h>
SEC("socket")
int bpf_sk_prog(struct __sk_buff *skb)
{
return 0;
}
char _license[] SEC("license") = "GPL";我将_kern.c编译成
clang -S -I. -O2 -emit-llvm -c mineonlyret_kern.c -o - | llc -march=bpf -filetype=obj -o mineonlyret_kern.o和_user.c与
gcc -o mineonlyret mineonlyret_user.c -I../libbpf/src/ ../libbpf/src/libbpf.a -lelf此外,我还有另一个疑问:如果我使用共享版本的库,它为什么不能工作?我是说如果我执行
gcc -o mineonlyret mineonlyret_user.c -I../libbpf/src/ -L../libbpf/src/ -lbpf目录树
.
├── libbpf
│ ├── include
│ ├── src
│ │ ├── libbpf.so
│ │ └── libbpf.a
└── libbpfebpf
|── mineonlyret_user.c
|── mineonlyret_kern.c发布于 2020-09-28 04:00:36
您需要指定-g来请求Clang生成.BTF (它还将生成矮小的调试信息,但是您可以忽略或删除它,它不会被libbpf使用)。虽然.BTF最初是用于更好的调试和BPF程序集转储的可选额外信息,但它已经发展成为现代BPF应用程序(至少是那些使用libbpf的应用程序)的一个非常必要的部分,因此请确保始终指定'-g‘。
https://stackoverflow.com/questions/58914021
复制相似问题