blob: b577e2cbe9b2d540910cf782da40cb8f92590c53 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
/* SPDX-License-Identifier: BSD-3-Clause
* Copyright(c) 2018 Intel Corporation
*/
#ifndef _BPF_H_
#define _BPF_H_
#include <rte_bpf.h>
#include <sys/mman.h>
#ifdef __cplusplus
extern "C" {
#endif
#define MAX_BPF_STACK_SIZE 0x200
struct rte_bpf {
struct rte_bpf_prm prm;
struct rte_bpf_jit jit;
size_t sz;
uint32_t stack_sz;
};
extern int bpf_validate(struct rte_bpf *bpf);
extern int bpf_jit(struct rte_bpf *bpf);
#ifdef RTE_ARCH_X86_64
extern int bpf_jit_x86(struct rte_bpf *);
#endif
extern int rte_bpf_logtype;
#define RTE_BPF_LOG(lvl, fmt, args...) \
rte_log(RTE_LOG_## lvl, rte_bpf_logtype, fmt, ##args)
static inline size_t
bpf_size(uint32_t bpf_op_sz)
{
if (bpf_op_sz == BPF_B)
return sizeof(uint8_t);
else if (bpf_op_sz == BPF_H)
return sizeof(uint16_t);
else if (bpf_op_sz == BPF_W)
return sizeof(uint32_t);
else if (bpf_op_sz == EBPF_DW)
return sizeof(uint64_t);
return 0;
}
#ifdef __cplusplus
}
#endif
#endif /* _BPF_H_ */
|