|
@@ -0,0 +1,66 @@
|
|
|
+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
|