Merge pull request #6397 from ethereum/yulInterpreter-maxSteps

yulInterpreter: Add timeout based on the number of interpreted statem…
This commit is contained in:
chriseth 2019-03-27 14:34:23 +01:00 committed by GitHub
commit 77b8b4874d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 9 additions and 0 deletions

View File

@ -24,6 +24,7 @@ void yulFuzzerUtil::interpret(ostream& _os, shared_ptr<yul::Block> _ast)
{
InterpreterState state;
state.maxTraceSize = 75;
state.maxSteps = 10000;
Interpreter interpreter(state);
try
{

View File

@ -128,6 +128,12 @@ void Interpreter::operator()(Continue const&)
void Interpreter::operator()(Block const& _block)
{
m_state.numSteps++;
if (m_state.maxSteps > 0 && m_state.numSteps >= m_state.maxSteps)
{
m_state.trace.emplace_back("Interpreter execution step limit reached.");
throw InterpreterTerminated();
}
openScope();
// Register functions.
for (auto const& statement: _block.statements)

View File

@ -75,6 +75,8 @@ struct InterpreterState
/// Memory size limit. Anything beyond this will still work, but it has
/// deterministic yet not necessarily consistent behaviour.
size_t maxMemSize = 0x200;
size_t maxSteps = 0;
size_t numSteps = 0;
LoopState loopState = LoopState::Default;
};