mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Merge pull request #7873 from ethereum/smt_rlimit
[SMTChecker] Use rlimit instead of tlimit for SMT queries
This commit is contained in:
commit
63b56f4673
@ -35,7 +35,7 @@ void CVC4Interface::reset()
|
|||||||
m_variables.clear();
|
m_variables.clear();
|
||||||
m_solver.reset();
|
m_solver.reset();
|
||||||
m_solver.setOption("produce-models", true);
|
m_solver.setOption("produce-models", true);
|
||||||
m_solver.setTimeLimit(queryTimeout);
|
m_solver.setResourceLimit(resourceLimit);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CVC4Interface::push()
|
void CVC4Interface::push()
|
||||||
|
@ -63,6 +63,12 @@ private:
|
|||||||
CVC4::ExprManager m_context;
|
CVC4::ExprManager m_context;
|
||||||
CVC4::SmtEngine m_solver;
|
CVC4::SmtEngine m_solver;
|
||||||
std::map<std::string, CVC4::Expr> m_variables;
|
std::map<std::string, CVC4::Expr> m_variables;
|
||||||
|
|
||||||
|
// CVC4 "basic resources" limit.
|
||||||
|
// This is used to make the runs more deterministic and platform/machine independent.
|
||||||
|
// The tests start failing for CVC4 with less than 6000,
|
||||||
|
// so using double that.
|
||||||
|
static int const resourceLimit = 12000;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -359,10 +359,6 @@ public:
|
|||||||
|
|
||||||
/// @returns how many SMT solvers this interface has.
|
/// @returns how many SMT solvers this interface has.
|
||||||
virtual unsigned solvers() { return 1; }
|
virtual unsigned solvers() { return 1; }
|
||||||
|
|
||||||
protected:
|
|
||||||
// SMT query timeout in milliseconds.
|
|
||||||
static int const queryTimeout = 10000;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -29,10 +29,9 @@ Z3CHCInterface::Z3CHCInterface():
|
|||||||
m_context(m_z3Interface->context()),
|
m_context(m_z3Interface->context()),
|
||||||
m_solver(*m_context)
|
m_solver(*m_context)
|
||||||
{
|
{
|
||||||
// This needs to be set globally.
|
// These need to be set globally.
|
||||||
z3::set_param("rewriter.pull_cheap_ite", true);
|
z3::set_param("rewriter.pull_cheap_ite", true);
|
||||||
// This needs to be set in the context.
|
z3::set_param("rlimit", Z3Interface::resourceLimit);
|
||||||
m_context->set("timeout", queryTimeout);
|
|
||||||
|
|
||||||
// Spacer options.
|
// Spacer options.
|
||||||
// These needs to be set in the solver.
|
// These needs to be set in the solver.
|
||||||
|
@ -54,9 +54,6 @@ private:
|
|||||||
z3::context* m_context;
|
z3::context* m_context;
|
||||||
// Horn solver.
|
// Horn solver.
|
||||||
z3::fixedpoint m_solver;
|
z3::fixedpoint m_solver;
|
||||||
|
|
||||||
// SMT query timeout in milliseconds.
|
|
||||||
static int const queryTimeout = 10000;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -27,10 +27,9 @@ using namespace dev::solidity::smt;
|
|||||||
Z3Interface::Z3Interface():
|
Z3Interface::Z3Interface():
|
||||||
m_solver(m_context)
|
m_solver(m_context)
|
||||||
{
|
{
|
||||||
// This needs to be set globally.
|
// These need to be set globally.
|
||||||
z3::set_param("rewriter.pull_cheap_ite", true);
|
z3::set_param("rewriter.pull_cheap_ite", true);
|
||||||
// This needs to be set in the context.
|
z3::set_param("rlimit", resourceLimit);
|
||||||
m_context.set("timeout", queryTimeout);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Z3Interface::reset()
|
void Z3Interface::reset()
|
||||||
|
@ -50,6 +50,12 @@ public:
|
|||||||
|
|
||||||
z3::context* context() { return &m_context; }
|
z3::context* context() { return &m_context; }
|
||||||
|
|
||||||
|
// Z3 "basic resources" limit.
|
||||||
|
// This is used to make the runs more deterministic and platform/machine independent.
|
||||||
|
// The tests start failing for Z3 with less than 20000000,
|
||||||
|
// so using double that.
|
||||||
|
static int const resourceLimit = 40000000;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void declareFunction(std::string const& _name, Sort const& _sort);
|
void declareFunction(std::string const& _name, Sort const& _sort);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user