| eBPF sample programs | 
 | ==================== | 
 |  | 
 | This directory contains a mini eBPF library, test stubs, verifier | 
 | test-suite and examples for using eBPF. | 
 |  | 
 | 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 |