aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2014-10-28 20:26:30 +0800
committerobscuren <geffobscura@gmail.com>2014-10-28 20:26:30 +0800
commit48125a25eb9f4ece2613559ced5075bde1c75c7a (patch)
tree17d6e70c3d34f8ddb31e8a4d4e7c23086b38eec6
parent7849b7e97873ea443b480f45aa4fe6ffbb41cdb0 (diff)
downloadgo-tangerine-48125a25eb9f4ece2613559ced5075bde1c75c7a.tar
go-tangerine-48125a25eb9f4ece2613559ced5075bde1c75c7a.tar.gz
go-tangerine-48125a25eb9f4ece2613559ced5075bde1c75c7a.tar.bz2
go-tangerine-48125a25eb9f4ece2613559ced5075bde1c75c7a.tar.lz
go-tangerine-48125a25eb9f4ece2613559ced5075bde1c75c7a.tar.xz
go-tangerine-48125a25eb9f4ece2613559ced5075bde1c75c7a.tar.zst
go-tangerine-48125a25eb9f4ece2613559ced5075bde1c75c7a.zip
Added missing requires on SSTORE SLOAD
-rw-r--r--vm/common.go23
-rw-r--r--vm/vm_debug.go6
2 files changed, 17 insertions, 12 deletions
diff --git a/vm/common.go b/vm/common.go
index c73744506..16a0b5523 100644
--- a/vm/common.go
+++ b/vm/common.go
@@ -19,17 +19,18 @@ const (
)
var (
- GasStep = big.NewInt(1)
- GasSha = big.NewInt(20)
- GasSLoad = big.NewInt(20)
- GasSStore = big.NewInt(100)
- GasBalance = big.NewInt(20)
- GasCreate = big.NewInt(100)
- GasCall = big.NewInt(20)
- GasMemory = big.NewInt(1)
- GasData = big.NewInt(5)
- GasTx = big.NewInt(500)
- GasLog = big.NewInt(32)
+ GasStep = big.NewInt(1)
+ GasSha = big.NewInt(20)
+ GasSLoad = big.NewInt(20)
+ GasSStore = big.NewInt(100)
+ GasSStoreRefund = big.NewInt(100)
+ GasBalance = big.NewInt(20)
+ GasCreate = big.NewInt(100)
+ GasCall = big.NewInt(20)
+ GasMemory = big.NewInt(1)
+ GasData = big.NewInt(5)
+ GasTx = big.NewInt(500)
+ GasLog = big.NewInt(32)
Pow256 = ethutil.BigPow(2, 256)
diff --git a/vm/vm_debug.go b/vm/vm_debug.go
index d38373411..1e45813bc 100644
--- a/vm/vm_debug.go
+++ b/vm/vm_debug.go
@@ -169,9 +169,13 @@ func (self *DebugVm) RunClosure(closure *Closure) (ret []byte, err error) {
gas.Set(ethutil.Big0)
case SLOAD:
+ require(1)
+
gas.Set(GasSLoad)
// Memory resize & Gas
case SSTORE:
+ require(2)
+
var mult *big.Int
y, x := stack.Peekn()
val := closure.GetStorage(x)
@@ -179,7 +183,7 @@ func (self *DebugVm) RunClosure(closure *Closure) (ret []byte, err error) {
// 0 => non 0
mult = ethutil.Big3
} else if val.BigInt().Cmp(ethutil.Big0) != 0 && len(y.Bytes()) == 0 {
- state.Refund(closure.caller.Address(), big.NewInt(100), closure.Price)
+ state.Refund(closure.caller.Address(), GasSStoreRefund, closure.Price)
mult = ethutil.Big0
} else {