P4C
The P4 Compiler
Loading...
Searching...
No Matches
p4tools/modules/testgen/targets/tofino/target.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_TARGET_H_
21#define BACKENDS_P4TOOLS_MODULES_TESTGEN_TARGETS_TOFINO_TARGET_H_
22
23#include <string>
24
25#include <boost/filesystem.hpp>
26
27#include "ir/ir.h"
28#include "ir/solver.h"
29
30#include "backends/p4tools/modules/testgen/core/program_info.h"
31#include "backends/p4tools/modules/testgen/core/symbolic_executor/symbolic_executor.h"
32#include "backends/p4tools/modules/testgen/core/target.h"
33#include "backends/p4tools/modules/testgen/lib/execution_state.h"
34#include "backends/p4tools/modules/testgen/targets/tofino/test_backend.h"
35#include "backends/p4tools/modules/testgen/targets/tofino/tofino/cmd_stepper.h"
36#include "backends/p4tools/modules/testgen/targets/tofino/tofino/expr_stepper.h"
37#include "backends/p4tools/modules/testgen/targets/tofino/tofino/program_info.h"
38#include "backends/p4tools/modules/testgen/targets/tofino/tofino2/cmd_stepper.h"
39#include "backends/p4tools/modules/testgen/targets/tofino/tofino2/expr_stepper.h"
40#include "backends/p4tools/modules/testgen/targets/tofino/tofino2/program_info.h"
41#if HAVE_FLATROCK_TARGET
42#include "backends/p4tools/modules/testgen/targets/tofino/tofino5/cmd_stepper.h"
43#include "backends/p4tools/modules/testgen/targets/tofino/tofino5/expr_stepper.h"
44#endif
45
46namespace P4::P4Tools::P4Testgen::Tofino {
47
48class AbstractTofinoProgramInfo : public ProgramInfo {
49 public:
50 ~AbstractTofinoProgramInfo() override = default;
51};
52
53class AbstractTofinoTestgenTarget : public TestgenTarget {
54 protected:
56 const TestBackendConfiguration &testBackendConfiguration,
57 SymbolicExecutor &symbex) const override;
58
59 explicit AbstractTofinoTestgenTarget(const std::string &deviceName,
60 const std::string &archName);
61
62 [[nodiscard]] MidEnd mkMidEnd(const CompilerOptions &options) const override;
63
64 [[nodiscard]] P4::FrontEnd mkFrontEnd() const override;
65
67 const IR::P4Program *program) const override;
68};
69
70class Tofino_TnaTestgenTarget : public AbstractTofinoTestgenTarget {
71 public:
73 static void make();
74
75 protected:
77 const CompilerResult &compilerResult,
78 const IR::Declaration_Instance *mainDecl) const override;
79
81 const ProgramInfo &programInfo) const override;
82
84 const ProgramInfo &programInfo) const override;
85
86 private:
87 Tofino_TnaTestgenTarget();
88};
89
90class JBay_T2naTestgenTarget : public AbstractTofinoTestgenTarget {
91 public:
93 static void make();
94
95 protected:
97 const CompilerResult &compilerResult,
98 const IR::Declaration_Instance *mainDecl) const override;
99
101 const ProgramInfo &programInfo) const override;
102
104 const ProgramInfo &programInfo) const override;
105
106 private:
107 JBay_T2naTestgenTarget();
108};
109
110} // namespace P4::P4Tools::P4Testgen::Tofino
111
112#endif /* BACKENDS_P4TOOLS_MODULES_TESTGEN_TARGETS_TOFINO_TARGET_H_ */
Provides a higher-level interface for an SMT solver.
Definition solver.h:24
Definition frontends/common/options.h:30
Definition frontends/p4/frontend.h:78
Definition common/compiler/compiler_result.h:14
Definition p4tools/common/compiler/midend.h:24
Represents state of execution after having reached a program point.
Definition execution_state.h:34
Stores target-specific information about a P4 program.
Definition core/program_info.h:21
Definition symbolic_executor.h:21
Definition p4tools/modules/testgen/targets/tofino/target.h:48
CompilerResultOrError runCompilerImpl(const CompilerOptions &options, const IR::P4Program *program) const override
Definition p4tools/modules/testgen/targets/tofino/target.cpp:90
P4::FrontEnd mkFrontEnd() const override
A factory method for providing a target-specific front end implementation.
Definition p4tools/modules/testgen/targets/tofino/target.cpp:65
MidEnd mkMidEnd(const CompilerOptions &options) const override
A factory method for providing a target-specific mid end implementation.
Definition p4tools/modules/testgen/targets/tofino/target.cpp:71
TofinoTestBackend * getTestBackendImpl(const ProgramInfo &programInfo, const TestBackendConfiguration &testBackendConfiguration, SymbolicExecutor &symbex) const override
Definition p4tools/modules/testgen/targets/tofino/target.cpp:58
JBayExprStepper * getExprStepperImpl(ExecutionState &state, AbstractSolver &solver, const ProgramInfo &programInfo) const override
Definition p4tools/modules/testgen/targets/tofino/target.cpp:300
JBayCmdStepper * getCmdStepperImpl(ExecutionState &state, AbstractSolver &solver, const ProgramInfo &programInfo) const override
Definition p4tools/modules/testgen/targets/tofino/target.cpp:294
static void make()
Registers this target.
Definition p4tools/modules/testgen/targets/tofino/target.cpp:223
const JBayProgramInfo * produceProgramInfoImpl(const CompilerResult &compilerResult, const IR::Declaration_Instance *mainDecl) const override
Definition p4tools/modules/testgen/targets/tofino/target.cpp:230
Definition targets/tofino/tofino2/cmd_stepper.h:38
Definition targets/tofino/tofino2/expr_stepper.h:33
Definition targets/tofino/tofino2/program_info.h:35
Definition targets/tofino/tofino/expr_stepper.h:33
static void make()
Registers this target.
Definition p4tools/modules/testgen/targets/tofino/target.cpp:142
Tofino1ExprStepper * getExprStepperImpl(ExecutionState &state, AbstractSolver &solver, const ProgramInfo &programInfo) const override
Definition p4tools/modules/testgen/targets/tofino/target.cpp:212
const TofinoProgramInfo * produceProgramInfoImpl(const CompilerResult &compilerResult, const IR::Declaration_Instance *mainDecl) const override
Definition p4tools/modules/testgen/targets/tofino/target.cpp:149
TofinoCmdStepper * getCmdStepperImpl(ExecutionState &state, AbstractSolver &solver, const ProgramInfo &programInfo) const override
Definition p4tools/modules/testgen/targets/tofino/target.cpp:206
Definition targets/tofino/tofino/cmd_stepper.h:39
Definition targets/tofino/tofino/program_info.h:35
Definition targets/tofino/test_backend.h:43
std::optional< std::reference_wrapper< const CompilerResult > > CompilerResultOrError
Definition common/compiler/compiler_result.h:31
Definition phv/solver/action_constraint_solver.cpp:33
Definition test_backend_configuration.h:16