diff options
author | Jesper Dangaard Brouer <brouer@redhat.com> | 2016-04-28 08:21:04 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-04-29 14:25:32 -0400 |
commit | 1c97566d515de2ef66873e30288b150f0154f3b3 (patch) | |
tree | fc261307afeec86f598abe3d87832c98fd19f4af /samples/bpf | |
parent | 7b01dd5793394ee2ef47c328b28c30f5c01107c9 (diff) |
samples/bpf: add a README file to get users started
Getting started with using examples in samples/bpf/ is not
straightforward. There are several dependencies, and specific
versions of these dependencies.
Just compiling the example tool is also slightly obscure, e.g. one
need to call make like:
make samples/bpf/
Do notice the "/" slash after the directory name.
Signed-off-by: Jesper Dangaard Brouer <brouer@redhat.com>
Acked-by: Naveen N. Rao <naveen.n.rao@linux.vnet.ibm.com>
Acked-by: Alexei Starovoitov <ast@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'samples/bpf')
-rw-r--r-- | samples/bpf/README.rst | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/samples/bpf/README.rst b/samples/bpf/README.rst new file mode 100644 index 000000000000..6f133f3f0075 --- /dev/null +++ b/samples/bpf/README.rst | |||
@@ -0,0 +1,63 @@ | |||
1 | eBPF sample programs | ||
2 | ==================== | ||
3 | |||
4 | This directory contains a mini eBPF library, test stubs, verifier | ||
5 | test-suite and examples for using eBPF. | ||
6 | |||
7 | Build dependencies | ||
8 | ================== | ||
9 | |||
10 | Compiling requires having installed: | ||
11 | * clang >= version 3.4.0 | ||
12 | * llvm >= version 3.7.1 | ||
13 | |||
14 | Note that LLVM's tool 'llc' must support target 'bpf', list version | ||
15 | and supported targets with command: ``llc --version`` | ||
16 | |||
17 | Kernel headers | ||
18 | -------------- | ||
19 | |||
20 | There are usually dependencies to header files of the current kernel. | ||
21 | To avoid installing devel kernel headers system wide, as a normal | ||
22 | user, simply call:: | ||
23 | |||
24 | make headers_install | ||
25 | |||
26 | This will creates a local "usr/include" directory in the git/build top | ||
27 | level directory, that the make system automatically pickup first. | ||
28 | |||
29 | Compiling | ||
30 | ========= | ||
31 | |||
32 | For building the BPF samples, issue the below command from the kernel | ||
33 | top level directory:: | ||
34 | |||
35 | make samples/bpf/ | ||
36 | |||
37 | Do notice the "/" slash after the directory name. | ||
38 | |||
39 | Manually compiling LLVM with 'bpf' support | ||
40 | ------------------------------------------ | ||
41 | |||
42 | Since version 3.7.0, LLVM adds a proper LLVM backend target for the | ||
43 | BPF bytecode architecture. | ||
44 | |||
45 | By default llvm will build all non-experimental backends including bpf. | ||
46 | To generate a smaller llc binary one can use:: | ||
47 | |||
48 | -DLLVM_TARGETS_TO_BUILD="BPF" | ||
49 | |||
50 | Quick sniplet for manually compiling LLVM and clang | ||
51 | (build dependencies are cmake and gcc-c++):: | ||
52 | |||
53 | $ git clone http://llvm.org/git/llvm.git | ||
54 | $ cd llvm/tools | ||
55 | $ git clone --depth 1 http://llvm.org/git/clang.git | ||
56 | $ cd ..; mkdir build; cd build | ||
57 | $ cmake .. -DLLVM_TARGETS_TO_BUILD="BPF;X86" | ||
58 | $ make -j $(getconf _NPROCESSORS_ONLN) | ||
59 | |||
60 | It is also possible to point make to the newly compiled 'llc' command | ||
61 | via redefining LLC on the make command line:: | ||
62 | |||
63 | make samples/bpf/ LLC=~/git/llvm/build/bin/llc | ||