Alexei Starovoitov | 249b812 | 2014-12-01 15:06:37 -0800 | [diff] [blame] | 1 | #ifndef __BPF_LOAD_H |
| 2 | #define __BPF_LOAD_H |
| 3 | |
Joe Stringer | d40fc18 | 2016-12-14 14:43:38 -0800 | [diff] [blame] | 4 | #include "libbpf.h" |
| 5 | |
Alexei Starovoitov | 249b812 | 2014-12-01 15:06:37 -0800 | [diff] [blame] | 6 | #define MAX_MAPS 32 |
| 7 | #define MAX_PROGS 32 |
| 8 | |
Martin KaFai Lau | 9fd63d0 | 2017-04-14 10:30:28 -0700 | [diff] [blame] | 9 | struct bpf_map_def { |
| 10 | unsigned int type; |
| 11 | unsigned int key_size; |
| 12 | unsigned int value_size; |
| 13 | unsigned int max_entries; |
| 14 | unsigned int map_flags; |
| 15 | unsigned int inner_map_idx; |
| 16 | }; |
| 17 | |
| 18 | typedef void (*fixup_map_cb)(struct bpf_map_def *map, const char *map_name, |
| 19 | int idx); |
| 20 | |
Alexei Starovoitov | 249b812 | 2014-12-01 15:06:37 -0800 | [diff] [blame] | 21 | extern int map_fd[MAX_MAPS]; |
| 22 | extern int prog_fd[MAX_PROGS]; |
Alexei Starovoitov | b896c4f | 2015-03-25 12:49:23 -0700 | [diff] [blame] | 23 | extern int event_fd[MAX_PROGS]; |
Joe Stringer | d40fc18 | 2016-12-14 14:43:38 -0800 | [diff] [blame] | 24 | extern char bpf_log_buf[BPF_LOG_BUF_SIZE]; |
David Ahern | 4f2e7ae | 2016-12-01 08:48:07 -0800 | [diff] [blame] | 25 | extern int prog_cnt; |
Alexei Starovoitov | 249b812 | 2014-12-01 15:06:37 -0800 | [diff] [blame] | 26 | |
| 27 | /* parses elf file compiled by llvm .c->.o |
| 28 | * . parses 'maps' section and creates maps via BPF syscall |
| 29 | * . parses 'license' section and passes it to syscall |
| 30 | * . parses elf relocations for BPF maps and adjusts BPF_LD_IMM64 insns by |
| 31 | * storing map_fd into insn->imm and marking such insns as BPF_PSEUDO_MAP_FD |
| 32 | * . loads eBPF programs via BPF syscall |
| 33 | * |
| 34 | * One ELF file can contain multiple BPF programs which will be loaded |
| 35 | * and their FDs stored stored in prog_fd array |
| 36 | * |
| 37 | * returns zero on success |
| 38 | */ |
| 39 | int load_bpf_file(char *path); |
Martin KaFai Lau | 9fd63d0 | 2017-04-14 10:30:28 -0700 | [diff] [blame] | 40 | int load_bpf_file_fixup_map(const char *path, fixup_map_cb fixup_map); |
Alexei Starovoitov | 249b812 | 2014-12-01 15:06:37 -0800 | [diff] [blame] | 41 | |
Alexei Starovoitov | b896c4f | 2015-03-25 12:49:23 -0700 | [diff] [blame] | 42 | void read_trace_pipe(void); |
Alexei Starovoitov | 3622e7e | 2016-03-07 21:57:19 -0800 | [diff] [blame] | 43 | struct ksym { |
| 44 | long addr; |
| 45 | char *name; |
| 46 | }; |
Alexei Starovoitov | b896c4f | 2015-03-25 12:49:23 -0700 | [diff] [blame] | 47 | |
Alexei Starovoitov | 3622e7e | 2016-03-07 21:57:19 -0800 | [diff] [blame] | 48 | int load_kallsyms(void); |
| 49 | struct ksym *ksym_search(long key); |
Jesper Dangaard Brouer | 6387d01 | 2017-05-01 11:26:15 +0200 | [diff] [blame^] | 50 | int set_link_xdp_fd(int ifindex, int fd, __u32 flags); |
Alexei Starovoitov | 249b812 | 2014-12-01 15:06:37 -0800 | [diff] [blame] | 51 | #endif |