| /linux/drivers/net/ethernet/netronome/nfp/bpf/ |
| A D | main.c | 223 if (bpf->adjust_head.off_min > bpf->adjust_head.off_max) { in nfp_bpf_parse_cap_adjust_head() 230 memset(&bpf->adjust_head, 0, sizeof(bpf->adjust_head)); in nfp_bpf_parse_cap_adjust_head() 327 if (bpf->abi_version < 2 || bpf->abi_version > 3) { in nfp_bpf_parse_cap_abi_version() 449 bpf->cmsg_cache_cnt = nfp_bpf_ctrl_cmsg_cache_cnt(bpf); in nfp_bpf_start() 461 bpf = kzalloc(sizeof(*bpf), GFP_KERNEL); in nfp_bpf_init() 462 if (!bpf) in nfp_bpf_init() 487 bpf->cmsg_key_sz = bpf->maps.max_key_sz; in nfp_bpf_init() 488 bpf->cmsg_val_sz = bpf->maps.max_val_sz; in nfp_bpf_init() 504 kfree(bpf); in nfp_bpf_init() 515 WARN_ON(bpf->maps_in_use || bpf->map_elems_in_use); in nfp_bpf_clean() [all …]
|
| A D | cmsg.c | 34 size += (bpf->cmsg_key_sz + bpf->cmsg_val_sz) * n; in nfp_bpf_cmsg_map_req_size() 42 return nfp_bpf_cmsg_alloc(bpf, nfp_bpf_cmsg_map_req_size(bpf, n)); in nfp_bpf_cmsg_map_req_alloc() 51 size += (bpf->cmsg_key_sz + bpf->cmsg_val_sz) * n; in nfp_bpf_cmsg_map_reply_size() 155 return &req->data[bpf->cmsg_key_sz * n + bpf->cmsg_val_sz * n]; in nfp_bpf_ctrl_req_key() 162 return &req->data[bpf->cmsg_key_sz * (n + 1) + bpf->cmsg_val_sz * n]; in nfp_bpf_ctrl_req_val() 169 return &reply->data[bpf->cmsg_key_sz * n + bpf->cmsg_val_sz * n]; in nfp_bpf_ctrl_reply_key() 176 return &reply->data[bpf->cmsg_key_sz * (n + 1) + bpf->cmsg_val_sz * n]; in nfp_bpf_ctrl_reply_val() 203 struct nfp_app_bpf *bpf = nfp_map->bpf; in nfp_bpf_ctrl_op_cache_get() local 297 struct nfp_app_bpf *bpf = nfp_map->bpf; in nfp_bpf_ctrl_entry_op() local 435 entry_sz = bpf->cmsg_key_sz + bpf->cmsg_val_sz; in nfp_bpf_ctrl_cmsg_cache_cnt() [all …]
|
| A D | offload.c | 139 nfp_map_ptrs_forget(bpf, nfp_prog); in nfp_map_ptrs_record() 338 if (!bpf->maps.types) in nfp_bpf_map_alloc() 351 if (bpf->maps.max_maps == bpf->maps_in_use) { in nfp_bpf_map_alloc() 355 if (bpf->maps.max_elems - bpf->map_elems_in_use < in nfp_bpf_map_alloc() 359 bpf->maps.max_elems - bpf->map_elems_in_use); in nfp_bpf_map_alloc() 368 bpf->maps.max_elem_sz); in nfp_bpf_map_alloc() 391 nfp_map->bpf = bpf; in nfp_bpf_map_alloc() 402 bpf->maps_in_use++; in nfp_bpf_map_alloc() 414 nfp_bpf_ctrl_free_map(bpf, nfp_map); in nfp_bpf_map_free() 419 bpf->maps_in_use--; in nfp_bpf_map_free() [all …]
|
| /linux/drivers/hid/bpf/progs/ |
| A D | README | 17 Once a .bpf.c file is accepted here, it is duplicated in `udev-hid-bpf` 30 Just run `sudo udev-hid-bpf install ./my-awesome-fix.bpf.o` 34 - copy the `.bpf.o` you want in `/etc/udev-hid-bpf/` 41 $> cp xppen-ArtistPro16Gen2.bpf.o /etc/udev-hid-bpf/ 42 $> udev-hid-bpf inspect xppen-ArtistPro16Gen2.bpf.o 45 "name": "xppen-ArtistPro16Gen2.bpf.o", 65 # xppen-ArtistPro16Gen2.bpf.o 66 …5A", RUN{program}+="/usr/local/bin/udev-hid-bpf add $sys$devpath /etc/udev-hid-bpf/xppen-ArtistPro… 68 # xppen-ArtistPro16Gen2.bpf.o 69 …5B", RUN{program}+="/usr/local/bin/udev-hid-bpf add $sys$devpath /etc/udev-hid-bpf/xppen-ArtistPro… [all …]
|
| A D | Makefile | 10 BPFTOOL_SRC := $(TOOLS_PATH)/bpf/bpftool 15 LIBBPF_SRC := $(TOOLS_PATH)/lib/bpf 48 SOURCES = $(wildcard *.bpf.c) 49 TARGETS = $(SOURCES:.bpf.c=.bpf.o) 57 %.bpf.o: %.bpf.c vmlinux.h $(BPFOBJ) | $(OUTPUT) 59 $(Q)$(CLANG) -g -O2 --target=bpf -Wall -Werror $(INCLUDES) \
|
| /linux/samples/bpf/ |
| A D | Makefile | 105 always-y += tracex1.bpf.o 106 always-y += tracex3.bpf.o 107 always-y += tracex4.bpf.o 108 always-y += tracex5.bpf.o 109 always-y += tracex6.bpf.o 110 always-y += tracex7.bpf.o 118 always-y += spintest.bpf.o 364 $(obj)/xdp_router_ipv4.bpf.o: $(obj)/xdp_sample.bpf.o 366 $(obj)/%.bpf.o: $(src)/%.bpf.c $(obj)/vmlinux.h $(src)/xdp_sample.bpf.h $(src)/xdp_sample_shared.h 377 xdp_router_ipv4.skel.h-deps := xdp_router_ipv4.bpf.o xdp_sample.bpf.o [all …]
|
| /linux/tools/testing/selftests/bpf/ |
| A D | test_bpftool_build.sh | 23 if [ ! -e tools/bpf/bpftool/Makefile ]; then 92 make_and_clean tools/bpf 96 make -C tools/bpf/runqslower OUTPUT=${KDIR_ROOT_DIR}/tools/bpf/runqslower/ clean 104 make_with_tmpdir tools/bpf O 113 make_and_clean -C tools/bpf/bpftool 115 make_with_tmpdir -C tools/bpf/bpftool OUTPUT 117 make_with_tmpdir -C tools/bpf/bpftool O 122 make_and_clean bpf 142 make_with_tmpdir bpf O 145 cd bpf/bpftool
|
| A D | test_flow_dissector.sh | 27 $bpftool prog loadall $BPF_FILE /sys/fs/bpf/flow \ 31 /sys/fs/bpf/flow/_dissect flow_dissector; then 36 $bpftool prog attach pinned /sys/fs/bpf/flow/_dissect \ 40 /sys/fs/bpf/flow/_dissect flow_dissector; then 46 /sys/fs/bpf/flow/_dissect flow_dissector; then 51 rm -rf /sys/fs/bpf/flow 91 if /bin/mount | grep /sys/fs/bpf > /dev/null; then 96 /bin/mount bpffs /sys/fs/bpf -t bpf
|
| A D | Makefile | 11 BPFDIR := $(LIBDIR)/bpf 13 BPFTOOLDIR := $(TOOLSDIR)/bpf/bpftool 27 BPF_GCC ?= $(shell command -v bpf-gcc;) 124 TEST_GEN_FILES = test_lwt_ip_encap.bpf.o test_tc_edt.bpf.o 525 test_static_linked.skel.h-deps := test_static_linked1.bpf.o test_static_linked2.bpf.o 526 linked_funcs.skel.h-deps := linked_funcs1.bpf.o linked_funcs2.bpf.o 527 linked_vars.skel.h-deps := linked_vars1.bpf.o linked_vars2.bpf.o 528 linked_maps.skel.h-deps := linked_maps1.bpf.o linked_maps2.bpf.o 531 …_subskeleton.skel.h-deps := test_subskeleton_lib2.bpf.o test_subskeleton_lib.bpf.o test_subskeleto… 532 test_subskeleton_lib.skel.h-deps := test_subskeleton_lib2.bpf.o test_subskeleton_lib.bpf.o [all …]
|
| /linux/tools/bpf/bpftool/Documentation/ |
| A D | bpftool-iter.rst | 35 A bpf iterator combines a kernel iterating of particular kernel data (e.g., 40 The *pin* command creates a bpf iterator from *OBJ*, and pin it to *PATH*. 44 Map element bpf iterator requires an additional parameter *MAP* so bpf 45 program can iterate over map elements for that map. User can have a bpf 49 User can then *cat PATH* to see the bpf iterator output. 60 **# bpftool iter pin bpf_iter_netlink.o /sys/fs/bpf/my_netlink** 64 Create a file-based bpf iterator from bpf_iter_netlink.o and pin it 65 to /sys/fs/bpf/my_netlink 67 **# bpftool iter pin bpf_iter_hashmap.o /sys/fs/bpf/my_hashmap map id 20** 71 Create a file-based bpf iterator from bpf_iter_hashmap.o and map with [all …]
|
| /linux/drivers/hid/bpf/ |
| A D | hid_bpf_dispatch.c | 35 .data = hdev->bpf.device_data, in dispatch_hid_bpf_device_event() 45 if (!hdev->bpf.device_data) in dispatch_hid_bpf_device_event() 99 idx = srcu_read_lock(&hdev->bpf.srcu); in dispatch_hid_bpf_raw_requests() 162 if (!hdev->bpf.rdesc_ops) in call_hid_bpf_rdesc_fixup() 255 if (hdev->bpf.device_data) in hid_bpf_allocate_event_data() 258 return __hid_bpf_allocate_data(hdev, &hdev->bpf.device_data, &hdev->bpf.allocated_data); in hid_bpf_allocate_event_data() 622 kfree(hdev->bpf.device_data); in hid_bpf_disconnect_device() 623 hdev->bpf.device_data = NULL; in hid_bpf_disconnect_device() 624 hdev->bpf.allocated_data = 0; in hid_bpf_disconnect_device() 634 hdev->bpf.destroyed = true; in hid_bpf_destroy_device() [all …]
|
| A D | hid_bpf_struct_ops.c | 196 mutex_lock(&hdev->bpf.prog_list_lock); in hid_bpf_reg() 205 if (hdev->bpf.rdesc_ops) { in hid_bpf_reg() 210 hdev->bpf.rdesc_ops = ops; in hid_bpf_reg() 223 synchronize_srcu(&hdev->bpf.srcu); in hid_bpf_reg() 226 mutex_unlock(&hdev->bpf.prog_list_lock); in hid_bpf_reg() 229 if (hdev->bpf.rdesc_ops == ops) in hid_bpf_reg() 230 hdev->bpf.rdesc_ops = NULL; in hid_bpf_reg() 251 mutex_lock(&hdev->bpf.prog_list_lock); in hid_bpf_unreg() 254 synchronize_srcu(&hdev->bpf.srcu); in hid_bpf_unreg() 257 reconnect = hdev->bpf.rdesc_ops == ops; in hid_bpf_unreg() [all …]
|
| /linux/drivers/net/netdevsim/ |
| A D | bpf.c | 207 if (bpf->command == XDP_SETUP_PROG_HW) { in nsim_xdp_set_prog() 208 err = nsim_xdp_offload_prog(ns, bpf); in nsim_xdp_set_prog() 213 xdp_attachment_setup(xdp, bpf); in nsim_xdp_set_prog() 295 if (bpf->prog && bpf->prog->aux->offload) { in nsim_setup_prog_checks() 311 if (!bpf->prog) in nsim_setup_prog_hw_checks() 319 state = bpf->prog->aux->offload->dev_priv; in nsim_setup_prog_hw_checks() 554 switch (bpf->command) { in nsim_bpf() 556 err = nsim_setup_prog_checks(ns, bpf); in nsim_bpf() 562 err = nsim_setup_prog_hw_checks(ns, bpf); in nsim_bpf() 571 return nsim_bpf_map_alloc(ns, bpf->offmap); in nsim_bpf() [all …]
|
| /linux/samples/hid/ |
| A D | Makefile | 13 LIBBPF_SRC = $(TOOLS_PATH)/lib/bpf 120 BPFTOOLDIR := $(TOOLS_PATH)/bpf/bpftool 198 $(obj)/%.bpf.o: $(src)/%.bpf.c $(EXTRA_BPF_HEADERS_SRC) $(obj)/vmlinux.h 204 -c $(filter %.bpf.c,$^) -o $@ 209 hid_mouse.skel.h-deps := hid_mouse.bpf.o 210 hid_surface_dial.skel.h-deps := hid_surface_dial.bpf.o 212 LINKED_BPF_SRCS := $(patsubst %.bpf.o,%.bpf.c,$(foreach skel,$(LINKED_SKELS),$($(skel)-deps))) 215 BPF_OBJS_LINKED := $(patsubst %.bpf.c,$(obj)/%.bpf.o, $(BPF_SRCS_LINKED)) 235 -I$(obj) -I$(srctree)/tools/testing/selftests/bpf/ \ 245 $(OPT) -O2 -mtriple=bpf-pc-linux | $(LLVM_DIS) | \ [all …]
|
| /linux/net/core/ |
| A D | lwt_bpf.c | 120 struct bpf_lwt *bpf; in bpf_input() local 124 if (bpf->in.prog) { in bpf_input() 143 struct bpf_lwt *bpf; in bpf_output() local 147 if (bpf->out.prog) { in bpf_output() 155 bpf->out.name); in bpf_output() 272 struct bpf_lwt *bpf; in bpf_xmit() local 275 if (bpf->xmit.prog) { in bpf_xmit() 323 bpf_lwt_prog_destroy(&bpf->in); in bpf_destroy_state() 378 struct bpf_lwt *bpf; in bpf_build_state() local 397 bpf = bpf_lwt_lwtunnel(newts); in bpf_build_state() [all …]
|
| /linux/kernel/bpf/ |
| A D | net_namespace.c | 85 list_for_each(pos, &net->bpf.links[type]) in link_count() 316 if (!list_empty(&net->bpf.links[type])) { in netns_bpf_prog_attach() 332 attached = net->bpf.progs[type]; in netns_bpf_prog_attach() 353 net->bpf.progs[type] = prog; in netns_bpf_prog_attach() 371 if (!list_empty(&net->bpf.links[type])) in __netns_bpf_prog_detach() 374 attached = net->bpf.progs[type]; in __netns_bpf_prog_detach() 378 net->bpf.progs[type] = NULL; in __netns_bpf_prog_detach() 437 if (net->bpf.progs[type]) { in netns_bpf_link_attach() 534 INIT_LIST_HEAD(&net->bpf.links[type]); in netns_bpf_pernet_init() 551 if (net->bpf.progs[type]) in netns_bpf_pernet_pre_exit() [all …]
|
| A D | cgroup.c | 295 bpf.release_work); in cgroup_bpf_release() 325 cgrp->bpf.effective[atype], in cgroup_bpf_release() 546 desc->bpf.inactive = NULL; in update_effective_progs() 552 desc->bpf.inactive = NULL; in update_effective_progs() 565 desc->bpf.inactive = NULL; in update_effective_progs() 781 head = &cg->bpf.progs[atype]; in replace_effective_prog() 793 desc->bpf.effective[atype], in replace_effective_prog() 933 head = &cg->bpf.progs[atype]; in purge_effective_progs() 947 desc->bpf.effective[atype], in purge_effective_progs() 987 flags = cgrp->bpf.flags[atype]; in __cgroup_bpf_detach() [all …]
|
| /linux/samples/seccomp/ |
| A D | Makefile | 2 userprogs-always-y += bpf-fancy dropper bpf-direct user-trap 4 bpf-fancy-objs := bpf-fancy.o bpf-helper.o
|
| /linux/tools/sched_ext/ |
| A D | Makefile | 45 BPFDIR := $(LIBDIR)/bpf 47 BPFTOOLDIR := $(TOOLSDIR)/bpf/bpftool 120 -I$(CURDIR)/include -I$(CURDIR)/include/bpf-compat \ 137 $(APIDIR)/linux/bpf.h \ 162 $(SCXOBJ_DIR)/%.bpf.o: %.bpf.c $(INCLUDE_DIR)/vmlinux.h include/scx/*.h \ 165 $(Q)$(CLANG) $(BPF_CFLAGS) -target bpf -c $< -o $@ 167 $(INCLUDE_DIR)/%.bpf.skel.h: $(SCXOBJ_DIR)/%.bpf.o $(INCLUDE_DIR)/vmlinux.h $(BPFTOOL) 174 $(Q)$(BPFTOOL) gen skeleton $(<:.o=.linked3.o) name $(subst .bpf.skel.h,,$(sched)) > $@ 183 $(filter-out %.bpf.c,%.c) \ 184 $(INCLUDE_DIR)/%.bpf.skel.h \ [all …]
|
| /linux/Documentation/userspace-api/ebpf/ |
| A D | syscall.rst | 10 The primary info for the bpf syscall is available in the `man-pages`_ 11 for `bpf(2)`_. 13 bpf() subcommand reference 16 .. kernel-doc:: include/uapi/linux/bpf.h 19 .. kernel-doc:: include/uapi/linux/bpf.h 24 .. _bpf(2): https://man7.org/linux/man-pages/man2/bpf.2.html
|
| /linux/Documentation/translations/zh_CN/userspace-api/ebpf/ |
| A D | syscall.rst | 18 bpf syscall的主要信息可以在 `man-pages`_ 中的 `bpf(2)`_ 找到。 20 bpf() 子命令参考 25 include/uapi/linux/bpf.h 29 .. _bpf(2): https://man7.org/linux/man-pages/man2/bpf.2.html
|
| /linux/Documentation/bpf/ |
| A D | bpf_devel_QA.rst | 27 bpf@vger.kernel.org 62 kernel-patches/bpf's bpf-next_base or bpf_base branch, respectively 78 bpf@vger.kernel.org 108 the 'bpf' delegate). 116 * https://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf.git/ 117 * https://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf-next.git/ 119 The bpf tree itself is for fixes only, whereas bpf-next for features, 155 maintainers know whether it is targeted at bpf or bpf-next. 173 If it is clear that patches should go into bpf or bpf-next tree, 225 accumulate too many patches in bpf or bpf-next. [all …]
|
| A D | prog_lsm.rst | 23 eBPF programs that use Documentation/bpf/btf.rst do not need to include kernel 58 macros defined in `tools/lib/bpf/bpf_tracing.h`_. In this 91 Documentation/bpf/btf.rst information. Since the BPF verifier is aware of the 98 eBPF programs can be loaded with the :manpage:`bpf(2)` syscall's 120 The LSM allows attachment of eBPF programs as LSM hooks using :manpage:`bpf(2)` 134 `tools/testing/selftests/bpf/progs/lsm.c`_ and the corresponding 135 userspace code in `tools/testing/selftests/bpf/prog_tests/test_lsm.c`_ 138 .. _tools/lib/bpf/bpf_tracing.h: 139 https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/tree/tools/lib/bpf/bpf_tracing.h 140 .. _tools/testing/selftests/bpf/progs/lsm.c: [all …]
|
| /linux/kernel/bpf/preload/iterators/ |
| A D | Makefile | 10 BPFTOOL_SRC := $(TOOLS_PATH)/bpf/bpftool 15 LIBBPF_SRC := $(TOOLS_PATH)/lib/bpf 46 iterators.lskel-%.h: $(OUTPUT)/%/iterators.bpf.o | $(BPFTOOL) 50 $(OUTPUT)/%/iterators.bpf.o: iterators.bpf.c $(BPFOBJ) | $(OUTPUT) 53 $(Q)$(CLANG) -g -O2 --target=bpf -m$* $(INCLUDES) \
|
| /linux/tools/testing/selftests/sched_ext/ |
| A D | Makefile | 17 BPFDIR := $(LIBDIR)/bpf 19 BPFTOOLDIR := $(TOOLSDIR)/bpf/bpftool 90 -I$(CURDIR)/include -I$(CURDIR)/include/bpf-compat \ 108 $(APIDIR)/linux/bpf.h \ 134 $(SCXOBJ_DIR)/%.bpf.o: %.bpf.c $(INCLUDE_DIR)/vmlinux.h | $(BPFOBJ) $(SCXOBJ_DIR) 136 $(Q)$(CLANG) $(BPF_CFLAGS) -target bpf -c $< -o $@ 138 $(INCLUDE_DIR)/%.bpf.skel.h: $(SCXOBJ_DIR)/%.bpf.o $(INCLUDE_DIR)/vmlinux.h $(BPFTOOL) | $(INCLUDE_… 145 $(Q)$(BPFTOOL) gen skeleton $(<:.o=.linked3.o) name $(subst .bpf.skel.h,,$(sched)) > $@ 146 …$(Q)$(BPFTOOL) gen subskeleton $(<:.o=.linked3.o) name $(subst .bpf.skel.h,,$(sched)) > $(@:.skel.… 160 all_test_bpfprogs := $(foreach prog,$(wildcard *.bpf.c),$(INCLUDE_DIR)/$(patsubst %.c,%.skel.h,$(pr…
|