forked from mirrors/linux
		
	|  dce45af5c2 This has been a smaller cycle than normal. One new driver was accepted,
 which is unusual, and at least one more driver remains in review on the
 list.
 
 - Driver fixes for hns, hfi1, nes, rxe, i40iw, mlx5, cxgb4, vmw_pvrdma
 
 - Many patches from MatthewW converting radix tree and IDR users to use
   xarray
 
 - Introduction of tracepoints to the MAD layer
 
 - Build large SGLs at the start for DMA mapping and get the driver to
   split them
 
 - Generally clean SGL handling code throughout the subsystem
 
 - Support for restricting RDMA devices to net namespaces for containers
 
 - Progress to remove object allocation boilerplate code from drivers
 
 - Change in how the mlx5 driver shows representor ports linked to VFs
 
 - mlx5 uapi feature to access the on chip SW ICM memory
 
 - Add a new driver for 'EFA'. This is HW that supports user space packet
   processing through QPs in Amazon's cloud
 -----BEGIN PGP SIGNATURE-----
 
 iQIzBAABCgAdFiEEfB7FMLh+8QxL+6i3OG33FX4gmxoFAlzTIU0ACgkQOG33FX4g
 mxrGKQ/8CqpyvuCyZDW5ovO4DI4YlzYSPXehWlwxA4CWhU1AYTujutnNOdZdngnz
 atTthOlJpZWJV26orvvzwIOi4qX/5UjLXEY3HYdn07JP1Z4iT7E3P4W2sdU3vdl3
 j8bU7xM7ZWmnGxrBZ6yQlVRadEhB8+HJIZWMw+wx66cIPnvU+g9NgwouH67HEEQ3
 PU8OCtGBwNNR508WPiZhjqMDfi/3BED4BfCihFhMbZEgFgObjRgtCV0M33SSXKcR
 IO2FGNVuDAUBlND3vU9guW1+M77xE6p1GvzkIgdCp6qTc724NuO5F2ngrpHKRyZT
 CxvBhAJI6tAZmjBVnmgVJex7rA8p+y/8M/2WD6GE3XSO89XVOkzNBiO2iTMeoxXr
 +CX6VvP2BWwCArxsfKMgW3j0h/WVE9w8Ciej1628m1NvvKEV4AGIJC1g93lIJkRN
 i3RkJ5PkIrdBrTEdKwDu1FdXQHaO7kGgKvwzJ7wBFhso8BRMrMfdULiMbaXs2Bw1
 WdL5zoSe/bLUpPZxcT9IjXRxY5qR0FpIOoo6925OmvyYe/oZo1zbitS5GGbvV90g
 tkq6Jb+aq8ZKtozwCo+oMcg9QPLYNibQsnkL3QirtURXWCG467xdgkaJLdF6s5Oh
 cp+YBqbR/8HNMG/KQlCfnNQKp1ci8mG3EdthQPhvdcZ4jtbqnSI=
 =TS64
 -----END PGP SIGNATURE-----
Merge tag 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/rdma/rdma
Pull rdma updates from Jason Gunthorpe:
 "This has been a smaller cycle than normal. One new driver was
  accepted, which is unusual, and at least one more driver remains in
  review on the list.
  Summary:
   - Driver fixes for hns, hfi1, nes, rxe, i40iw, mlx5, cxgb4,
     vmw_pvrdma
   - Many patches from MatthewW converting radix tree and IDR users to
     use xarray
   - Introduction of tracepoints to the MAD layer
   - Build large SGLs at the start for DMA mapping and get the driver to
     split them
   - Generally clean SGL handling code throughout the subsystem
   - Support for restricting RDMA devices to net namespaces for
     containers
   - Progress to remove object allocation boilerplate code from drivers
   - Change in how the mlx5 driver shows representor ports linked to VFs
   - mlx5 uapi feature to access the on chip SW ICM memory
   - Add a new driver for 'EFA'. This is HW that supports user space
     packet processing through QPs in Amazon's cloud"
* tag 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/rdma/rdma: (186 commits)
  RDMA/ipoib: Allow user space differentiate between valid dev_port
  IB/core, ipoib: Do not overreact to SM LID change event
  RDMA/device: Don't fire uevent before device is fully initialized
  lib/scatterlist: Remove leftover from sg_page_iter comment
  RDMA/efa: Add driver to Kconfig/Makefile
  RDMA/efa: Add the efa module
  RDMA/efa: Add EFA verbs implementation
  RDMA/efa: Add common command handlers
  RDMA/efa: Implement functions that submit and complete admin commands
  RDMA/efa: Add the ABI definitions
  RDMA/efa: Add the com service API definitions
  RDMA/efa: Add the efa_com.h file
  RDMA/efa: Add the efa.h header file
  RDMA/efa: Add EFA device definitions
  RDMA: Add EFA related definitions
  RDMA/umem: Remove hugetlb flag
  RDMA/bnxt_re: Use core helpers to get aligned DMA address
  RDMA/i40iw: Use core helpers to get aligned DMA address within a supported page size
  RDMA/verbs: Add a DMA iterator to return aligned contiguous memory blocks
  RDMA/umem: Add API to find best driver supported page size in an MR
  ... | ||
|---|---|---|
| .. | ||
| .gitignore | ||
| asm_goto_workaround.h | ||
| bpf_insn.h | ||
| bpf_load.c | ||
| bpf_load.h | ||
| cookie_uid_helper_example.c | ||
| cpustat_kern.c | ||
| cpustat_user.c | ||
| do_hbm_test.sh | ||
| fds_example.c | ||
| hash_func01.h | ||
| hbm.c | ||
| hbm.h | ||
| hbm_kern.h | ||
| hbm_out_kern.c | ||
| ibumad_kern.c | ||
| ibumad_user.c | ||
| lathist_kern.c | ||
| lathist_user.c | ||
| lwt_len_hist.sh | ||
| lwt_len_hist_kern.c | ||
| lwt_len_hist_user.c | ||
| Makefile | ||
| map_perf_test_kern.c | ||
| map_perf_test_user.c | ||
| offwaketime_kern.c | ||
| offwaketime_user.c | ||
| parse_ldabs.c | ||
| parse_simple.c | ||
| parse_varlen.c | ||
| README.rst | ||
| run_cookie_uid_helper_example.sh | ||
| sampleip_kern.c | ||
| sampleip_user.c | ||
| sock_example.c | ||
| sock_example.h | ||
| sock_flags_kern.c | ||
| sockex1_kern.c | ||
| sockex1_user.c | ||
| sockex2_kern.c | ||
| sockex2_user.c | ||
| sockex3_kern.c | ||
| sockex3_user.c | ||
| spintest_kern.c | ||
| spintest_user.c | ||
| syscall_nrs.c | ||
| syscall_tp_kern.c | ||
| syscall_tp_user.c | ||
| task_fd_query_kern.c | ||
| task_fd_query_user.c | ||
| tc_l2_redirect.sh | ||
| tc_l2_redirect_kern.c | ||
| tc_l2_redirect_user.c | ||
| tcbpf1_kern.c | ||
| tcp_basertt_kern.c | ||
| tcp_bpf.readme | ||
| tcp_bufs_kern.c | ||
| tcp_clamp_kern.c | ||
| tcp_cong_kern.c | ||
| tcp_iw_kern.c | ||
| tcp_rwnd_kern.c | ||
| tcp_synrto_kern.c | ||
| tcp_tos_reflect_kern.c | ||
| test_cgrp2_array_pin.c | ||
| test_cgrp2_attach.c | ||
| test_cgrp2_attach2.c | ||
| test_cgrp2_sock.c | ||
| test_cgrp2_sock.sh | ||
| test_cgrp2_sock2.c | ||
| test_cgrp2_sock2.sh | ||
| test_cgrp2_tc.sh | ||
| test_cgrp2_tc_kern.c | ||
| test_cls_bpf.sh | ||
| test_current_task_under_cgroup_kern.c | ||
| test_current_task_under_cgroup_user.c | ||
| test_ipip.sh | ||
| test_lru_dist.c | ||
| test_lwt_bpf.c | ||
| test_lwt_bpf.sh | ||
| test_map_in_map_kern.c | ||
| test_map_in_map_user.c | ||
| test_overhead_kprobe_kern.c | ||
| test_overhead_raw_tp_kern.c | ||
| test_overhead_tp_kern.c | ||
| test_overhead_user.c | ||
| test_override_return.sh | ||
| test_probe_write_user_kern.c | ||
| test_probe_write_user_user.c | ||
| trace_event_kern.c | ||
| trace_event_user.c | ||
| trace_output_kern.c | ||
| trace_output_user.c | ||
| tracex1_kern.c | ||
| tracex1_user.c | ||
| tracex2_kern.c | ||
| tracex2_user.c | ||
| tracex3_kern.c | ||
| tracex3_user.c | ||
| tracex4_kern.c | ||
| tracex4_user.c | ||
| tracex5_kern.c | ||
| tracex5_user.c | ||
| tracex6_kern.c | ||
| tracex6_user.c | ||
| tracex7_kern.c | ||
| tracex7_user.c | ||
| xdp1_kern.c | ||
| xdp1_user.c | ||
| xdp2_kern.c | ||
| xdp2skb_meta.sh | ||
| xdp2skb_meta_kern.c | ||
| xdp_adjust_tail_kern.c | ||
| xdp_adjust_tail_user.c | ||
| xdp_fwd_kern.c | ||
| xdp_fwd_user.c | ||
| xdp_monitor_kern.c | ||
| xdp_monitor_user.c | ||
| xdp_redirect_cpu_kern.c | ||
| xdp_redirect_cpu_user.c | ||
| xdp_redirect_kern.c | ||
| xdp_redirect_map_kern.c | ||
| xdp_redirect_map_user.c | ||
| xdp_redirect_user.c | ||
| xdp_router_ipv4_kern.c | ||
| xdp_router_ipv4_user.c | ||
| xdp_rxq_info_kern.c | ||
| xdp_rxq_info_user.c | ||
| xdp_sample_pkts_kern.c | ||
| xdp_sample_pkts_user.c | ||
| xdp_tx_iptunnel_common.h | ||
| xdp_tx_iptunnel_kern.c | ||
| xdp_tx_iptunnel_user.c | ||
| xdpsock_user.c | ||
eBPF sample programs ==================== This directory contains a test stubs, verifier test-suite and examples for using eBPF. The examples use libbpf from tools/lib/bpf. Build dependencies ================== Compiling requires having installed: * clang >= version 3.4.0 * llvm >= version 3.7.1 Note that LLVM's tool 'llc' must support target 'bpf', list version and supported targets with command: ``llc --version`` Kernel headers -------------- There are usually dependencies to header files of the current kernel. To avoid installing devel kernel headers system wide, as a normal user, simply call:: make headers_install This will creates a local "usr/include" directory in the git/build top level directory, that the make system automatically pickup first. Compiling ========= For building the BPF samples, issue the below command from the kernel top level directory:: make samples/bpf/ Do notice the "/" slash after the directory name. It is also possible to call make from this directory. This will just hide the the invocation of make as above with the appended "/". Manually compiling LLVM with 'bpf' support ------------------------------------------ Since version 3.7.0, LLVM adds a proper LLVM backend target for the BPF bytecode architecture. By default llvm will build all non-experimental backends including bpf. To generate a smaller llc binary one can use:: -DLLVM_TARGETS_TO_BUILD="BPF" Quick sniplet for manually compiling LLVM and clang (build dependencies are cmake and gcc-c++):: $ git clone http://llvm.org/git/llvm.git $ cd llvm/tools $ git clone --depth 1 http://llvm.org/git/clang.git $ cd ..; mkdir build; cd build $ cmake .. -DLLVM_TARGETS_TO_BUILD="BPF;X86" $ make -j $(getconf _NPROCESSORS_ONLN) It is also possible to point make to the newly compiled 'llc' or 'clang' command via redefining LLC or CLANG on the make command line:: make samples/bpf/ LLC=~/git/llvm/build/bin/llc CLANG=~/git/llvm/build/bin/clang Cross compiling samples ----------------------- In order to cross-compile, say for arm64 targets, export CROSS_COMPILE and ARCH environment variables before calling make. This will direct make to build samples for the cross target. export ARCH=arm64 export CROSS_COMPILE="aarch64-linux-gnu-" make samples/bpf/ LLC=~/git/llvm/build/bin/llc CLANG=~/git/llvm/build/bin/clang