aboutsummaryrefslogtreecommitdiffstats
path: root/ethchain/vm.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2014-04-18 19:41:07 +0800
committerobscuren <geffobscura@gmail.com>2014-04-18 19:41:07 +0800
commita96c8c8af969665cc0c357eef81d43b5b7285dfe (patch)
tree6578941fc1b32f848e65ef763a0ce7315ec6d850 /ethchain/vm.go
parentc5729d7ecc564f8eff6df565173a4f5cc6c43cb0 (diff)
downloadgo-tangerine-a96c8c8af969665cc0c357eef81d43b5b7285dfe.tar
go-tangerine-a96c8c8af969665cc0c357eef81d43b5b7285dfe.tar.gz
go-tangerine-a96c8c8af969665cc0c357eef81d43b5b7285dfe.tar.bz2
go-tangerine-a96c8c8af969665cc0c357eef81d43b5b7285dfe.tar.lz
go-tangerine-a96c8c8af969665cc0c357eef81d43b5b7285dfe.tar.xz
go-tangerine-a96c8c8af969665cc0c357eef81d43b5b7285dfe.tar.zst
go-tangerine-a96c8c8af969665cc0c357eef81d43b5b7285dfe.zip
Added proper gas handling
Diffstat (limited to 'ethchain/vm.go')
-rw-r--r--ethchain/vm.go9
1 files changed, 5 insertions, 4 deletions
diff --git a/ethchain/vm.go b/ethchain/vm.go
index 33d667457..85aefa685 100644
--- a/ethchain/vm.go
+++ b/ethchain/vm.go
@@ -71,7 +71,7 @@ func (vm *Vm) RunClosure(closure *Closure, hook DebugHook) (ret []byte, err erro
// New stack (should this be shared?)
stack := NewStack()
require := func(m int) {
- if stack.Len()-1 > m {
+ if stack.Len() < m {
isRequireError = true
panic(fmt.Sprintf("stack = %d, req = %d", stack.Len(), m))
}
@@ -105,7 +105,7 @@ func (vm *Vm) RunClosure(closure *Closure, hook DebugHook) (ret []byte, err erro
// TODO Get each instruction cost properly
gas := new(big.Int)
useGas := func(amount *big.Int) {
- gas.Add(gas, amount)
+ gas.Add(gas, new(big.Int).Mul(amount, closure.Price))
}
switch op {
@@ -142,6 +142,7 @@ func (vm *Vm) RunClosure(closure *Closure, hook DebugHook) (ret []byte, err erro
return closure.Return(nil), fmt.Errorf("insufficient gas %v %v", closure.Gas, gas)
}
+ closure.Gas.Sub(closure.Gas, gas)
switch op {
case oLOG:
@@ -411,7 +412,7 @@ func (vm *Vm) RunClosure(closure *Closure, hook DebugHook) (ret []byte, err erro
// 0x60 range
case oCREATE:
case oCALL:
- require(8)
+ require(7)
// Closure addr
addr := stack.Pop()
// Pop gas and value of the stack.
@@ -425,7 +426,7 @@ func (vm *Vm) RunClosure(closure *Closure, hook DebugHook) (ret []byte, err erro
// Fetch the contract which will serve as the closure body
contract := vm.state.GetContract(addr.Bytes())
// Create a new callable closure
- closure := NewClosure(closure, contract, contract.script, vm.state, gas, value)
+ closure := NewClosure(closure, contract, contract.script, vm.state, gas, closure.Price, value)
// Executer the closure and get the return value (if any)
ret, err := closure.Call(vm, args, hook)
if err != nil {