diff options
author | obscuren <geffobscura@gmail.com> | 2015-03-03 20:29:52 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2015-03-03 20:29:52 +0800 |
commit | fa831206c617b398c3b74a1b6589893cd9dde6bd (patch) | |
tree | c975ff97f4af816e3c768a57d5a9c538abe4eabb /vm/vm.go | |
parent | ffa6b99ab638af7bb6753b663612bad48019c334 (diff) | |
download | dexon-fa831206c617b398c3b74a1b6589893cd9dde6bd.tar dexon-fa831206c617b398c3b74a1b6589893cd9dde6bd.tar.gz dexon-fa831206c617b398c3b74a1b6589893cd9dde6bd.tar.bz2 dexon-fa831206c617b398c3b74a1b6589893cd9dde6bd.tar.lz dexon-fa831206c617b398c3b74a1b6589893cd9dde6bd.tar.xz dexon-fa831206c617b398c3b74a1b6589893cd9dde6bd.tar.zst dexon-fa831206c617b398c3b74a1b6589893cd9dde6bd.zip |
Updated gast costs
Diffstat (limited to 'vm/vm.go')
-rw-r--r-- | vm/vm.go | 16 |
1 files changed, 5 insertions, 11 deletions
@@ -931,9 +931,9 @@ func (self *Vm) calculateGasAndSize(context *Context, caller ContextRef, op OpCo words := toWordSize(stack.data[stack.Len()-4]) gas.Add(gas, words.Mul(words, GasCopyWord)) + case CREATE: - size := new(big.Int).Set(stack.data[stack.Len()-2]) - gas.Add(gas, size.Mul(size, GasCreateByte)) + newMemSize = calcMemSize(stack.data[stack.Len()-2], stack.data[stack.Len()-3]) case CALL, CALLCODE: gas.Add(gas, stack.data[stack.Len()-1]) @@ -941,17 +941,16 @@ func (self *Vm) calculateGasAndSize(context *Context, caller ContextRef, op OpCo if self.env.State().GetStateObject(stack.data[stack.Len()-2].Bytes()) == nil { gas.Add(gas, GasCallNewAccount) } + } - if len(stack.data[stack.Len()-3].Bytes()) > 0 { - gas.Add(gas, GasCallValueTransfer) - } + if len(stack.data[stack.Len()-3].Bytes()) > 0 { + gas.Add(gas, GasCallValueTransfer) } x := calcMemSize(stack.data[stack.Len()-6], stack.data[stack.Len()-7]) y := calcMemSize(stack.data[stack.Len()-4], stack.data[stack.Len()-5]) newMemSize = ethutil.BigMax(x, y) - newMemSize = calcMemSize(stack.data[stack.Len()-2], stack.data[stack.Len()-3]) } if newMemSize.Cmp(ethutil.Big0) > 0 { @@ -959,11 +958,6 @@ func (self *Vm) calculateGasAndSize(context *Context, caller ContextRef, op OpCo newMemSize.Mul(newMemSizeWords, u256(32)) if newMemSize.Cmp(u256(int64(mem.Len()))) > 0 { - //memGasUsage := new(big.Int).Sub(newMemSize, u256(int64(mem.Len()))) - //memGasUsage.Mul(GasMemWord, memGasUsage) - //memGasUsage.Div(memGasUsage, u256(32)) - - //Old: full_memory_gas_cost = W + floor(W*W / 1024), W = words in memory oldSize := toWordSize(big.NewInt(int64(mem.Len()))) pow := new(big.Int).Exp(oldSize, ethutil.Big2, Zero) linCoef := new(big.Int).Mul(oldSize, GasMemWord) |