![]() |
P4C
The P4 Compiler
|
Represents the final state after execution. More...
#include <final_state.h>
Public Member Functions | |
FinalState (AbstractSolver &solver, const ExecutionState &finalState) | |
FinalState (AbstractSolver &solver, const ExecutionState &finalState, const Model &finalModel) | |
This constructor takes the input model as is and does not invoke processModel(). | |
std::optional< std::reference_wrapper< const FinalState > > | computeConcolicState (const ConcolicVariableMap &resolvedConcolicVariables) const |
const ExecutionState * | getExecutionState () const |
const Model & | getFinalModel () const |
AbstractSolver & | getSolver () const |
const std::vector< std::reference_wrapper< const TraceEvent > > * | getTraces () const |
const P4::Coverage::CoverageSet & | getVisited () const |
Represents the final state after execution.
P4Tools::P4Testgen::FinalState::FinalState | ( | AbstractSolver & | solver, |
const ExecutionState & | finalState ) |
This constructor invokes processModel() to produce the model based on the solver and the executionState.
|
nodiscard |
If there are concolic variables in the program, compute a new final state by rerunning the solver on the concolic assignments. If the concolic assignment is not satisfiable, return std::nullopt. Otherwise, create a new final state with the new assignment. IMPORTANT: Some variables in this final state may have been added in post, e.g., the payload size. If the concolic variables do not recompute these variables, the model will simply copy these variables over manually to the newly generated model.
Transfer any derived variables from that are missing in this model. Do NOT update any variables that already exist.
|
nodiscard |
|
nodiscard |
|
nodiscard |
|
nodiscard |
|
nodiscard |