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