mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-10-31 16:38:12 +00:00
3e689141e6
Fix all selftests to include libbpf header files with the bpf/ prefix, to
be consistent with external users of the library. Also ensure that all
includes of exported libbpf header files (those that are exported on 'make
install' of the library) use bracketed includes instead of quoted.
To not break the build, keep the old include path until everything has been
changed to the new one; a subsequent patch will remove that.
Fixes: 6910d7d386
("selftests/bpf: Ensure bpf_helper_defs.h are taken from selftests dir")
Signed-off-by: Toke Høiland-Jørgensen <toke@redhat.com>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Acked-by: Andrii Nakryiko <andriin@fb.com>
Link: https://lore.kernel.org/bpf/157952560568.1683545.9649335788846513446.stgit@toke.dk
65 lines
1.3 KiB
C
65 lines
1.3 KiB
C
#include <linux/bpf.h>
|
|
#include <bpf/bpf_helpers.h>
|
|
#include <bpf/bpf_endian.h>
|
|
|
|
int _version SEC("version") = 1;
|
|
|
|
struct {
|
|
__uint(type, BPF_MAP_TYPE_SOCKMAP);
|
|
__uint(max_entries, 20);
|
|
__uint(key_size, sizeof(int));
|
|
__uint(value_size, sizeof(int));
|
|
} sock_map_rx SEC(".maps");
|
|
|
|
struct {
|
|
__uint(type, BPF_MAP_TYPE_SOCKMAP);
|
|
__uint(max_entries, 20);
|
|
__uint(key_size, sizeof(int));
|
|
__uint(value_size, sizeof(int));
|
|
} sock_map_tx SEC(".maps");
|
|
|
|
struct {
|
|
__uint(type, BPF_MAP_TYPE_SOCKMAP);
|
|
__uint(max_entries, 20);
|
|
__uint(key_size, sizeof(int));
|
|
__uint(value_size, sizeof(int));
|
|
} sock_map_msg SEC(".maps");
|
|
|
|
struct {
|
|
__uint(type, BPF_MAP_TYPE_ARRAY);
|
|
__uint(max_entries, 20);
|
|
__type(key, int);
|
|
__type(value, int);
|
|
} sock_map_break SEC(".maps");
|
|
|
|
SEC("sk_skb2")
|
|
int bpf_prog2(struct __sk_buff *skb)
|
|
{
|
|
void *data_end = (void *)(long) skb->data_end;
|
|
void *data = (void *)(long) skb->data;
|
|
__u32 lport = skb->local_port;
|
|
__u32 rport = skb->remote_port;
|
|
__u8 *d = data;
|
|
__u8 sk, map;
|
|
|
|
if (data + 8 > data_end)
|
|
return SK_DROP;
|
|
|
|
map = d[0];
|
|
sk = d[1];
|
|
|
|
d[0] = 0xd;
|
|
d[1] = 0xe;
|
|
d[2] = 0xa;
|
|
d[3] = 0xd;
|
|
d[4] = 0xb;
|
|
d[5] = 0xe;
|
|
d[6] = 0xe;
|
|
d[7] = 0xf;
|
|
|
|
if (!map)
|
|
return bpf_sk_redirect_map(skb, &sock_map_rx, sk, 0);
|
|
return bpf_sk_redirect_map(skb, &sock_map_tx, sk, 0);
|
|
}
|
|
|
|
char _license[] SEC("license") = "GPL";
|