aboutsummaryrefslogtreecommitdiffstats
path: root/vm/vm.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2015-03-03 18:56:43 +0800
committerobscuren <geffobscura@gmail.com>2015-03-03 18:56:43 +0800
commitba0a758d8c7c574047d5d4ece9fde0b42a62fc6f (patch)
treea78c69f4069f80a3835b44f50478b6505362421d /vm/vm.go
parent49da6a8d809ecc5f5b1f3c5ccea9ebcd45d4e1c3 (diff)
downloadgo-tangerine-ba0a758d8c7c574047d5d4ece9fde0b42a62fc6f.tar
go-tangerine-ba0a758d8c7c574047d5d4ece9fde0b42a62fc6f.tar.gz
go-tangerine-ba0a758d8c7c574047d5d4ece9fde0b42a62fc6f.tar.bz2
go-tangerine-ba0a758d8c7c574047d5d4ece9fde0b42a62fc6f.tar.lz
go-tangerine-ba0a758d8c7c574047d5d4ece9fde0b42a62fc6f.tar.xz
go-tangerine-ba0a758d8c7c574047d5d4ece9fde0b42a62fc6f.tar.zst
go-tangerine-ba0a758d8c7c574047d5d4ece9fde0b42a62fc6f.zip
Quad mem & log changes
Diffstat (limited to 'vm/vm.go')
-rw-r--r--vm/vm.go18
1 files changed, 11 insertions, 7 deletions
diff --git a/vm/vm.go b/vm/vm.go
index b9c7f73a8..03acb72d2 100644
--- a/vm/vm.go
+++ b/vm/vm.go
@@ -399,7 +399,7 @@ func (self *Vm) Run(me, caller ContextRef, code []byte, value, gas, price *big.I
stack.Push(ethutil.BigD(data))
- self.Printf(" => %x", data)
+ self.Printf(" => (%v) %x", size, data)
// 0x30 range
case ADDRESS:
stack.Push(ethutil.BigD(context.Address()))
@@ -690,6 +690,10 @@ func (self *Vm) Run(me, caller ContextRef, code []byte, value, gas, price *big.I
// Get the arguments from the memory
args := mem.Get(inOffset.Int64(), inSize.Int64())
+ if len(value.Bytes()) > 0 {
+ gas.Add(gas, GasStipend)
+ }
+
var (
ret []byte
err error
@@ -938,7 +942,7 @@ func (self *Vm) calculateGasAndSize(context *Context, caller ContextRef, op OpCo
gas.Add(gas, GasCallNewAccount)
}
- if len(stack.data[stack.Len()-1].Bytes()) > 0 {
+ if len(stack.data[stack.Len()-3].Bytes()) > 0 {
gas.Add(gas, GasCallValueTransfer)
}
}
@@ -951,7 +955,8 @@ func (self *Vm) calculateGasAndSize(context *Context, caller ContextRef, op OpCo
}
if newMemSize.Cmp(ethutil.Big0) > 0 {
- newMemSize = toWordSize(newMemSize)
+ newMemSizeWords := toWordSize(newMemSize)
+ newMemSize.Mul(newMemSizeWords, u256(32))
if newMemSize.Cmp(u256(int64(mem.Len()))) > 0 {
//memGasUsage := new(big.Int).Sub(newMemSize, u256(int64(mem.Len())))
@@ -959,20 +964,19 @@ func (self *Vm) calculateGasAndSize(context *Context, caller ContextRef, op OpCo
//memGasUsage.Div(memGasUsage, u256(32))
//Old: full_memory_gas_cost = W + floor(W*W / 1024), W = words in memory
- pow := new(big.Int).Exp(oldSize, ethutil.Big2, Zero)
oldSize := toWordSize(big.NewInt(int64(mem.Len())))
+ pow := new(big.Int).Exp(oldSize, ethutil.Big2, Zero)
linCoef := new(big.Int).Mul(oldSize, GasMemWord)
quadCoef := new(big.Int).Div(pow, GasQuadCoeffDenom)
oldTotalFee := new(big.Int).Add(linCoef, quadCoef)
- pow.Exp(newMemSize, ethutil.Big2, Zero)
- linCoef = new(big.Int).Mul(newMemSize, GasMemWord)
+ pow.Exp(newMemSizeWords, ethutil.Big2, Zero)
+ linCoef = new(big.Int).Mul(newMemSizeWords, GasMemWord)
quadCoef = new(big.Int).Div(pow, GasQuadCoeffDenom)
newTotalFee := new(big.Int).Add(linCoef, quadCoef)
gas.Add(gas, new(big.Int).Sub(newTotalFee, oldTotalFee))
}
-
}
return newMemSize, gas