selftests/bpf: Add tests for write-only stacks/queues
[linux-block.git] / include / linux / bpf_types.h
CommitLineData
b2441318 1/* SPDX-License-Identifier: GPL-2.0 */
be9370a7
JB
2/* internal file - do not include directly */
3
4#ifdef CONFIG_NET
91cc1a99
AS
5BPF_PROG_TYPE(BPF_PROG_TYPE_SOCKET_FILTER, sk_filter,
6 struct __sk_buff, struct sk_buff)
7BPF_PROG_TYPE(BPF_PROG_TYPE_SCHED_CLS, tc_cls_act,
8 struct __sk_buff, struct sk_buff)
9BPF_PROG_TYPE(BPF_PROG_TYPE_SCHED_ACT, tc_cls_act,
10 struct __sk_buff, struct sk_buff)
11BPF_PROG_TYPE(BPF_PROG_TYPE_XDP, xdp,
12 struct xdp_md, struct xdp_buff)
befa6181 13#ifdef CONFIG_CGROUP_BPF
91cc1a99
AS
14BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SKB, cg_skb,
15 struct __sk_buff, struct sk_buff)
16BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SOCK, cg_sock,
17 struct bpf_sock, struct sock)
18BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SOCK_ADDR, cg_sock_addr,
19 struct bpf_sock_addr, struct bpf_sock_addr_kern)
20#endif
21BPF_PROG_TYPE(BPF_PROG_TYPE_LWT_IN, lwt_in,
22 struct __sk_buff, struct sk_buff)
23BPF_PROG_TYPE(BPF_PROG_TYPE_LWT_OUT, lwt_out,
24 struct __sk_buff, struct sk_buff)
25BPF_PROG_TYPE(BPF_PROG_TYPE_LWT_XMIT, lwt_xmit,
26 struct __sk_buff, struct sk_buff)
27BPF_PROG_TYPE(BPF_PROG_TYPE_LWT_SEG6LOCAL, lwt_seg6local,
28 struct __sk_buff, struct sk_buff)
29BPF_PROG_TYPE(BPF_PROG_TYPE_SOCK_OPS, sock_ops,
30 struct bpf_sock_ops, struct bpf_sock_ops_kern)
31BPF_PROG_TYPE(BPF_PROG_TYPE_SK_SKB, sk_skb,
32 struct __sk_buff, struct sk_buff)
33BPF_PROG_TYPE(BPF_PROG_TYPE_SK_MSG, sk_msg,
34 struct sk_msg_md, struct sk_msg)
35BPF_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
39BPF_PROG_TYPE(BPF_PROG_TYPE_KPROBE, kprobe,
40 bpf_user_pt_regs_t, struct pt_regs)
41BPF_PROG_TYPE(BPF_PROG_TYPE_TRACEPOINT, tracepoint,
42 __u64, u64)
43BPF_PROG_TYPE(BPF_PROG_TYPE_PERF_EVENT, perf_event,
44 struct bpf_perf_event_data, struct bpf_perf_event_data_kern)
45BPF_PROG_TYPE(BPF_PROG_TYPE_RAW_TRACEPOINT, raw_tracepoint,
46 struct bpf_raw_tracepoint_args, u64)
47BPF_PROG_TYPE(BPF_PROG_TYPE_RAW_TRACEPOINT_WRITABLE, raw_tracepoint_writable,
48 struct bpf_raw_tracepoint_args, u64)
49BPF_PROG_TYPE(BPF_PROG_TYPE_TRACING, tracing,
50 void *, void *)
be9370a7 51#endif
ebc614f6 52#ifdef CONFIG_CGROUP_BPF
91cc1a99
AS
53BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_DEVICE, cg_dev,
54 struct bpf_cgroup_dev_ctx, struct bpf_cgroup_dev_ctx)
55BPF_PROG_TYPE(BPF_PROG_TYPE_CGROUP_SYSCTL, cg_sysctl,
56 struct bpf_sysctl, struct bpf_sysctl_kern)
57BPF_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
61BPF_PROG_TYPE(BPF_PROG_TYPE_LIRC_MODE2, lirc_mode2,
62 __u32, u32)
f4364dcf 63#endif
2dbb9b9e 64#ifdef CONFIG_INET
91cc1a99
AS
65BPF_PROG_TYPE(BPF_PROG_TYPE_SK_REUSEPORT, sk_reuseport,
66 struct sk_reuseport_md, struct sk_reuseport_kern)
2dbb9b9e 67#endif
27ae7997
MKL
68#if defined(CONFIG_BPF_JIT)
69BPF_PROG_TYPE(BPF_PROG_TYPE_STRUCT_OPS, bpf_struct_ops,
70 void *, void *)
be8704ff
AS
71BPF_PROG_TYPE(BPF_PROG_TYPE_EXT, bpf_extension,
72 void *, void *)
fc611f47
KS
73#ifdef CONFIG_BPF_LSM
74BPF_PROG_TYPE(BPF_PROG_TYPE_LSM, lsm,
75 void *, void *)
76#endif /* CONFIG_BPF_LSM */
27ae7997 77#endif
40077e0c
JB
78
79BPF_MAP_TYPE(BPF_MAP_TYPE_ARRAY, array_map_ops)
80BPF_MAP_TYPE(BPF_MAP_TYPE_PERCPU_ARRAY, percpu_array_map_ops)
81BPF_MAP_TYPE(BPF_MAP_TYPE_PROG_ARRAY, prog_array_map_ops)
82BPF_MAP_TYPE(BPF_MAP_TYPE_PERF_EVENT_ARRAY, perf_event_array_map_ops)
83#ifdef CONFIG_CGROUPS
84BPF_MAP_TYPE(BPF_MAP_TYPE_CGROUP_ARRAY, cgroup_array_map_ops)
85#endif
de9cbbaa
RG
86#ifdef CONFIG_CGROUP_BPF
87BPF_MAP_TYPE(BPF_MAP_TYPE_CGROUP_STORAGE, cgroup_storage_map_ops)
b741f163 88BPF_MAP_TYPE(BPF_MAP_TYPE_PERCPU_CGROUP_STORAGE, cgroup_storage_map_ops)
de9cbbaa 89#endif
40077e0c
JB
90BPF_MAP_TYPE(BPF_MAP_TYPE_HASH, htab_map_ops)
91BPF_MAP_TYPE(BPF_MAP_TYPE_PERCPU_HASH, htab_percpu_map_ops)
92BPF_MAP_TYPE(BPF_MAP_TYPE_LRU_HASH, htab_lru_map_ops)
93BPF_MAP_TYPE(BPF_MAP_TYPE_LRU_PERCPU_HASH, htab_lru_percpu_map_ops)
94BPF_MAP_TYPE(BPF_MAP_TYPE_LPM_TRIE, trie_map_ops)
95#ifdef CONFIG_PERF_EVENTS
14499160 96BPF_MAP_TYPE(BPF_MAP_TYPE_STACK_TRACE, stack_trace_map_ops)
40077e0c
JB
97#endif
98BPF_MAP_TYPE(BPF_MAP_TYPE_ARRAY_OF_MAPS, array_of_maps_map_ops)
99BPF_MAP_TYPE(BPF_MAP_TYPE_HASH_OF_MAPS, htab_of_maps_map_ops)
546ac1ff
JF
100#ifdef CONFIG_NET
101BPF_MAP_TYPE(BPF_MAP_TYPE_DEVMAP, dev_map_ops)
6f9d451a 102BPF_MAP_TYPE(BPF_MAP_TYPE_DEVMAP_HASH, dev_map_hash_ops)
6ac99e8f 103BPF_MAP_TYPE(BPF_MAP_TYPE_SK_STORAGE, sk_storage_map_ops)
604326b4 104#if defined(CONFIG_BPF_STREAM_PARSER)
174a79ff 105BPF_MAP_TYPE(BPF_MAP_TYPE_SOCKMAP, sock_map_ops)
81110384 106BPF_MAP_TYPE(BPF_MAP_TYPE_SOCKHASH, sock_hash_ops)
546ac1ff 107#endif
6710e112 108BPF_MAP_TYPE(BPF_MAP_TYPE_CPUMAP, cpu_map_ops)
fbfc504a
BT
109#if defined(CONFIG_XDP_SOCKETS)
110BPF_MAP_TYPE(BPF_MAP_TYPE_XSKMAP, xsk_map_ops)
111#endif
5dc4c4b7
MKL
112#ifdef CONFIG_INET
113BPF_MAP_TYPE(BPF_MAP_TYPE_REUSEPORT_SOCKARRAY, reuseport_array_ops)
114#endif
6bdc9c4c 115#endif
f1a2e44a
MV
116BPF_MAP_TYPE(BPF_MAP_TYPE_QUEUE, queue_map_ops)
117BPF_MAP_TYPE(BPF_MAP_TYPE_STACK, stack_map_ops)
85d33df3
MKL
118#if defined(CONFIG_BPF_JIT)
119BPF_MAP_TYPE(BPF_MAP_TYPE_STRUCT_OPS, bpf_struct_ops_map_ops)
120#endif
f2e10bff
AN
121
122BPF_LINK_TYPE(BPF_LINK_TYPE_RAW_TRACEPOINT, raw_tracepoint)
123BPF_LINK_TYPE(BPF_LINK_TYPE_TRACING, tracing)
124#ifdef CONFIG_CGROUP_BPF
125BPF_LINK_TYPE(BPF_LINK_TYPE_CGROUP, cgroup)
126#endif
de4e05ca 127BPF_LINK_TYPE(BPF_LINK_TYPE_ITER, iter)