diff options
author | Alexei Starovoitov <ast@plumgrid.com> | 2014-12-01 18:06:37 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-12-06 00:47:33 -0500 |
commit | 249b812d8005ec38e351ee763ceb85d56b155064 (patch) | |
tree | b81980d495f62e9a167ab75e132da0d387713179 /samples/bpf/bpf_helpers.h | |
parent | 03f4723ed7a52bd31da26eefe2cdde563ea0f468 (diff) |
samples: bpf: elf_bpf file loader
simple .o parser and loader using BPF syscall.
.o is a standard ELF generated by LLVM backend
It parses elf file compiled by llvm .c->.o
- parses 'maps' section and creates maps via BPF syscall
- parses 'license' section and passes it to syscall
- parses elf relocations for BPF maps and adjusts BPF_LD_IMM64 insns
by storing map_fd into insn->imm and marking such insns as BPF_PSEUDO_MAP_FD
- loads eBPF programs via BPF syscall
One ELF file can contain multiple BPF programs.
int load_bpf_file(char *path);
populates prog_fd[] and map_fd[] with FDs received from bpf syscall
bpf_helpers.h - helper functions available to eBPF programs written in C
Signed-off-by: Alexei Starovoitov <ast@plumgrid.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'samples/bpf/bpf_helpers.h')
-rw-r--r-- | samples/bpf/bpf_helpers.h | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/samples/bpf/bpf_helpers.h b/samples/bpf/bpf_helpers.h new file mode 100644 index 000000000000..ca0333146006 --- /dev/null +++ b/samples/bpf/bpf_helpers.h | |||
@@ -0,0 +1,40 @@ | |||
1 | #ifndef __BPF_HELPERS_H | ||
2 | #define __BPF_HELPERS_H | ||
3 | |||
4 | /* helper macro to place programs, maps, license in | ||
5 | * different sections in elf_bpf file. Section names | ||
6 | * are interpreted by elf_bpf loader | ||
7 | */ | ||
8 | #define SEC(NAME) __attribute__((section(NAME), used)) | ||
9 | |||
10 | /* helper functions called from eBPF programs written in C */ | ||
11 | static void *(*bpf_map_lookup_elem)(void *map, void *key) = | ||
12 | (void *) BPF_FUNC_map_lookup_elem; | ||
13 | static int (*bpf_map_update_elem)(void *map, void *key, void *value, | ||
14 | unsigned long long flags) = | ||
15 | (void *) BPF_FUNC_map_update_elem; | ||
16 | static int (*bpf_map_delete_elem)(void *map, void *key) = | ||
17 | (void *) BPF_FUNC_map_delete_elem; | ||
18 | |||
19 | /* llvm builtin functions that eBPF C program may use to | ||
20 | * emit BPF_LD_ABS and BPF_LD_IND instructions | ||
21 | */ | ||
22 | struct sk_buff; | ||
23 | unsigned long long load_byte(void *skb, | ||
24 | unsigned long long off) asm("llvm.bpf.load.byte"); | ||
25 | unsigned long long load_half(void *skb, | ||
26 | unsigned long long off) asm("llvm.bpf.load.half"); | ||
27 | unsigned long long load_word(void *skb, | ||
28 | unsigned long long off) asm("llvm.bpf.load.word"); | ||
29 | |||
30 | /* a helper structure used by eBPF C program | ||
31 | * to describe map attributes to elf_bpf loader | ||
32 | */ | ||
33 | struct bpf_map_def { | ||
34 | unsigned int type; | ||
35 | unsigned int key_size; | ||
36 | unsigned int value_size; | ||
37 | unsigned int max_entries; | ||
38 | }; | ||
39 | |||
40 | #endif | ||