20#ifndef BACKENDS_P4TOOLS_MODULES_TESTGEN_TARGETS_TOFINO_TARGET_H_
21#define BACKENDS_P4TOOLS_MODULES_TESTGEN_TARGETS_TOFINO_TARGET_H_
25#include <boost/filesystem.hpp>
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"
46namespace P4::P4Tools::P4Testgen::Tofino {
53class AbstractTofinoTestgenTarget :
public TestgenTarget {
59 explicit AbstractTofinoTestgenTarget(
const std::string &deviceName,
60 const std::string &archName);
67 const IR::P4Program *program)
const override;
70class Tofino_TnaTestgenTarget :
public AbstractTofinoTestgenTarget {
78 const IR::Declaration_Instance *mainDecl)
const override;
87 Tofino_TnaTestgenTarget();
90class JBay_T2naTestgenTarget :
public AbstractTofinoTestgenTarget {
98 const IR::Declaration_Instance *mainDecl)
const override;
107 JBay_T2naTestgenTarget();
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 phv/solver/action_constraint_solver.cpp:33