Browse Source

Avoid memneed overflow

cl-refactor
Christoph Jentzsch 10 years ago
committed by CJentzsch
parent
commit
e6358fce31
  1. 12
      libevm/VM.h

12
libevm/VM.h

@ -173,15 +173,15 @@ template <class Ext> dev::bytesConstRef dev::eth::VM::go(Ext& _ext, OnOpFunc con
// These all operate on memory and therefore potentially expand it: // These all operate on memory and therefore potentially expand it:
case Instruction::MSTORE: case Instruction::MSTORE:
require(2); require(2);
newTempSize = m_stack.back() + 32; newTempSize = (bigint)m_stack.back() + 32;
break; break;
case Instruction::MSTORE8: case Instruction::MSTORE8:
require(2); require(2);
newTempSize = m_stack.back() + 1; newTempSize = (bigint)m_stack.back() + 1;
break; break;
case Instruction::MLOAD: case Instruction::MLOAD:
require(1); require(1);
newTempSize = m_stack.back() + 32; newTempSize = (bigint)m_stack.back() + 32;
break; break;
case Instruction::RETURN: case Instruction::RETURN:
require(2); require(2);
@ -236,9 +236,9 @@ template <class Ext> dev::bytesConstRef dev::eth::VM::go(Ext& _ext, OnOpFunc con
case Instruction::CREATE: case Instruction::CREATE:
{ {
require(3); require(3);
auto inOff = m_stack[m_stack.size() - 2]; u256 inOff = m_stack[m_stack.size() - 2];
auto inSize = m_stack[m_stack.size() - 3]; u256 inSize = m_stack[m_stack.size() - 3];
newTempSize = inOff + inSize; newTempSize = (bigint)inOff + inSize;
runGas = c_createGas; runGas = c_createGas;
break; break;
} }

Loading…
Cancel
Save