[Question] Failed to load ebpf program with BTF-defined map

From: wuzongyo
Date: Wed Apr 06 2022 - 13:02:42 EST


Hi,

I wrote a simple tc-bpf program like that:

#include <linux/bpf.h>
#include <linux/pkt_cls.h>
#include <linx/types.h>
#include <bpf/bpf_helpers.h>

struct {
__uint(type, BPF_MAP_TYPE_HASH);
__uint(max_entries, 1);
__type(key, int);
__type(value, int);
} hmap SEC(".maps");

SEC("classifier")
int _classifier(struct __sk_buff *skb)
{
int key = 0;
int *val;

val = bpf_map_lookup_elem(&hmap, &key);
if (!val)
return TC_ACT_OK;
return TC_ACT_OK;
}

char __license[] SEC("license") = "GPL";

Then I tried to use tc to load the program:

tc qdisc add dev eth0 clsact
tc filter add dev eth0 egress bpf da obj test_bpf.o

But the program loading failed with error messages:

Prog section 'classifier' rejected: Permission denied (13)!
- Type: 3
- Instructions: 9 (0 over limit
- License: GPL

Verifier analysis:

Error fetching program/map!
Unable to load program

I tried to replace the map definition with the following code and the program is loaded successfully!

struct bpf_map_def SEC("maps") hmap = {
.type = BPF_MAP_TYPE_HASH,
.key_size = sizeof(int),
.value_size = sizeof(int),
.max_entries = 1,
};

With bpftrace, I can find that the errno -EACCES is returned by function do_check(). But I am still confused what's wrong with it.

Linux Version: 5.17.0-rc3+ with CONFIG_DEBUG_INFO_BTF=y
TC Version: 5.14.0

Any suggestion will be appreciated!

Thanks