aboutsummaryrefslogtreecommitdiffhomepage
path: root/lib/Solver/Z3Solver.cpp
diff options
context:
space:
mode:
authorTimotej Kapus <timotej.kapus13@imperial.ac.uk>2018-03-16 10:42:12 +0000
committerCristian Cadar <c.cadar@imperial.ac.uk>2018-05-09 12:19:53 +0100
commit13b5bcbfd933461526f08c6ad759af9e129d6764 (patch)
treefb3eb848493ccf697f8193aeae81d098874dc340 /lib/Solver/Z3Solver.cpp
parente0aff85c24c039606d82d209617a1334a9ed21e2 (diff)
downloadklee-13b5bcbfd933461526f08c6ad759af9e129d6764.tar.gz
Improve handling of constant array in Z3
Diffstat (limited to 'lib/Solver/Z3Solver.cpp')
-rw-r--r--lib/Solver/Z3Solver.cpp54
1 files changed, 37 insertions, 17 deletions
diff --git a/lib/Solver/Z3Solver.cpp b/lib/Solver/Z3Solver.cpp
index 985c143d..e89c9463 100644
--- a/lib/Solver/Z3Solver.cpp
+++ b/lib/Solver/Z3Solver.cpp
@@ -153,19 +153,10 @@ char *Z3SolverImpl::getConstraintLog(const Query &query) {
// with whatever the solver's builder is set to do.
Z3Builder temp_builder(/*autoClearConstructCache=*/false,
/*z3LogInteractionFile=*/NULL);
-
- for (std::vector<ref<Expr> >::const_iterator it = query.constraints.begin(),
- ie = query.constraints.end();
- it != ie; ++it) {
- assumptions.push_back(temp_builder.construct(*it));
- }
- ::Z3_ast *assumptionsArray = NULL;
- int numAssumptions = query.constraints.size();
- if (numAssumptions) {
- assumptionsArray = (::Z3_ast *)malloc(sizeof(::Z3_ast) * numAssumptions);
- for (int index = 0; index < numAssumptions; ++index) {
- assumptionsArray[index] = (::Z3_ast)assumptions[index];
- }
+ ConstantArrayFinder constant_arrays_in_query;
+ for (auto const &constraint : query.constraints) {
+ assumptions.push_back(temp_builder.construct(constraint));
+ constant_arrays_in_query.visit(constraint);
}
// KLEE Queries are validity queries i.e.
@@ -176,6 +167,25 @@ char *Z3SolverImpl::getConstraintLog(const Query &query) {
Z3ASTHandle formula = Z3ASTHandle(
Z3_mk_not(temp_builder.ctx, temp_builder.construct(query.expr)),
temp_builder.ctx);
+ constant_arrays_in_query.visit(query.expr);
+
+ for (auto const &constant_array : constant_arrays_in_query.results) {
+ assert(builder->constant_array_assertions.count(constant_array) == 1 &&
+ "Constant array found in query, but not handled by Z3Builder");
+ for (auto const &arrayIndexValueExpr :
+ builder->constant_array_assertions[constant_array]) {
+ assumptions.push_back(arrayIndexValueExpr);
+ }
+ }
+
+ ::Z3_ast *assumptionsArray = NULL;
+ int numAssumptions = assumptions.size();
+ if (numAssumptions) {
+ assumptionsArray = (::Z3_ast *)malloc(sizeof(::Z3_ast) * numAssumptions);
+ for (int index = 0; index < numAssumptions; ++index) {
+ assumptionsArray[index] = (::Z3_ast)assumptions[index];
+ }
+ }
::Z3_string result = Z3_benchmark_to_smtlib_string(
temp_builder.ctx,
@@ -249,10 +259,10 @@ bool Z3SolverImpl::internalRunSolver(
runStatusCode = SOLVER_RUN_STATUS_FAILURE;
- for (ConstraintManager::const_iterator it = query.constraints.begin(),
- ie = query.constraints.end();
- it != ie; ++it) {
- Z3_solver_assert(builder->ctx, theSolver, builder->construct(*it));
+ ConstantArrayFinder constant_arrays_in_query;
+ for (auto const &constraint : query.constraints) {
+ Z3_solver_assert(builder->ctx, theSolver, builder->construct(constraint));
+ constant_arrays_in_query.visit(constraint);
}
++stats::queries;
if (objects)
@@ -260,6 +270,16 @@ bool Z3SolverImpl::internalRunSolver(
Z3ASTHandle z3QueryExpr =
Z3ASTHandle(builder->construct(query.expr), builder->ctx);
+ constant_arrays_in_query.visit(query.expr);
+
+ for (auto const &constant_array : constant_arrays_in_query.results) {
+ assert(builder->constant_array_assertions.count(constant_array) == 1 &&
+ "Constant array found in query, but not handled by Z3Builder");
+ for (auto const &arrayIndexValueExpr :
+ builder->constant_array_assertions[constant_array]) {
+ Z3_solver_assert(builder->ctx, theSolver, arrayIndexValueExpr);
+ }
+ }
// KLEE Queries are validity queries i.e.
// ∀ X Constraints(X) → query(X)