-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathzodiacfx-Model.h
93 lines (76 loc) · 2.93 KB
/
zodiacfx-Model.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
/*
Copyright 2019 Northbound Networks.
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_ZODIACFX_ZODIACFXMODEL_H_
#define _BACKENDS_ZODIACFX_ZODIACFXMODEL_H_
#include "frontends/common/model.h"
#include "frontends/p4/coreLibrary.h"
#include "ir/ir.h"
#include "lib/cstring.h"
namespace ZODIACFX {
struct TableImpl_Model : public ::Model::Extern_Model {
explicit TableImpl_Model(cstring name) :
Extern_Model(name),
size("size") {}
::Model::Elem size;
};
struct Switch_Model : public ::Model::Elem {
Switch_Model() : Elem("zodiacfx"),
zfx_parser("prs"), zfx_switch("swtch"), zfx_deparser("deprs") {}
::Model::Elem zfx_parser;
::Model::Elem zfx_switch;
::Model::Elem zfx_deparser;
};
struct InputMetadataModel : public ::Model::Type_Model {
InputMetadataModel() : ::Model::Type_Model("zodiacfx_input"),
inputPort("input_port"), inputPortType(IR::Type_Bits::get(32))
{}
::Model::Elem inputPort;
const IR::Type* inputPortType;
};
struct OutputMetadataModel : public ::Model::Type_Model {
OutputMetadataModel() : ::Model::Type_Model("zodiacfx_output"),
outputPort("output_port"), outputPortType(IR::Type_Bits::get(32)),
output_action("output_action")
{}
::Model::Elem outputPort;
const IR::Type* outputPortType;
::Model::Elem output_action;
};
// Keep this in sync with zodiacfx_model.p4
class ZODIACFXModel : public ::Model::Model {
protected:
ZODIACFXModel() : Model("0.1"),
hash_table("hash_table"),
tableImplProperty("implementation"),
CPacketName("p_uc_data"),
packet("packet", P4::P4CoreLibrary::instance.packetIn, 0),
inputMetadataModel(), outputMetadataModel(),
zfx_switch(), counterIndexType("uint32_t"), counterValueType("uint32_t")
{}
public:
static ZODIACFXModel instance;
static cstring reservedPrefix;
TableImpl_Model hash_table;
::Model::Elem tableImplProperty;
::Model::Elem CPacketName;
::Model::Param_Model packet;
InputMetadataModel inputMetadataModel;
OutputMetadataModel outputMetadataModel;
Switch_Model zfx_switch;
cstring counterIndexType;
cstring counterValueType;
static cstring reserved(cstring name)
{ return reservedPrefix + name; }
};
} // namespace ZODIACFX
#endif /* _BACKENDS_ZODIACFX_ZODIACFXMODEL_H_ */