xref: /linux-6.15/include/linux/bpf_types.h (revision c2f80305)
1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */
2be9370a7SJohannes Berg /* internal file - do not include directly */
3be9370a7SJohannes Berg 
4be9370a7SJohannes Berg #ifdef CONFIG_NET
591cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_SOCKET_FILTER, sk_filter,
691cc1a99SAlexei Starovoitov 	      struct __sk_buff, struct sk_buff)
791cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_SCHED_CLS, tc_cls_act,
891cc1a99SAlexei Starovoitov 	      struct __sk_buff, struct sk_buff)
991cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_SCHED_ACT, tc_cls_act,
1091cc1a99SAlexei Starovoitov 	      struct __sk_buff, struct sk_buff)
1191cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_XDP, xdp,
1291cc1a99SAlexei Starovoitov 	      struct xdp_md, struct xdp_buff)
13befa6181SStanislav Fomichev #ifdef CONFIG_CGROUP_BPF
1491cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SKB, cg_skb,
1591cc1a99SAlexei Starovoitov 	      struct __sk_buff, struct sk_buff)
1691cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SOCK, cg_sock,
1791cc1a99SAlexei Starovoitov 	      struct bpf_sock, struct sock)
1891cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SOCK_ADDR, cg_sock_addr,
1991cc1a99SAlexei Starovoitov 	      struct bpf_sock_addr, struct bpf_sock_addr_kern)
20befa6181SStanislav Fomichev #endif
2191cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_LWT_IN, lwt_in,
2291cc1a99SAlexei Starovoitov 	      struct __sk_buff, struct sk_buff)
2391cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_LWT_OUT, lwt_out,
2491cc1a99SAlexei Starovoitov 	      struct __sk_buff, struct sk_buff)
2591cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_LWT_XMIT, lwt_xmit,
2691cc1a99SAlexei Starovoitov 	      struct __sk_buff, struct sk_buff)
2791cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_LWT_SEG6LOCAL, lwt_seg6local,
2891cc1a99SAlexei Starovoitov 	      struct __sk_buff, struct sk_buff)
2991cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_SOCK_OPS, sock_ops,
3091cc1a99SAlexei Starovoitov 	      struct bpf_sock_ops, struct bpf_sock_ops_kern)
3191cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_SK_SKB, sk_skb,
3291cc1a99SAlexei Starovoitov 	      struct __sk_buff, struct sk_buff)
3391cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_SK_MSG, sk_msg,
3491cc1a99SAlexei Starovoitov 	      struct sk_msg_md, struct sk_msg)
3591cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_FLOW_DISSECTOR, flow_dissector,
3691cc1a99SAlexei Starovoitov 	      struct __sk_buff, struct bpf_flow_dissector)
37be9370a7SJohannes Berg #endif
38be9370a7SJohannes Berg #ifdef CONFIG_BPF_EVENTS
3991cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_KPROBE, kprobe,
4091cc1a99SAlexei Starovoitov 	      bpf_user_pt_regs_t, struct pt_regs)
4191cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_TRACEPOINT, tracepoint,
4291cc1a99SAlexei Starovoitov 	      __u64, u64)
4391cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_PERF_EVENT, perf_event,
4491cc1a99SAlexei Starovoitov 	      struct bpf_perf_event_data, struct bpf_perf_event_data_kern)
4591cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_RAW_TRACEPOINT, raw_tracepoint,
4691cc1a99SAlexei Starovoitov 	      struct bpf_raw_tracepoint_args, u64)
4791cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_RAW_TRACEPOINT_WRITABLE, raw_tracepoint_writable,
4891cc1a99SAlexei Starovoitov 	      struct bpf_raw_tracepoint_args, u64)
4991cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_TRACING, tracing,
5091cc1a99SAlexei Starovoitov 	      void *, void *)
51be9370a7SJohannes Berg #endif
52ebc614f6SRoman Gushchin #ifdef CONFIG_CGROUP_BPF
5391cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_DEVICE, cg_dev,
5491cc1a99SAlexei Starovoitov 	      struct bpf_cgroup_dev_ctx, struct bpf_cgroup_dev_ctx)
5591cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SYSCTL, cg_sysctl,
5691cc1a99SAlexei Starovoitov 	      struct bpf_sysctl, struct bpf_sysctl_kern)
5791cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SOCKOPT, cg_sockopt,
5891cc1a99SAlexei Starovoitov 	      struct bpf_sockopt, struct bpf_sockopt_kern)
59ebc614f6SRoman Gushchin #endif
60f4364dcfSSean Young #ifdef CONFIG_BPF_LIRC_MODE2
6191cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_LIRC_MODE2, lirc_mode2,
6291cc1a99SAlexei Starovoitov 	      __u32, u32)
63f4364dcfSSean Young #endif
642dbb9b9eSMartin KaFai Lau #ifdef CONFIG_INET
6591cc1a99SAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_SK_REUSEPORT, sk_reuseport,
6691cc1a99SAlexei Starovoitov 	      struct sk_reuseport_md, struct sk_reuseport_kern)
67e9ddbb77SJakub Sitnicki BPF_PROG_TYPE(BPF_PROG_TYPE_SK_LOOKUP, sk_lookup,
68e9ddbb77SJakub Sitnicki 	      struct bpf_sk_lookup, struct bpf_sk_lookup_kern)
692dbb9b9eSMartin KaFai Lau #endif
7027ae7997SMartin KaFai Lau #if defined(CONFIG_BPF_JIT)
7127ae7997SMartin KaFai Lau BPF_PROG_TYPE(BPF_PROG_TYPE_STRUCT_OPS, bpf_struct_ops,
7227ae7997SMartin KaFai Lau 	      void *, void *)
73be8704ffSAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_EXT, bpf_extension,
74be8704ffSAlexei Starovoitov 	      void *, void *)
75fc611f47SKP Singh #ifdef CONFIG_BPF_LSM
76fc611f47SKP Singh BPF_PROG_TYPE(BPF_PROG_TYPE_LSM, lsm,
77fc611f47SKP Singh 	       void *, void *)
78fc611f47SKP Singh #endif /* CONFIG_BPF_LSM */
7927ae7997SMartin KaFai Lau #endif
8079a7f8bdSAlexei Starovoitov BPF_PROG_TYPE(BPF_PROG_TYPE_SYSCALL, bpf_syscall,
8179a7f8bdSAlexei Starovoitov 	      void *, void *)
826d26d985SFlorian Westphal #ifdef CONFIG_NETFILTER_BPF_LINK
83fd9c663bSFlorian Westphal BPF_PROG_TYPE(BPF_PROG_TYPE_NETFILTER, netfilter,
84fd9c663bSFlorian Westphal 	      struct bpf_nf_ctx, struct bpf_nf_ctx)
85fd9c663bSFlorian Westphal #endif
8640077e0cSJohannes Berg 
8740077e0cSJohannes Berg BPF_MAP_TYPE(BPF_MAP_TYPE_ARRAY, array_map_ops)
8840077e0cSJohannes Berg BPF_MAP_TYPE(BPF_MAP_TYPE_PERCPU_ARRAY, percpu_array_map_ops)
8940077e0cSJohannes Berg BPF_MAP_TYPE(BPF_MAP_TYPE_PROG_ARRAY, prog_array_map_ops)
9040077e0cSJohannes Berg BPF_MAP_TYPE(BPF_MAP_TYPE_PERF_EVENT_ARRAY, perf_event_array_map_ops)
9140077e0cSJohannes Berg #ifdef CONFIG_CGROUPS
9240077e0cSJohannes Berg BPF_MAP_TYPE(BPF_MAP_TYPE_CGROUP_ARRAY, cgroup_array_map_ops)
93c4bcfb38SYonghong Song BPF_MAP_TYPE(BPF_MAP_TYPE_CGRP_STORAGE, cgrp_storage_map_ops)
9440077e0cSJohannes Berg #endif
95de9cbbaaSRoman Gushchin #ifdef CONFIG_CGROUP_BPF
96de9cbbaaSRoman Gushchin BPF_MAP_TYPE(BPF_MAP_TYPE_CGROUP_STORAGE, cgroup_storage_map_ops)
97b741f163SRoman Gushchin BPF_MAP_TYPE(BPF_MAP_TYPE_PERCPU_CGROUP_STORAGE, cgroup_storage_map_ops)
98de9cbbaaSRoman Gushchin #endif
9940077e0cSJohannes Berg BPF_MAP_TYPE(BPF_MAP_TYPE_HASH, htab_map_ops)
10040077e0cSJohannes Berg BPF_MAP_TYPE(BPF_MAP_TYPE_PERCPU_HASH, htab_percpu_map_ops)
10140077e0cSJohannes Berg BPF_MAP_TYPE(BPF_MAP_TYPE_LRU_HASH, htab_lru_map_ops)
10240077e0cSJohannes Berg BPF_MAP_TYPE(BPF_MAP_TYPE_LRU_PERCPU_HASH, htab_lru_percpu_map_ops)
10340077e0cSJohannes Berg BPF_MAP_TYPE(BPF_MAP_TYPE_LPM_TRIE, trie_map_ops)
10440077e0cSJohannes Berg #ifdef CONFIG_PERF_EVENTS
10514499160SMauricio Vasquez B BPF_MAP_TYPE(BPF_MAP_TYPE_STACK_TRACE, stack_trace_map_ops)
10640077e0cSJohannes Berg #endif
10740077e0cSJohannes Berg BPF_MAP_TYPE(BPF_MAP_TYPE_ARRAY_OF_MAPS, array_of_maps_map_ops)
10840077e0cSJohannes Berg BPF_MAP_TYPE(BPF_MAP_TYPE_HASH_OF_MAPS, htab_of_maps_map_ops)
1098ea63684SKP Singh #ifdef CONFIG_BPF_LSM
1108ea63684SKP Singh BPF_MAP_TYPE(BPF_MAP_TYPE_INODE_STORAGE, inode_storage_map_ops)
1118ea63684SKP Singh #endif
112a10787e6SSong Liu BPF_MAP_TYPE(BPF_MAP_TYPE_TASK_STORAGE, task_storage_map_ops)
11399d0a383STejun Heo #ifdef CONFIG_NET
11499d0a383STejun Heo BPF_MAP_TYPE(BPF_MAP_TYPE_DEVMAP, dev_map_ops)
11599d0a383STejun Heo BPF_MAP_TYPE(BPF_MAP_TYPE_DEVMAP_HASH, dev_map_hash_ops)
11699d0a383STejun Heo BPF_MAP_TYPE(BPF_MAP_TYPE_SK_STORAGE, sk_storage_map_ops)
1176710e112SJesper Dangaard Brouer BPF_MAP_TYPE(BPF_MAP_TYPE_CPUMAP, cpu_map_ops)
118fbfc504aSBjörn Töpel #if defined(CONFIG_XDP_SOCKETS)
119fbfc504aSBjörn Töpel BPF_MAP_TYPE(BPF_MAP_TYPE_XSKMAP, xsk_map_ops)
120fbfc504aSBjörn Töpel #endif
1215dc4c4b7SMartin KaFai Lau #ifdef CONFIG_INET
12288759609SCong Wang BPF_MAP_TYPE(BPF_MAP_TYPE_SOCKMAP, sock_map_ops)
12388759609SCong Wang BPF_MAP_TYPE(BPF_MAP_TYPE_SOCKHASH, sock_hash_ops)
1245dc4c4b7SMartin KaFai Lau BPF_MAP_TYPE(BPF_MAP_TYPE_REUSEPORT_SOCKARRAY, reuseport_array_ops)
1255dc4c4b7SMartin KaFai Lau #endif
1266bdc9c4cSJohn Fastabend #endif
127f1a2e44aSMauricio Vasquez B BPF_MAP_TYPE(BPF_MAP_TYPE_QUEUE, queue_map_ops)
128f1a2e44aSMauricio Vasquez B BPF_MAP_TYPE(BPF_MAP_TYPE_STACK, stack_map_ops)
12985d33df3SMartin KaFai Lau #if defined(CONFIG_BPF_JIT)
13085d33df3SMartin KaFai Lau BPF_MAP_TYPE(BPF_MAP_TYPE_STRUCT_OPS, bpf_struct_ops_map_ops)
13185d33df3SMartin KaFai Lau #endif
132457f4436SAndrii Nakryiko BPF_MAP_TYPE(BPF_MAP_TYPE_RINGBUF, ringbuf_map_ops)
1339330986cSJoanne Koong BPF_MAP_TYPE(BPF_MAP_TYPE_BLOOM_FILTER, bloom_filter_map_ops)
134583c1f42SDavid Vernet BPF_MAP_TYPE(BPF_MAP_TYPE_USER_RINGBUF, user_ringbuf_map_ops)
13531746031SAlexei Starovoitov BPF_MAP_TYPE(BPF_MAP_TYPE_ARENA, arena_map_ops)
136f2e10bffSAndrii Nakryiko 
137f2e10bffSAndrii Nakryiko BPF_LINK_TYPE(BPF_LINK_TYPE_RAW_TRACEPOINT, raw_tracepoint)
138f2e10bffSAndrii Nakryiko BPF_LINK_TYPE(BPF_LINK_TYPE_TRACING, tracing)
139f2e10bffSAndrii Nakryiko #ifdef CONFIG_CGROUP_BPF
140f2e10bffSAndrii Nakryiko BPF_LINK_TYPE(BPF_LINK_TYPE_CGROUP, cgroup)
141f2e10bffSAndrii Nakryiko #endif
142de4e05caSYonghong Song BPF_LINK_TYPE(BPF_LINK_TYPE_ITER, iter)
1437f045a49SJakub Sitnicki #ifdef CONFIG_NET
1447f045a49SJakub Sitnicki BPF_LINK_TYPE(BPF_LINK_TYPE_NETNS, netns)
145d6371c76SLorenz Bauer BPF_LINK_TYPE(BPF_LINK_TYPE_XDP, xdp)
146117211aaSJiri Olsa BPF_LINK_TYPE(BPF_LINK_TYPE_NETFILTER, netfilter)
147117211aaSJiri Olsa BPF_LINK_TYPE(BPF_LINK_TYPE_TCX, tcx)
148117211aaSJiri Olsa BPF_LINK_TYPE(BPF_LINK_TYPE_NETKIT, netkit)
149*c2f80305SHou Tao BPF_LINK_TYPE(BPF_LINK_TYPE_SOCKMAP, sockmap)
1507f045a49SJakub Sitnicki #endif
151b89fbfbbSAndrii Nakryiko #ifdef CONFIG_PERF_EVENTS
152b89fbfbbSAndrii Nakryiko BPF_LINK_TYPE(BPF_LINK_TYPE_PERF_EVENT, perf)
153b89fbfbbSAndrii Nakryiko #endif
1540dcac272SJiri Olsa BPF_LINK_TYPE(BPF_LINK_TYPE_KPROBE_MULTI, kprobe_multi)
155f7e0beafSKui-Feng Lee BPF_LINK_TYPE(BPF_LINK_TYPE_STRUCT_OPS, struct_ops)
156117211aaSJiri Olsa BPF_LINK_TYPE(BPF_LINK_TYPE_UPROBE_MULTI, uprobe_multi)
157