Add delegatecall to the optimizer.

This commit is contained in:
chriseth 2016-03-03 16:56:22 +01:00
parent 96ea3c63f3
commit 05d30fc7cf
2 changed files with 11 additions and 4 deletions

View File

@ -126,18 +126,22 @@ GasMeter::GasConsumption GasMeter::estimateMax(AssemblyItem const& _item)
} }
case Instruction::CALL: case Instruction::CALL:
case Instruction::CALLCODE: case Instruction::CALLCODE:
case Instruction::DELEGATECALL:
{
gas = m_schedule.callGas; gas = m_schedule.callGas;
if (u256 const* value = classes.knownConstant(m_state->relativeStackElement(0))) if (u256 const* value = classes.knownConstant(m_state->relativeStackElement(0)))
gas += (*value); gas += (*value);
else else
gas = GasConsumption::infinite(); gas = GasConsumption::infinite();
if (_item.instruction() != Instruction::CALLCODE) if (_item.instruction() == Instruction::CALL)
gas += m_schedule.callNewAccountGas; // We very rarely know whether the address exists. gas += m_schedule.callNewAccountGas; // We very rarely know whether the address exists.
if (!classes.knownZero(m_state->relativeStackElement(-2))) int valueSize = _item.instruction() == Instruction::DELEGATECALL ? 0 : 1;
if (!classes.knownZero(m_state->relativeStackElement(-1 - valueSize)))
gas += m_schedule.callValueTransferGas; gas += m_schedule.callValueTransferGas;
gas += memoryGas(-3, -4); gas += memoryGas(-2 - valueSize, -3 - valueSize);
gas += memoryGas(-5, -6); gas += memoryGas(-4 - valueSize, -5 - valueSize);
break; break;
}
case Instruction::CREATE: case Instruction::CREATE:
gas = m_schedule.createGas; gas = m_schedule.createGas;
gas += memoryGas(-1, -2); gas += memoryGas(-1, -2);

View File

@ -134,6 +134,7 @@ bool SemanticInformation::isDeterministic(AssemblyItem const& _item)
{ {
case Instruction::CALL: case Instruction::CALL:
case Instruction::CALLCODE: case Instruction::CALLCODE:
case Instruction::DELEGATECALL:
case Instruction::CREATE: case Instruction::CREATE:
case Instruction::GAS: case Instruction::GAS:
case Instruction::PC: case Instruction::PC:
@ -157,6 +158,7 @@ bool SemanticInformation::invalidatesMemory(Instruction _instruction)
case Instruction::MSTORE8: case Instruction::MSTORE8:
case Instruction::CALL: case Instruction::CALL:
case Instruction::CALLCODE: case Instruction::CALLCODE:
case Instruction::DELEGATECALL:
return true; return true;
default: default:
return false; return false;
@ -169,6 +171,7 @@ bool SemanticInformation::invalidatesStorage(Instruction _instruction)
{ {
case Instruction::CALL: case Instruction::CALL:
case Instruction::CALLCODE: case Instruction::CALLCODE:
case Instruction::DELEGATECALL:
case Instruction::CREATE: case Instruction::CREATE:
case Instruction::SSTORE: case Instruction::SSTORE:
return true; return true;