aboutsummaryrefslogtreecommitdiffstats
path: root/core/vm
diff options
context:
space:
mode:
authorMartin Holst Swende <martin@swende.se>2018-08-12 20:47:03 +0800
committerPéter Szilágyi <peterke@gmail.com>2018-09-18 18:08:32 +0800
commitcaa2c23a38141911a570ba098a940b4fdbf0aa88 (patch)
treedf85df9790ac43a17d16b08538eb6c629efb7af7 /core/vm
parent58374e28d95c03d8b0e6d9035c0fb92fad3e865e (diff)
downloadgo-tangerine-caa2c23a38141911a570ba098a940b4fdbf0aa88.tar
go-tangerine-caa2c23a38141911a570ba098a940b4fdbf0aa88.tar.gz
go-tangerine-caa2c23a38141911a570ba098a940b4fdbf0aa88.tar.bz2
go-tangerine-caa2c23a38141911a570ba098a940b4fdbf0aa88.tar.lz
go-tangerine-caa2c23a38141911a570ba098a940b4fdbf0aa88.tar.xz
go-tangerine-caa2c23a38141911a570ba098a940b4fdbf0aa88.tar.zst
go-tangerine-caa2c23a38141911a570ba098a940b4fdbf0aa88.zip
core,state: finish implementing Eip 1283
Diffstat (limited to 'core/vm')
-rw-r--r--core/vm/gas_table.go29
-rw-r--r--core/vm/interface.go1
-rw-r--r--core/vm/jump_table.go8
-rw-r--r--core/vm/noop.go1
4 files changed, 23 insertions, 16 deletions
diff --git a/core/vm/gas_table.go b/core/vm/gas_table.go
index aee6d6f6d..77250978d 100644
--- a/core/vm/gas_table.go
+++ b/core/vm/gas_table.go
@@ -17,11 +17,9 @@
package vm
import (
- "bytes"
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/common/math"
"github.com/ethereum/go-ethereum/params"
- "math/big"
)
// memoryGasCosts calculates the quadratic gas for memory expansion. It does so
@@ -117,7 +115,7 @@ func gasReturnDataCopy(gt params.GasTable, evm *EVM, contract *Contract, stack *
return gas, nil
}
-func gasSStoreOld(gt params.GasTable, evm *EVM, contract *Contract, stack *Stack, mem *Memory, memorySize uint64) (uint64, error) {
+func gasSStore(gt params.GasTable, evm *EVM, contract *Contract, stack *Stack, mem *Memory, memorySize uint64) (uint64, error) {
var (
y, x = stack.Back(1), stack.Back(0)
val = evm.StateDB.GetState(contract.Address(), common.BigToHash(x))
@@ -139,10 +137,11 @@ func gasSStoreOld(gt params.GasTable, evm *EVM, contract *Contract, stack *Stack
}
}
-func gasSStore(gt params.GasTable, evm *EVM, contract *Contract, stack *Stack, mem *Memory, memorySize uint64) (uint64, error) {
+// gasSStoreEip1283 calculates SSTORE gas cost according to EIP-1283
+func gasSStoreEip1283(gt params.GasTable, evm *EVM, contract *Contract, stack *Stack, mem *Memory, memorySize uint64) (uint64, error) {
var (
- y, x = stack.Back(1), stack.Back(0)
- current = evm.StateDB.GetState(contract.Address(), common.BigToHash(x))
+ y, x = stack.Back(1), stack.Back(0)
+ current = evm.StateDB.GetState(contract.Address(), common.BigToHash(x))
)
//1. If current value equals new value (this is a no-op), 200 gas is deducted.
//2. If current value does not equal new value
@@ -161,33 +160,31 @@ func gasSStore(gt params.GasTable, evm *EVM, contract *Contract, stack *Stack, m
// 1. current == new
return 200, nil
}
- // Todo, get this value
- original := common.Hash{}
-
+ original := evm.StateDB.GetStateOriginal(contract.Address(), common.BigToHash(x))
// 2
if original == current { // 2.1
- if original == (common.Hash{}){ // 2.1.1
+ if original == (common.Hash{}) { // 2.1.1
return 20000, nil
}
// 2.1.2
- if new == (common.Hash{}){
+ if new == (common.Hash{}) {
evm.StateDB.AddRefund(15000)
}
return 5000, nil
}
// 2.2
- if original != (common.Hash{}){ // 2.2.1
- if current == (common.Hash{}){ // 2.2.1.1
+ if original != (common.Hash{}) { // 2.2.1
+ if current == (common.Hash{}) { // 2.2.1.1
evm.StateDB.SubRefund(15000)
- }else{
+ } else {
// 2.2.1.2
evm.StateDB.AddRefund(15000)
}
}
if original == new { // 2.2.2
- if original == (common.Hash{}){
+ if original == (common.Hash{}) {
evm.StateDB.AddRefund(19800)
- }else{
+ } else {
evm.StateDB.AddRefund(4800)
}
}
diff --git a/core/vm/interface.go b/core/vm/interface.go
index a5a3ff3e3..2e2e3e925 100644
--- a/core/vm/interface.go
+++ b/core/vm/interface.go
@@ -44,6 +44,7 @@ type StateDB interface {
GetRefund() uint64
GetState(common.Address, common.Hash) common.Hash
+ GetStateOriginal(common.Address, common.Hash) common.Hash
SetState(common.Address, common.Hash, common.Hash)
Suicide(common.Address) bool
diff --git a/core/vm/jump_table.go b/core/vm/jump_table.go
index deedf70cd..8a997adc4 100644
--- a/core/vm/jump_table.go
+++ b/core/vm/jump_table.go
@@ -95,6 +95,14 @@ func newConstantinopleInstructionSet() [256]operation {
writes: true,
returns: true,
}
+ instructionSet[SSTORE] = operation{
+ execute: opSstore,
+ gasCost: gasSStoreEip1283,
+ validateStack: makeStackFunc(2, 0),
+ valid: true,
+ writes: true,
+ }
+
return instructionSet
}
diff --git a/core/vm/noop.go b/core/vm/noop.go
index c7ed2e451..19539d978 100644
--- a/core/vm/noop.go
+++ b/core/vm/noop.go
@@ -59,6 +59,7 @@ func (NoopStateDB) AddRefund(uint64)
func (NoopStateDB) SubRefund(uint64) {}
func (NoopStateDB) GetRefund() uint64 { return 0 }
func (NoopStateDB) GetState(common.Address, common.Hash) common.Hash { return common.Hash{} }
+func (NoopStateDB) GetStateOriginal(common.Address, common.Hash) common.Hash { return common.Hash{} }
func (NoopStateDB) SetState(common.Address, common.Hash, common.Hash) {}
func (NoopStateDB) Suicide(common.Address) bool { return false }
func (NoopStateDB) HasSuicided(common.Address) bool { return false }