diff options
author | Daniel Schemmel <daniel@schemmel.net> | 2023-03-24 15:05:43 +0000 |
---|---|---|
committer | Cristian Cadar <c.cadar@imperial.ac.uk> | 2023-04-21 13:07:31 +0100 |
commit | ac0fa15ab0679fe1b5067b07647b0701ae3bc347 (patch) | |
tree | f2294eb5f0795ee9ce0f92d527242b7b7a507e79 /lib/Core | |
parent | e9d77be6c688836d68a2be5f3f0a02e63f392bb8 (diff) | |
download | klee-ac0fa15ab0679fe1b5067b07647b0701ae3bc347.tar.gz |
use unique_ptr all throughout the solver chain
Diffstat (limited to 'lib/Core')
-rw-r--r-- | lib/Core/Executor.cpp | 19 | ||||
-rw-r--r-- | lib/Core/Executor.h | 2 | ||||
-rw-r--r-- | lib/Core/TimingSolver.h | 5 |
3 files changed, 13 insertions, 13 deletions
diff --git a/lib/Core/Executor.cpp b/lib/Core/Executor.cpp index b13afb6a..0b28d608 100644 --- a/lib/Core/Executor.cpp +++ b/lib/Core/Executor.cpp @@ -481,19 +481,19 @@ Executor::Executor(LLVMContext &ctx, const InterpreterOptions &opts, coreSolverTimeout = time::Span{MaxCoreSolverTime}; if (coreSolverTimeout) UseForkedCoreSolver = true; - Solver *coreSolver = klee::createCoreSolver(CoreSolverToUse); + std::unique_ptr<Solver> coreSolver = klee::createCoreSolver(CoreSolverToUse); if (!coreSolver) { klee_error("Failed to create core solver\n"); } - Solver *solver = constructSolverChain( - coreSolver, + std::unique_ptr<Solver> solver = constructSolverChain( + std::move(coreSolver), interpreterHandler->getOutputFilename(ALL_QUERIES_SMT2_FILE_NAME), interpreterHandler->getOutputFilename(SOLVER_QUERIES_SMT2_FILE_NAME), interpreterHandler->getOutputFilename(ALL_QUERIES_KQUERY_FILE_NAME), interpreterHandler->getOutputFilename(SOLVER_QUERIES_KQUERY_FILE_NAME)); - this->solver = new TimingSolver(solver, EqualitySubstitution); + this->solver = std::make_unique<TimingSolver>(std::move(solver), EqualitySubstitution); memory = new MemoryManager(&arrayCache); initializeSearchOptions(); @@ -593,7 +593,6 @@ Executor::~Executor() { delete externalDispatcher; delete specialFunctionHandler; delete statsTracker; - delete solver; } /***/ @@ -1236,7 +1235,7 @@ void Executor::addConstraint(ExecutionState &state, ref<Expr> condition) { assert(success && "FIXME: Unhandled solver failure"); (void) success; if (res) { - siit->patchSeed(state, condition, solver); + siit->patchSeed(state, condition, solver.get()); warn = true; } } @@ -3895,7 +3894,7 @@ void Executor::callExternalFunction(ExecutionState &state, // Checking to see if the argument is a pointer to something if (ce->getWidth() == Context::get().getPointerWidth() && state.addressSpace.resolveOne(ce, op)) { - op.second->flushToConcreteStore(solver, state); + op.second->flushToConcreteStore(solver.get(), state); } wordIndex += (ce->getWidth()+63)/64; } else { @@ -4234,7 +4233,7 @@ void Executor::resolveExact(ExecutionState &state, p = optimizer.optimizeExpr(p, true); // XXX we may want to be capping this? ResolutionList rl; - state.addressSpace.resolve(state, solver, p, rl); + state.addressSpace.resolve(state, solver.get(), p, rl); ExecutionState *unbound = &state; for (ResolutionList::iterator it = rl.begin(), ie = rl.end(); @@ -4294,7 +4293,7 @@ void Executor::executeMemoryOperation(ExecutionState &state, ObjectPair op; bool success; solver->setTimeout(coreSolverTimeout); - if (!state.addressSpace.resolveOne(state, solver, address, op, success)) { + if (!state.addressSpace.resolveOne(state, solver.get(), address, op, success)) { address = toConstant(state, address, "resolveOne failure"); success = state.addressSpace.resolveOne(cast<ConstantExpr>(address), op); } @@ -4351,7 +4350,7 @@ void Executor::executeMemoryOperation(ExecutionState &state, address = optimizer.optimizeExpr(address, true); ResolutionList rl; solver->setTimeout(coreSolverTimeout); - bool incomplete = state.addressSpace.resolve(state, solver, address, rl, + bool incomplete = state.addressSpace.resolve(state, solver.get(), address, rl, 0, coreSolverTimeout); solver->setTimeout(time::Span()); diff --git a/lib/Core/Executor.h b/lib/Core/Executor.h index 28a7d56d..40111af9 100644 --- a/lib/Core/Executor.h +++ b/lib/Core/Executor.h @@ -110,7 +110,7 @@ private: Searcher *searcher; ExternalDispatcher *externalDispatcher; - TimingSolver *solver; + std::unique_ptr<TimingSolver> solver; MemoryManager *memory; std::set<ExecutionState*, ExecutionStateIDCompare> states; StatsTracker *statsTracker; diff --git a/lib/Core/TimingSolver.h b/lib/Core/TimingSolver.h index 1f179e54..0b88be3c 100644 --- a/lib/Core/TimingSolver.h +++ b/lib/Core/TimingSolver.h @@ -16,6 +16,7 @@ #include "klee/System/Time.h" #include <memory> +#include <utility> #include <vector> namespace klee { @@ -35,8 +36,8 @@ public: /// \param _simplifyExprs - Whether expressions should be /// simplified (via the constraint manager interface) prior to /// querying. - TimingSolver(Solver *_solver, bool _simplifyExprs = true) - : solver(_solver), simplifyExprs(_simplifyExprs) {} + TimingSolver(std::unique_ptr<Solver> solver, bool simplifyExprs = true) + : solver(std::move(solver)), simplifyExprs(simplifyExprs) {} void setTimeout(time::Span t) { solver->setCoreSolverTimeout(t); } |