-
Notifications
You must be signed in to change notification settings - Fork 448
/
Copy pathebpfProgram.h
116 lines (99 loc) · 4.15 KB
/
ebpfProgram.h
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/*
Copyright 2013-present Barefoot Networks, Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
#ifndef BACKENDS_EBPF_EBPFPROGRAM_H_
#define BACKENDS_EBPF_EBPFPROGRAM_H_
#include "codeGen.h"
#include "ebpfModel.h"
#include "ebpfObject.h"
#include "ebpfOptions.h"
#include "frontends/common/options.h"
#include "frontends/p4/evaluator/evaluator.h"
#include "frontends/p4/typeMap.h"
#include "ir/ir.h"
#include "target.h"
namespace P4::EBPF {
class EBPFProgram;
class EBPFParser;
class EBPFControl;
class EBPFDeparser;
class EBPFTable;
class EBPFType;
class EBPFProgram : public EBPFObject {
public:
// The builder->target defines either TC or XDP target,
// while for PSA-eBPF we may use both of them interchangeably.
// This field stores the Target object that is unique per eBPF program (pipeline).
const Target *progTarget;
const EbpfOptions &options;
const IR::P4Program *program;
const IR::ToplevelBlock *toplevel;
P4::ReferenceMap *refMap;
P4::TypeMap *typeMap;
EBPFParser *parser;
EBPFControl *control;
EBPFModel &model;
/// Deparser may be NULL if not supported (e.g. ebpfFilter package).
EBPFDeparser *deparser;
cstring endLabel, offsetVar, lengthVar, headerStartVar;
cstring zeroKey, functionName, errorVar;
cstring packetStartVar, packetEndVar, byteVar;
cstring errorEnum;
cstring license = "GPL"_cs; /// TODO: this should be a compiler option probably
cstring arrayIndexType = "u32"_cs;
virtual bool build(); /// return 'true' on success
EBPFProgram(const EbpfOptions &options, const IR::P4Program *program, P4::ReferenceMap *refMap,
P4::TypeMap *typeMap, const IR::ToplevelBlock *toplevel)
: progTarget(nullptr),
options(options),
program(program),
toplevel(toplevel),
refMap(refMap),
typeMap(typeMap),
parser(nullptr),
control(nullptr),
model(EBPFModel::instance),
deparser(nullptr) {
// NB: offsetVar not used in eBPF backend - uBPF and TC only
offsetVar = EBPFModel::reserved("packetOffsetInBits"_cs);
zeroKey = EBPFModel::reserved("zero"_cs);
functionName = EBPFModel::reserved("filter"_cs);
errorVar = EBPFModel::reserved("errorCode"_cs);
packetStartVar = EBPFModel::reserved("packetStart"_cs);
packetEndVar = EBPFModel::reserved("packetEnd"_cs);
headerStartVar = EBPFModel::reserved("headerStart"_cs);
lengthVar = EBPFModel::reserved("pkt_len"_cs);
byteVar = EBPFModel::reserved("byte"_cs);
endLabel = EBPFModel::reserved("end"_cs);
errorEnum = EBPFModel::reserved("errorCodes"_cs);
}
protected:
virtual void emitPreamble(CodeBuilder *builder);
virtual void emitTypes(CodeBuilder *builder);
virtual void emitHeaderInstances(CodeBuilder *builder);
virtual void emitLocalVariables(CodeBuilder *builder);
virtual void emitPipeline(CodeBuilder *builder);
/// Checks whether a method name is considered to be part of the standard library, e.g., defined
/// in core.p4 or ebpf_model.p4.
/// TODO: Should we also distinguish overloaded methods?
virtual bool isLibraryMethod(cstring methodName);
public:
virtual void emitCommonPreamble(CodeBuilder *builder);
virtual void emitGeneratedComment(CodeBuilder *builder);
virtual void emitH(CodeBuilder *builder,
const std::filesystem::path &headerFile); // emits C headers
virtual void emitC(CodeBuilder *builder,
const std::filesystem::path &headerFile); // emits C program
DECLARE_TYPEINFO(EBPFProgram, EBPFObject);
};
} // namespace P4::EBPF
#endif /* BACKENDS_EBPF_EBPFPROGRAM_H_ */