1 #include <linux/bpf.h>
2 #include <bpf/bpf_helpers.h>
3 #include <bpf/bpf_endian.h>
4
5 struct {
6 __uint(type, BPF_MAP_TYPE_SOCKMAP);
7 __uint(max_entries, 20);
8 __type(key, int);
9 __type(value, int);
10 } sock_map_rx SEC(".maps");
11
12 struct {
13 __uint(type, BPF_MAP_TYPE_SOCKMAP);
14 __uint(max_entries, 20);
15 __type(key, int);
16 __type(value, int);
17 } sock_map_tx SEC(".maps");
18
19 struct {
20 __uint(type, BPF_MAP_TYPE_SOCKMAP);
21 __uint(max_entries, 20);
22 __type(key, int);
23 __type(value, int);
24 } sock_map_msg SEC(".maps");
25
26 SEC("sk_skb/stream_verdict")
prog_skb_verdict(struct __sk_buff * skb)27 int prog_skb_verdict(struct __sk_buff *skb)
28 {
29 return SK_PASS;
30 }
31
32 int clone_called;
33
34 SEC("sk_skb/stream_verdict")
prog_skb_verdict_clone(struct __sk_buff * skb)35 int prog_skb_verdict_clone(struct __sk_buff *skb)
36 {
37 clone_called = 1;
38 return SK_PASS;
39 }
40
41 SEC("sk_skb/stream_parser")
prog_skb_parser(struct __sk_buff * skb)42 int prog_skb_parser(struct __sk_buff *skb)
43 {
44 return SK_PASS;
45 }
46
47 char _license[] SEC("license") = "GPL";
48