Commit | Line | Data |
---|---|---|
b2441318 | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
be9370a7 JB |
2 | /* internal file - do not include directly */ |
3 | ||
4 | #ifdef CONFIG_NET | |
91cc1a99 AS |
5 | BPF_PROG_TYPE(BPF_PROG_TYPE_SOCKET_FILTER, sk_filter, |
6 | struct __sk_buff, struct sk_buff) | |
7 | BPF_PROG_TYPE(BPF_PROG_TYPE_SCHED_CLS, tc_cls_act, | |
8 | struct __sk_buff, struct sk_buff) | |
9 | BPF_PROG_TYPE(BPF_PROG_TYPE_SCHED_ACT, tc_cls_act, | |
10 | struct __sk_buff, struct sk_buff) | |
11 | BPF_PROG_TYPE(BPF_PROG_TYPE_XDP, xdp, | |
12 | struct xdp_md, struct xdp_buff) | |
befa6181 | 13 | #ifdef CONFIG_CGROUP_BPF |
91cc1a99 AS |
14 | BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SKB, cg_skb, |
15 | struct __sk_buff, struct sk_buff) | |
16 | BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SOCK, cg_sock, | |
17 | struct bpf_sock, struct sock) | |
18 | BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SOCK_ADDR, cg_sock_addr, | |
19 | struct bpf_sock_addr, struct bpf_sock_addr_kern) | |
20 | #endif | |
21 | BPF_PROG_TYPE(BPF_PROG_TYPE_LWT_IN, lwt_in, | |
22 | struct __sk_buff, struct sk_buff) | |
23 | BPF_PROG_TYPE(BPF_PROG_TYPE_LWT_OUT, lwt_out, | |
24 | struct __sk_buff, struct sk_buff) | |
25 | BPF_PROG_TYPE(BPF_PROG_TYPE_LWT_XMIT, lwt_xmit, | |
26 | struct __sk_buff, struct sk_buff) | |
27 | BPF_PROG_TYPE(BPF_PROG_TYPE_LWT_SEG6LOCAL, lwt_seg6local, | |
28 | struct __sk_buff, struct sk_buff) | |
29 | BPF_PROG_TYPE(BPF_PROG_TYPE_SOCK_OPS, sock_ops, | |
30 | struct bpf_sock_ops, struct bpf_sock_ops_kern) | |
31 | BPF_PROG_TYPE(BPF_PROG_TYPE_SK_SKB, sk_skb, | |
32 | struct __sk_buff, struct sk_buff) | |
33 | BPF_PROG_TYPE(BPF_PROG_TYPE_SK_MSG, sk_msg, | |
34 | struct sk_msg_md, struct sk_msg) | |
35 | BPF_PROG_TYPE(BPF_PROG_TYPE_FLOW_DISSECTOR, flow_dissector, | |
36 | struct __sk_buff, struct bpf_flow_dissector) | |
be9370a7 JB |
37 | #endif |
38 | #ifdef CONFIG_BPF_EVENTS | |
91cc1a99 AS |
39 | BPF_PROG_TYPE(BPF_PROG_TYPE_KPROBE, kprobe, |
40 | bpf_user_pt_regs_t, struct pt_regs) | |
41 | BPF_PROG_TYPE(BPF_PROG_TYPE_TRACEPOINT, tracepoint, | |
42 | __u64, u64) | |
43 | BPF_PROG_TYPE(BPF_PROG_TYPE_PERF_EVENT, perf_event, | |
44 | struct bpf_perf_event_data, struct bpf_perf_event_data_kern) | |
45 | BPF_PROG_TYPE(BPF_PROG_TYPE_RAW_TRACEPOINT, raw_tracepoint, | |
46 | struct bpf_raw_tracepoint_args, u64) | |
47 | BPF_PROG_TYPE(BPF_PROG_TYPE_RAW_TRACEPOINT_WRITABLE, raw_tracepoint_writable, | |
48 | struct bpf_raw_tracepoint_args, u64) | |
49 | BPF_PROG_TYPE(BPF_PROG_TYPE_TRACING, tracing, | |
50 | void *, void *) | |
be9370a7 | 51 | #endif |
ebc614f6 | 52 | #ifdef CONFIG_CGROUP_BPF |
91cc1a99 AS |
53 | BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_DEVICE, cg_dev, |
54 | struct bpf_cgroup_dev_ctx, struct bpf_cgroup_dev_ctx) | |
55 | BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SYSCTL, cg_sysctl, | |
56 | struct bpf_sysctl, struct bpf_sysctl_kern) | |
57 | BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SOCKOPT, cg_sockopt, | |
58 | struct bpf_sockopt, struct bpf_sockopt_kern) | |
ebc614f6 | 59 | #endif |
f4364dcf | 60 | #ifdef CONFIG_BPF_LIRC_MODE2 |
91cc1a99 AS |
61 | BPF_PROG_TYPE(BPF_PROG_TYPE_LIRC_MODE2, lirc_mode2, |
62 | __u32, u32) | |
f4364dcf | 63 | #endif |
2dbb9b9e | 64 | #ifdef CONFIG_INET |
91cc1a99 AS |
65 | BPF_PROG_TYPE(BPF_PROG_TYPE_SK_REUSEPORT, sk_reuseport, |
66 | struct sk_reuseport_md, struct sk_reuseport_kern) | |
e9ddbb77 JS |
67 | BPF_PROG_TYPE(BPF_PROG_TYPE_SK_LOOKUP, sk_lookup, |
68 | struct bpf_sk_lookup, struct bpf_sk_lookup_kern) | |
2dbb9b9e | 69 | #endif |
27ae7997 MKL |
70 | #if defined(CONFIG_BPF_JIT) |
71 | BPF_PROG_TYPE(BPF_PROG_TYPE_STRUCT_OPS, bpf_struct_ops, | |
72 | void *, void *) | |
be8704ff AS |
73 | BPF_PROG_TYPE(BPF_PROG_TYPE_EXT, bpf_extension, |
74 | void *, void *) | |
fc611f47 KS |
75 | #ifdef CONFIG_BPF_LSM |
76 | BPF_PROG_TYPE(BPF_PROG_TYPE_LSM, lsm, | |
77 | void *, void *) | |
78 | #endif /* CONFIG_BPF_LSM */ | |
27ae7997 | 79 | #endif |
79a7f8bd AS |
80 | BPF_PROG_TYPE(BPF_PROG_TYPE_SYSCALL, bpf_syscall, |
81 | void *, void *) | |
6d26d985 | 82 | #ifdef CONFIG_NETFILTER_BPF_LINK |
fd9c663b FW |
83 | BPF_PROG_TYPE(BPF_PROG_TYPE_NETFILTER, netfilter, |
84 | struct bpf_nf_ctx, struct bpf_nf_ctx) | |
85 | #endif | |
40077e0c JB |
86 | |
87 | BPF_MAP_TYPE(BPF_MAP_TYPE_ARRAY, array_map_ops) | |
88 | BPF_MAP_TYPE(BPF_MAP_TYPE_PERCPU_ARRAY, percpu_array_map_ops) | |
89 | BPF_MAP_TYPE(BPF_MAP_TYPE_PROG_ARRAY, prog_array_map_ops) | |
90 | BPF_MAP_TYPE(BPF_MAP_TYPE_PERF_EVENT_ARRAY, perf_event_array_map_ops) | |
91 | #ifdef CONFIG_CGROUPS | |
92 | BPF_MAP_TYPE(BPF_MAP_TYPE_CGROUP_ARRAY, cgroup_array_map_ops) | |
c4bcfb38 | 93 | BPF_MAP_TYPE(BPF_MAP_TYPE_CGRP_STORAGE, cgrp_storage_map_ops) |
40077e0c | 94 | #endif |
de9cbbaa RG |
95 | #ifdef CONFIG_CGROUP_BPF |
96 | BPF_MAP_TYPE(BPF_MAP_TYPE_CGROUP_STORAGE, cgroup_storage_map_ops) | |
b741f163 | 97 | BPF_MAP_TYPE(BPF_MAP_TYPE_PERCPU_CGROUP_STORAGE, cgroup_storage_map_ops) |
de9cbbaa | 98 | #endif |
40077e0c JB |
99 | BPF_MAP_TYPE(BPF_MAP_TYPE_HASH, htab_map_ops) |
100 | BPF_MAP_TYPE(BPF_MAP_TYPE_PERCPU_HASH, htab_percpu_map_ops) | |
101 | BPF_MAP_TYPE(BPF_MAP_TYPE_LRU_HASH, htab_lru_map_ops) | |
102 | BPF_MAP_TYPE(BPF_MAP_TYPE_LRU_PERCPU_HASH, htab_lru_percpu_map_ops) | |
103 | BPF_MAP_TYPE(BPF_MAP_TYPE_LPM_TRIE, trie_map_ops) | |
104 | #ifdef CONFIG_PERF_EVENTS | |
14499160 | 105 | BPF_MAP_TYPE(BPF_MAP_TYPE_STACK_TRACE, stack_trace_map_ops) |
40077e0c JB |
106 | #endif |
107 | BPF_MAP_TYPE(BPF_MAP_TYPE_ARRAY_OF_MAPS, array_of_maps_map_ops) | |
108 | BPF_MAP_TYPE(BPF_MAP_TYPE_HASH_OF_MAPS, htab_of_maps_map_ops) | |
8ea63684 KS |
109 | #ifdef CONFIG_BPF_LSM |
110 | BPF_MAP_TYPE(BPF_MAP_TYPE_INODE_STORAGE, inode_storage_map_ops) | |
111 | #endif | |
a10787e6 | 112 | BPF_MAP_TYPE(BPF_MAP_TYPE_TASK_STORAGE, task_storage_map_ops) |
99d0a383 TH |
113 | #ifdef CONFIG_NET |
114 | BPF_MAP_TYPE(BPF_MAP_TYPE_DEVMAP, dev_map_ops) | |
115 | BPF_MAP_TYPE(BPF_MAP_TYPE_DEVMAP_HASH, dev_map_hash_ops) | |
116 | BPF_MAP_TYPE(BPF_MAP_TYPE_SK_STORAGE, sk_storage_map_ops) | |
6710e112 | 117 | BPF_MAP_TYPE(BPF_MAP_TYPE_CPUMAP, cpu_map_ops) |
fbfc504a BT |
118 | #if defined(CONFIG_XDP_SOCKETS) |
119 | BPF_MAP_TYPE(BPF_MAP_TYPE_XSKMAP, xsk_map_ops) | |
120 | #endif | |
5dc4c4b7 | 121 | #ifdef CONFIG_INET |
88759609 CW |
122 | BPF_MAP_TYPE(BPF_MAP_TYPE_SOCKMAP, sock_map_ops) |
123 | BPF_MAP_TYPE(BPF_MAP_TYPE_SOCKHASH, sock_hash_ops) | |
5dc4c4b7 MKL |
124 | BPF_MAP_TYPE(BPF_MAP_TYPE_REUSEPORT_SOCKARRAY, reuseport_array_ops) |
125 | #endif | |
6bdc9c4c | 126 | #endif |
f1a2e44a MV |
127 | BPF_MAP_TYPE(BPF_MAP_TYPE_QUEUE, queue_map_ops) |
128 | BPF_MAP_TYPE(BPF_MAP_TYPE_STACK, stack_map_ops) | |
85d33df3 MKL |
129 | #if defined(CONFIG_BPF_JIT) |
130 | BPF_MAP_TYPE(BPF_MAP_TYPE_STRUCT_OPS, bpf_struct_ops_map_ops) | |
131 | #endif | |
457f4436 | 132 | BPF_MAP_TYPE(BPF_MAP_TYPE_RINGBUF, ringbuf_map_ops) |
9330986c | 133 | BPF_MAP_TYPE(BPF_MAP_TYPE_BLOOM_FILTER, bloom_filter_map_ops) |
583c1f42 | 134 | BPF_MAP_TYPE(BPF_MAP_TYPE_USER_RINGBUF, user_ringbuf_map_ops) |
f2e10bff AN |
135 | |
136 | BPF_LINK_TYPE(BPF_LINK_TYPE_RAW_TRACEPOINT, raw_tracepoint) | |
137 | BPF_LINK_TYPE(BPF_LINK_TYPE_TRACING, tracing) | |
138 | #ifdef CONFIG_CGROUP_BPF | |
139 | BPF_LINK_TYPE(BPF_LINK_TYPE_CGROUP, cgroup) | |
140 | #endif | |
de4e05ca | 141 | BPF_LINK_TYPE(BPF_LINK_TYPE_ITER, iter) |
7f045a49 JS |
142 | #ifdef CONFIG_NET |
143 | BPF_LINK_TYPE(BPF_LINK_TYPE_NETNS, netns) | |
d6371c76 | 144 | BPF_LINK_TYPE(BPF_LINK_TYPE_XDP, xdp) |
7f045a49 | 145 | #endif |
b89fbfbb AN |
146 | #ifdef CONFIG_PERF_EVENTS |
147 | BPF_LINK_TYPE(BPF_LINK_TYPE_PERF_EVENT, perf) | |
148 | #endif | |
0dcac272 | 149 | BPF_LINK_TYPE(BPF_LINK_TYPE_KPROBE_MULTI, kprobe_multi) |
f7e0beaf | 150 | BPF_LINK_TYPE(BPF_LINK_TYPE_STRUCT_OPS, struct_ops) |