P4C
The P4 Compiler
Loading...
Searching...
No Matches
targets/tofino/test_spec.h
1/*******************************************************************************
2 * Copyright (C) 2024 Intel Corporation
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing,
11 * software distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions
14 * and limitations under the License.
15 *
16 *
17 * SPDX-License-Identifier: Apache-2.0
18 ******************************************************************************/
19
20#ifndef BACKENDS_P4TOOLS_MODULES_TESTGEN_TARGETS_TOFINO_TEST_SPEC_H_
21#define BACKENDS_P4TOOLS_MODULES_TESTGEN_TARGETS_TOFINO_TEST_SPEC_H_
22
23#include <cstddef>
24#include <utility>
25#include <vector>
26
27#include "backends/p4tools/common/lib/model.h"
28#include "ir/ir.h"
29#include "lib/cstring.h"
30
31#include "backends/p4tools/modules/testgen/lib/test_spec.h"
32
33namespace P4::P4Tools::P4Testgen::Tofino {
34
35/* =========================================================================================
36 * IndexExpression
37 * ========================================================================================= */
41class IndexExpression : public TestObject {
42 private:
44 const IR::Expression *index;
45
47 const IR::Expression *value;
48
49 public:
50 explicit IndexExpression(const IR::Expression *index, const IR::Expression *value);
51
54 [[nodiscard]] const IR::Constant *getEvaluatedIndex() const;
55
58 [[nodiscard]] const IR::Constant *getEvaluatedValue() const;
59
61 [[nodiscard]] const IR::Expression *getIndex() const;
62
64 [[nodiscard]] const IR::Expression *getValue() const;
65
66 [[nodiscard]] const IndexExpression *evaluate(const Model &model,
67 bool doComplete) const override;
68
69 [[nodiscard]] cstring getObjectName() const override;
70
71 DECLARE_TYPEINFO(IndexExpression, TestObject);
72};
73
74/* =========================================================================================
75 * IndexMap
76 * ========================================================================================= */
78class IndexMap : public TestObject {
79 protected:
81 const IR::Expression *initialValue;
82
84 std::vector<IndexExpression> indexConditions;
85
86 public:
87 explicit IndexMap(const IR::Expression *initialValue);
88
90 void writeToIndex(const IR::Expression *index, const IR::Expression *value);
91
93 [[nodiscard]] const IR::Expression *getInitialValue() const;
94
97 [[nodiscard]] const IR::Expression *getValueAtIndex(const IR::Expression *index) const;
98
101 [[nodiscard]] const IR::Expression *getEvaluatedInitialValue() const;
102
104 [[nodiscard]] std::map<big_int, std::pair<int, const IR::Constant *>> unravelMap() const;
105
106 DECLARE_TYPEINFO(IndexMap, TestObject);
107};
108
109/* =========================================================================================
110 * TofinoRegisterValue
111 * ========================================================================================= */
120class TofinoRegisterValue : public IndexMap {
121 private:
123 const IR::Declaration_Instance *decl;
124
126 const IR::Expression *initialIndex;
127
128 public:
129 explicit TofinoRegisterValue(const IR::Declaration_Instance *decl,
130 const IR::Expression *initialValue,
131 const IR::Expression *initialIndex);
132
133 [[nodiscard]] cstring getObjectName() const override;
134
135 [[nodiscard]] const TofinoRegisterValue *evaluate(const Model &model,
136 bool doComplete) const override;
137
139 [[nodiscard]] const IR::Declaration_Instance *getRegisterDeclaration() const;
140
142 [[nodiscard]] const IR::Constant *getEvaluatedInitialIndex() const;
143
144 DECLARE_TYPEINFO(TofinoRegisterValue, TestObject);
145};
146
147/* =========================================================================================
148 * TofinoDirectRegisterValue
149 * ========================================================================================= */
151class TofinoDirectRegisterValue : public TestObject {
152 private:
154 const IR::Expression *initialValue;
155
157 const IR::Declaration_Instance *decl;
158
160 const IR::P4Table *table;
161
162 public:
163 explicit TofinoDirectRegisterValue(const IR::Declaration_Instance *decl,
164 const IR::Expression *initialValue,
165 const IR::P4Table *table);
166
167 [[nodiscard]] cstring getObjectName() const override;
168
169 [[nodiscard]] const TofinoDirectRegisterValue *evaluate(const Model &model,
170 bool doComplete) const override;
171
173 [[nodiscard]] const IR::Declaration_Instance *getRegisterDeclaration() const;
174
176 [[nodiscard]] const IR::Expression *getInitialValue() const;
177
179 [[nodiscard]] const IR::P4Table *getRegisterTable() const;
180
182 [[nodiscard]] const IR::Expression *getEvaluatedInitialValue() const;
183
184 DECLARE_TYPEINFO(TofinoDirectRegisterValue, TestObject);
185};
186
187/* =========================================================================================
188 * TofinoRegisterParam
189 * ========================================================================================= */
191class TofinoRegisterParam : public TestObject {
192 private:
194 const IR::Declaration_Instance *decl;
195
197 const IR::Expression *initialValue;
198
199 public:
200 explicit TofinoRegisterParam(const IR::Declaration_Instance *decl,
201 const IR::Expression *initialValue);
202
203 [[nodiscard]] cstring getObjectName() const override;
204
205 [[nodiscard]] const TofinoRegisterParam *evaluate(const Model &model,
206 bool doComplete) const override;
208 [[nodiscard]] const IR::Expression *getInitialValue() const;
209
211 [[nodiscard]] const IR::Declaration_Instance *getRegisterParamDeclaration() const;
212
214 [[nodiscard]] const IR::Constant *getEvaluatedInitialValue() const;
215
216 DECLARE_TYPEINFO(TofinoRegisterParam, TestObject);
217};
218
219/* =========================================================================================
220 * TofinoActionProfile
221 * ========================================================================================= */
222class TofinoActionProfile : public TestObject {
223 private:
225 std::vector<std::pair<cstring, std::vector<ActionArg>>> actions;
226
228 const IR::IDeclaration *profileDecl;
229
230 public:
231 explicit TofinoActionProfile(const IR::IDeclaration *profileDecl);
232
233 cstring getObjectName() const override;
234
236 const std::vector<std::pair<cstring, std::vector<ActionArg>>> *getActions() const;
237
239 const IR::IDeclaration *getProfileDecl() const;
240
242 size_t getActionMapSize() const;
243
245 void addToActionMap(cstring actionName, std::vector<ActionArg> actionArgs);
246
247 const TofinoActionProfile *evaluate(const Model &model, bool doComplete) const override;
248
249 DECLARE_TYPEINFO(TofinoActionProfile, TestObject);
250};
251
252/* =========================================================================================
253 * TofinoActionSelector
254 * ========================================================================================= */
255class TofinoActionSelector : public TestObject {
256 private:
258 const IR::IDeclaration *selectorDecl;
259
261 const TofinoActionProfile *actionProfile;
262
263 public:
264 explicit TofinoActionSelector(const IR::IDeclaration *selectorDecl,
265 const TofinoActionProfile *actionProfile);
266
267 cstring getObjectName() const override;
268
270 const IR::IDeclaration *getSelectorDecl() const;
271
274
275 const TofinoActionSelector *evaluate(const Model &model, bool doComplete) const override;
276
277 DECLARE_TYPEINFO(TofinoActionSelector, TestObject);
278};
279
280/* =========================================================================================
281 * Table Key Match Types
282 * ========================================================================================= */
283
284class Range : public TableMatch {
285 private:
287 const IR::Expression *low;
288
290 const IR::Expression *high;
291
292 public:
293 explicit Range(const IR::KeyElement *key, const IR::Expression *low,
294 const IR::Expression *high);
295
296 const Range *evaluate(const Model &model, bool doComplete) const override;
297
298 cstring getObjectName() const override;
299
302 const IR::Constant *getEvaluatedLow() const;
303
306 const IR::Constant *getEvaluatedHigh() const;
307
308 DECLARE_TYPEINFO(Range, TableMatch);
309};
310
311} // namespace P4::P4Tools::P4Testgen::Tofino
312
313#endif /* BACKENDS_P4TOOLS_MODULES_TESTGEN_TARGETS_TOFINO_TEST_SPEC_H_ */
The Declaration interface, representing objects with names.
Definition declaration.h:26
Definition backends/p4tools/common/lib/model.h:18
const IR::Expression * getIndex() const
Definition targets/tofino/test_spec.cpp:45
const IR::Constant * getEvaluatedIndex() const
Definition targets/tofino/test_spec.cpp:38
const IndexExpression * evaluate(const Model &model, bool doComplete) const override
Definition targets/tofino/test_spec.cpp:51
const IR::Constant * getEvaluatedValue() const
Definition targets/tofino/test_spec.cpp:31
cstring getObjectName() const override
Definition targets/tofino/test_spec.cpp:49
const IR::Expression * getValue() const
Definition targets/tofino/test_spec.cpp:47
const IR::Expression * getValueAtIndex(const IR::Expression *index) const
Definition targets/tofino/test_spec.cpp:81
const IR::Expression * getInitialValue() const
Definition targets/tofino/test_spec.cpp:79
const IR::Expression * getEvaluatedInitialValue() const
Definition targets/tofino/test_spec.cpp:92
std::vector< IndexExpression > indexConditions
Each element is an API name paired with a match rule.
Definition targets/tofino/test_spec.h:84
const IR::Expression * initialValue
A new IndexMap always requires an initial value. This can be a constant or taint.
Definition targets/tofino/test_spec.h:81
void writeToIndex(const IR::Expression *index, const IR::Expression *value)
Write.
Definition targets/tofino/test_spec.cpp:75
std::map< big_int, std::pair< int, const IR::Constant * > > unravelMap() const
Return the "writes" to this index map as a.
Definition targets/tofino/test_spec.cpp:57
cstring getObjectName() const override
Definition targets/tofino/test_spec.cpp:293
const IR::Constant * getEvaluatedLow() const
Definition targets/tofino/test_spec.cpp:269
const IR::Constant * getEvaluatedHigh() const
Definition targets/tofino/test_spec.cpp:278
const Range * evaluate(const Model &model, bool doComplete) const override
Definition targets/tofino/test_spec.cpp:287
Definition targets/tofino/test_spec.h:222
const IR::IDeclaration * getProfileDecl() const
Definition targets/tofino/test_spec.cpp:220
size_t getActionMapSize() const
Definition targets/tofino/test_spec.cpp:225
cstring getObjectName() const override
Definition targets/tofino/test_spec.cpp:218
const std::vector< std::pair< cstring, std::vector< ActionArg > > > * getActions() const
Definition targets/tofino/test_spec.cpp:210
const TofinoActionProfile * evaluate(const Model &model, bool doComplete) const override
Definition targets/tofino/test_spec.cpp:227
void addToActionMap(cstring actionName, std::vector< ActionArg > actionArgs)
Add an action (its name) and the arguments to the action map of this profile.
Definition targets/tofino/test_spec.cpp:222
cstring getObjectName() const override
Definition targets/tofino/test_spec.cpp:246
const TofinoActionSelector * evaluate(const Model &model, bool doComplete) const override
Definition targets/tofino/test_spec.cpp:256
const TofinoActionProfile * getActionProfile() const
Definition targets/tofino/test_spec.cpp:250
const IR::IDeclaration * getSelectorDecl() const
Definition targets/tofino/test_spec.cpp:248
const IR::Expression * getEvaluatedInitialValue() const
Definition targets/tofino/test_spec.cpp:166
const IR::P4Table * getRegisterTable() const
Definition targets/tofino/test_spec.cpp:151
const IR::Expression * getInitialValue() const
Definition targets/tofino/test_spec.cpp:164
const TofinoDirectRegisterValue * evaluate(const Model &model, bool doComplete) const override
Definition targets/tofino/test_spec.cpp:153
cstring getObjectName() const override
Definition targets/tofino/test_spec.cpp:145
const IR::Declaration_Instance * getRegisterDeclaration() const
Definition targets/tofino/test_spec.cpp:147
const TofinoRegisterParam * evaluate(const Model &model, bool doComplete) const override
Definition targets/tofino/test_spec.cpp:188
const IR::Expression * getInitialValue() const
Definition targets/tofino/test_spec.cpp:197
const IR::Declaration_Instance * getRegisterParamDeclaration() const
Definition targets/tofino/test_spec.cpp:193
cstring getObjectName() const override
Definition targets/tofino/test_spec.cpp:186
const IR::Constant * getEvaluatedInitialValue() const
Definition targets/tofino/test_spec.cpp:199
const IR::Constant * getEvaluatedInitialIndex() const
Definition targets/tofino/test_spec.cpp:129
const IR::Declaration_Instance * getRegisterDeclaration() const
Definition targets/tofino/test_spec.cpp:115
const TofinoRegisterValue * evaluate(const Model &model, bool doComplete) const override
Definition targets/tofino/test_spec.cpp:117
cstring getObjectName() const override
Definition targets/tofino/test_spec.cpp:113
Definition cstring.h:85