mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Add delegatecall to the optimizer.
This commit is contained in:
parent
96ea3c63f3
commit
05d30fc7cf
12
GasMeter.cpp
12
GasMeter.cpp
@ -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);
|
||||||
|
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user