aboutsummaryrefslogtreecommitdiffstats
path: root/ethvm/vm.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2014-07-25 16:43:59 +0800
committerobscuren <geffobscura@gmail.com>2014-07-25 16:43:59 +0800
commit92ffc1cc4c7227de93d933181a30c57c5730c41f (patch)
tree6fe0805649ddf38b2b90e77c5fb2000a4bdab536 /ethvm/vm.go
parent702cf5a3e19e33616e7e98ec8ab7a00d56dd7e85 (diff)
parent54f9ea14e197ad805f24592153f1b9e69f3bc5c3 (diff)
downloadgo-tangerine-92ffc1cc4c7227de93d933181a30c57c5730c41f.tar
go-tangerine-92ffc1cc4c7227de93d933181a30c57c5730c41f.tar.gz
go-tangerine-92ffc1cc4c7227de93d933181a30c57c5730c41f.tar.bz2
go-tangerine-92ffc1cc4c7227de93d933181a30c57c5730c41f.tar.lz
go-tangerine-92ffc1cc4c7227de93d933181a30c57c5730c41f.tar.xz
go-tangerine-92ffc1cc4c7227de93d933181a30c57c5730c41f.tar.zst
go-tangerine-92ffc1cc4c7227de93d933181a30c57c5730c41f.zip
Merge branch 'release/0.6.0' into develop
Diffstat (limited to 'ethvm/vm.go')
-rw-r--r--ethvm/vm.go43
1 files changed, 16 insertions, 27 deletions
diff --git a/ethvm/vm.go b/ethvm/vm.go
index b81c8a189..a93b56e60 100644
--- a/ethvm/vm.go
+++ b/ethvm/vm.go
@@ -282,20 +282,15 @@ func (self *Vm) RunClosure(closure *Closure) (ret []byte, err error) {
case SDIV:
require(2)
x, y := stack.Popn()
- // n > 2**255
- if x.Cmp(Pow256) > 0 {
- x.Sub(Pow256, x)
- }
- if y.Cmp(Pow256) > 0 {
- y.Sub(Pow256, y)
- }
- z := new(big.Int)
- z.Div(x, y)
- if z.Cmp(Pow256) > 0 {
- z.Sub(Pow256, z)
+ self.Printf(" %v / %v", y, x)
+
+ if x.Cmp(ethutil.Big0) != 0 {
+ base.Div(y, x)
}
- // Push result on to the stack
- stack.Push(z)
+
+ self.Printf(" = %v", base)
+ // Pop result back on the stack
+ stack.Push(base)
case MOD:
require(2)
x, y := stack.Popn()
@@ -309,20 +304,14 @@ func (self *Vm) RunClosure(closure *Closure) (ret []byte, err error) {
case SMOD:
require(2)
x, y := stack.Popn()
- // n > 2**255
- if x.Cmp(Pow256) > 0 {
- x.Sub(Pow256, x)
- }
- if y.Cmp(Pow256) > 0 {
- y.Sub(Pow256, y)
- }
- z := new(big.Int)
- z.Mod(x, y)
- if z.Cmp(Pow256) > 0 {
- z.Sub(Pow256, z)
- }
- // Push result on to the stack
- stack.Push(z)
+
+ self.Printf(" %v %% %v", y, x)
+
+ base.Mod(y, x)
+
+ self.Printf(" = %v", base)
+ stack.Push(base)
+
case EXP:
require(2)
x, y := stack.Popn()