diff options
author | obscuren <geffobscura@gmail.com> | 2014-12-20 09:45:05 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2014-12-20 09:45:05 +0800 |
commit | 125bdc325352823bcf83a1a671a0bfaea1d7d7ff (patch) | |
tree | b2720bfa2e26d8c39d0ef34653c7dee649c76821 /core/execution.go | |
parent | 75f0412f9dcd883d93cbf39a90d9c434c746d19e (diff) | |
parent | 6cff6dd8b863e340851a9ec9a559881ea9520688 (diff) | |
download | dexon-125bdc325352823bcf83a1a671a0bfaea1d7d7ff.tar dexon-125bdc325352823bcf83a1a671a0bfaea1d7d7ff.tar.gz dexon-125bdc325352823bcf83a1a671a0bfaea1d7d7ff.tar.bz2 dexon-125bdc325352823bcf83a1a671a0bfaea1d7d7ff.tar.lz dexon-125bdc325352823bcf83a1a671a0bfaea1d7d7ff.tar.xz dexon-125bdc325352823bcf83a1a671a0bfaea1d7d7ff.tar.zst dexon-125bdc325352823bcf83a1a671a0bfaea1d7d7ff.zip |
Merge branch 'develop' into poc8
Conflicts:
cmd/ethereum/flags.go
Diffstat (limited to 'core/execution.go')
-rw-r--r-- | core/execution.go | 33 |
1 files changed, 14 insertions, 19 deletions
diff --git a/core/execution.go b/core/execution.go index cd98746c4..b7eead0dd 100644 --- a/core/execution.go +++ b/core/execution.go @@ -3,23 +3,21 @@ package core import ( "fmt" "math/big" + "time" "github.com/ethereum/go-ethereum/state" "github.com/ethereum/go-ethereum/vm" ) type Execution struct { - vm vm.VirtualMachine + env vm.Environment address, input []byte Gas, price, value *big.Int - object *state.StateObject SkipTransfer bool } func NewExecution(env vm.Environment, address, input []byte, gas, gasPrice, value *big.Int) *Execution { - evm := vm.New(env, vm.DebugVmTy) - - return &Execution{vm: evm, address: address, input: input, Gas: gas, price: gasPrice, value: value} + return &Execution{env: env, address: address, input: input, Gas: gas, price: gasPrice, value: value} } func (self *Execution) Addr() []byte { @@ -28,16 +26,16 @@ func (self *Execution) Addr() []byte { func (self *Execution) Call(codeAddr []byte, caller vm.ClosureRef) ([]byte, error) { // Retrieve the executing code - code := self.vm.Env().State().GetCode(codeAddr) + code := self.env.State().GetCode(codeAddr) return self.exec(code, codeAddr, caller) } func (self *Execution) exec(code, contextAddr []byte, caller vm.ClosureRef) (ret []byte, err error) { - env := self.vm.Env() - chainlogger.Debugf("pre state %x\n", env.State().Root()) + env := self.env + evm := vm.New(env, vm.DebugVmTy) - if self.vm.Env().Depth() == vm.MaxCallDepth { + if env.Depth() == vm.MaxCallDepth { // Consume all gas (by not returning it) and return a depth error return nil, vm.DepthError{} } @@ -55,22 +53,19 @@ func (self *Execution) exec(code, contextAddr []byte, caller vm.ClosureRef) (ret } snapshot := env.State().Copy() - defer func() { - if /*vm.IsDepthErr(err) ||*/ vm.IsOOGErr(err) { - env.State().Set(snapshot) - } - chainlogger.Debugf("post state %x\n", env.State().Root()) - }() - - self.object = to - ret, err = self.vm.Run(to, caller, code, self.value, self.Gas, self.price, self.input) + start := time.Now() + ret, err = evm.Run(to, caller, code, self.value, self.Gas, self.price, self.input) + if err != nil { + env.State().Set(snapshot) + } + chainlogger.Debugf("vm took %v\n", time.Since(start)) return } func (self *Execution) Create(caller vm.ClosureRef) (ret []byte, err error, account *state.StateObject) { ret, err = self.exec(self.input, nil, caller) - account = self.vm.Env().State().GetStateObject(self.address) + account = self.env.State().GetStateObject(self.address) return } |