Skip to content
This repository has been archived by the owner on Dec 4, 2024. It is now read-only.

Commit

Permalink
fixed error handling for op code CREATE2 (#1587)
Browse files Browse the repository at this point in the history
  • Loading branch information
dusan-maksimovic authored Jun 5, 2023
1 parent fc803f1 commit 2c2c45d
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 1 deletion.
4 changes: 3 additions & 1 deletion state/runtime/evm/instructions.go
Original file line number Diff line number Diff line change
Expand Up @@ -1101,7 +1101,9 @@ func opCreate(op OpCode) instruction {
v := c.push1()
if op == CREATE && c.config.Homestead && errors.Is(result.Err, runtime.ErrCodeStoreOutOfGas) {
v.Set(zero)
} else if result.Failed() && !errors.Is(result.Err, runtime.ErrCodeStoreOutOfGas) {
} else if op == CREATE && result.Failed() && !errors.Is(result.Err, runtime.ErrCodeStoreOutOfGas) {
v.Set(zero)
} else if op == CREATE2 && result.Failed() {
v.Set(zero)
} else {
v.SetBytes(contract.Address.Bytes())
Expand Down
51 changes: 51 additions & 0 deletions state/runtime/evm/instructions_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -359,6 +359,57 @@ func TestCreate(t *testing.T) {
},
},
},
{
name: "should set zero address if contract call throws any error for CREATE2",
op: CREATE2,
contract: &runtime.Contract{
Static: false,
Address: addr1,
},
config: &chain.ForksInTime{
Homestead: true,
Constantinople: true,
},
initState: &state{
gas: 1000,
sp: 4,
stack: []*big.Int{
big.NewInt(0x01), // salt
big.NewInt(0x01), // length
big.NewInt(0x00), // offset
big.NewInt(0x00), // value
},
memory: []byte{
byte(REVERT),
},
stop: false,
err: nil,
},
// during creation of code with length 1 for CREATE2 op code, 985 gas units are spent by buildCreateContract()
resultState: &state{
gas: 15,
sp: 1,
stack: []*big.Int{
big.NewInt(0x01).SetInt64(0x00),
big.NewInt(0x01),
big.NewInt(0x00),
big.NewInt(0x00),
},
memory: []byte{
byte(REVERT),
},
stop: false,
err: nil,
},
mockHost: &mockHostForInstructions{
nonce: 0,
callxResult: &runtime.ExecutionResult{
// if it is ErrCodeStoreOutOfGas then we set GasLeft to 0
GasLeft: 0,
Err: runtime.ErrCodeStoreOutOfGas,
},
},
},
}

for _, tt := range tests {
Expand Down

0 comments on commit 2c2c45d

Please sign in to comment.