vm.go 21 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003
  1. package ethvm
  2. import (
  3. "container/list"
  4. "fmt"
  5. "math/big"
  6. "github.com/ethereum/eth-go/ethcrypto"
  7. "github.com/ethereum/eth-go/ethstate"
  8. "github.com/ethereum/eth-go/ethutil"
  9. )
  10. type Debugger interface {
  11. BreakHook(step int, op OpCode, mem *Memory, stack *Stack, object *ethstate.StateObject) bool
  12. StepHook(step int, op OpCode, mem *Memory, stack *Stack, object *ethstate.StateObject) bool
  13. BreakPoints() []int64
  14. SetCode(byteCode []byte)
  15. }
  16. type Vm struct {
  17. env Environment
  18. Verbose bool
  19. logTy byte
  20. logStr string
  21. err error
  22. // Debugging
  23. Dbg Debugger
  24. BreakPoints []int64
  25. Stepping bool
  26. Fn string
  27. Recoverable bool
  28. queue *list.List
  29. }
  30. type Environment interface {
  31. State() *ethstate.State
  32. Origin() []byte
  33. BlockNumber() *big.Int
  34. PrevHash() []byte
  35. Coinbase() []byte
  36. Time() int64
  37. Difficulty() *big.Int
  38. Value() *big.Int
  39. BlockHash() []byte
  40. }
  41. type Object interface {
  42. GetStorage(key *big.Int) *ethutil.Value
  43. SetStorage(key *big.Int, value *ethutil.Value)
  44. }
  45. func New(env Environment) *Vm {
  46. lt := LogTyPretty
  47. if ethutil.Config.Diff {
  48. lt = LogTyDiff
  49. }
  50. return &Vm{env: env, logTy: lt, Recoverable: true, queue: list.New()}
  51. }
  52. func calcMemSize(off, l *big.Int) *big.Int {
  53. if l.Cmp(ethutil.Big0) == 0 {
  54. return ethutil.Big0
  55. }
  56. return new(big.Int).Add(off, l)
  57. }
  58. // Simple helper
  59. func u256(n int64) *big.Int {
  60. return big.NewInt(n)
  61. }
  62. func (self *Vm) RunClosure(closure *Closure) (ret []byte, err error) {
  63. if self.Recoverable {
  64. // Recover from any require exception
  65. defer func() {
  66. if r := recover(); r != nil {
  67. ret = closure.Return(nil)
  68. err = fmt.Errorf("%v", r)
  69. vmlogger.Errorln("vm err", err)
  70. }
  71. }()
  72. }
  73. // Debug hook
  74. if self.Dbg != nil {
  75. self.Dbg.SetCode(closure.Code)
  76. }
  77. // Don't bother with the execution if there's no code.
  78. if len(closure.Code) == 0 {
  79. return closure.Return(nil), nil
  80. }
  81. vmlogger.Debugf("(%s) %x gas: %v (d) %x\n", self.Fn, closure.Address(), closure.Gas, closure.Args)
  82. var (
  83. op OpCode
  84. mem = &Memory{}
  85. stack = NewStack()
  86. pc = big.NewInt(0)
  87. step = 0
  88. prevStep = 0
  89. require = func(m int) {
  90. if stack.Len() < m {
  91. panic(fmt.Sprintf("%04v (%v) stack err size = %d, required = %d", pc, op, stack.Len(), m))
  92. }
  93. }
  94. )
  95. for {
  96. prevStep = step
  97. // The base for all big integer arithmetic
  98. base := new(big.Int)
  99. step++
  100. // Get the memory location of pc
  101. val := closure.Get(pc)
  102. // Get the opcode (it must be an opcode!)
  103. op = OpCode(val.Uint())
  104. // XXX Leave this Println intact. Don't change this to the log system.
  105. // Used for creating diffs between implementations
  106. if self.logTy == LogTyDiff {
  107. /*
  108. switch op {
  109. case STOP, RETURN, SUICIDE:
  110. closure.object.EachStorage(func(key string, value *ethutil.Value) {
  111. value.Decode()
  112. fmt.Printf("%x %x\n", new(big.Int).SetBytes([]byte(key)).Bytes(), value.Bytes())
  113. })
  114. }
  115. */
  116. b := pc.Bytes()
  117. if len(b) == 0 {
  118. b = []byte{0}
  119. }
  120. fmt.Printf("%x %x %x %x\n", closure.Address(), b, []byte{byte(op)}, closure.Gas.Bytes())
  121. }
  122. gas := new(big.Int)
  123. addStepGasUsage := func(amount *big.Int) {
  124. if amount.Cmp(ethutil.Big0) >= 0 {
  125. gas.Add(gas, amount)
  126. }
  127. }
  128. addStepGasUsage(GasStep)
  129. var newMemSize *big.Int = ethutil.Big0
  130. switch op {
  131. case STOP:
  132. gas.Set(ethutil.Big0)
  133. case SUICIDE:
  134. gas.Set(ethutil.Big0)
  135. case SLOAD:
  136. gas.Set(GasSLoad)
  137. case SSTORE:
  138. var mult *big.Int
  139. y, x := stack.Peekn()
  140. val := closure.GetStorage(x)
  141. if val.BigInt().Cmp(ethutil.Big0) == 0 && len(y.Bytes()) > 0 {
  142. mult = ethutil.Big2
  143. } else if val.BigInt().Cmp(ethutil.Big0) != 0 && len(y.Bytes()) == 0 {
  144. mult = ethutil.Big0
  145. } else {
  146. mult = ethutil.Big1
  147. }
  148. gas = new(big.Int).Mul(mult, GasSStore)
  149. case BALANCE:
  150. gas.Set(GasBalance)
  151. case MSTORE:
  152. require(2)
  153. newMemSize = calcMemSize(stack.Peek(), u256(32))
  154. case MLOAD:
  155. require(1)
  156. newMemSize = calcMemSize(stack.Peek(), u256(32))
  157. case MSTORE8:
  158. require(2)
  159. newMemSize = calcMemSize(stack.Peek(), u256(1))
  160. case RETURN:
  161. require(2)
  162. newMemSize = calcMemSize(stack.Peek(), stack.data[stack.Len()-2])
  163. case SHA3:
  164. require(2)
  165. gas.Set(GasSha)
  166. newMemSize = calcMemSize(stack.Peek(), stack.data[stack.Len()-2])
  167. case CALLDATACOPY:
  168. require(3)
  169. newMemSize = calcMemSize(stack.Peek(), stack.data[stack.Len()-3])
  170. case CODECOPY:
  171. require(3)
  172. newMemSize = calcMemSize(stack.Peek(), stack.data[stack.Len()-3])
  173. case EXTCODECOPY:
  174. require(4)
  175. newMemSize = calcMemSize(stack.data[stack.Len()-1], stack.data[stack.Len()-4])
  176. case CALL, CALLSTATELESS:
  177. require(7)
  178. gas.Set(GasCall)
  179. addStepGasUsage(stack.data[stack.Len()-1])
  180. x := calcMemSize(stack.data[stack.Len()-6], stack.data[stack.Len()-7])
  181. y := calcMemSize(stack.data[stack.Len()-4], stack.data[stack.Len()-5])
  182. newMemSize = ethutil.BigMax(x, y)
  183. case CREATE:
  184. require(3)
  185. gas.Set(GasCreate)
  186. newMemSize = calcMemSize(stack.data[stack.Len()-2], stack.data[stack.Len()-3])
  187. }
  188. if newMemSize.Cmp(ethutil.Big0) > 0 {
  189. //newMemSize = (newMemSize + 31) / 32 * 32
  190. newMemSize = newMemSize.Add(newMemSize, u256(31)).Div(newMemSize, u256(32)).Mul(newMemSize, u256(32))
  191. //if newMemSize > uint64(mem.Len()) {
  192. if newMemSize.Cmp(u256(int64(mem.Len()))) > 0 {
  193. newMemSize = newMemSize.Sub(newMemSize, u256(int64(mem.Len())))
  194. memGasUsage := newMemSize.Mul(GasMemory, newMemSize).Div(newMemSize, u256(32))
  195. //m := GasMemory.Uint64() * (newMemSize - uint64(mem.Len())) / 32
  196. addStepGasUsage(memGasUsage)
  197. }
  198. }
  199. if !closure.UseGas(gas) {
  200. err := fmt.Errorf("Insufficient gas for %v. req %v has %v", op, gas, closure.Gas)
  201. closure.UseGas(closure.Gas)
  202. return closure.Return(nil), err
  203. }
  204. self.Printf("(pc) %-3d -o- %-14s", pc, op.String())
  205. self.Printf(" (g) %-3v (%v)", gas, closure.Gas)
  206. mem.Resize(newMemSize.Uint64())
  207. switch op {
  208. case LOG:
  209. stack.Print()
  210. mem.Print()
  211. // 0x20 range
  212. case ADD:
  213. require(2)
  214. x, y := stack.Popn()
  215. self.Printf(" %v + %v", y, x)
  216. base.Add(y, x)
  217. ensure256(base)
  218. self.Printf(" = %v", base)
  219. // Pop result back on the stack
  220. stack.Push(base)
  221. case SUB:
  222. require(2)
  223. x, y := stack.Popn()
  224. self.Printf(" %v - %v", y, x)
  225. base.Sub(y, x)
  226. ensure256(base)
  227. self.Printf(" = %v", base)
  228. // Pop result back on the stack
  229. stack.Push(base)
  230. case MUL:
  231. require(2)
  232. x, y := stack.Popn()
  233. self.Printf(" %v * %v", y, x)
  234. base.Mul(y, x)
  235. ensure256(base)
  236. self.Printf(" = %v", base)
  237. // Pop result back on the stack
  238. stack.Push(base)
  239. case DIV:
  240. require(2)
  241. x, y := stack.Popn()
  242. self.Printf(" %v / %v", y, x)
  243. if x.Cmp(ethutil.Big0) != 0 {
  244. base.Div(y, x)
  245. }
  246. ensure256(base)
  247. self.Printf(" = %v", base)
  248. // Pop result back on the stack
  249. stack.Push(base)
  250. case SDIV:
  251. require(2)
  252. x, y := stack.Popn()
  253. self.Printf(" %v / %v", y, x)
  254. if x.Cmp(ethutil.Big0) != 0 {
  255. base.Div(y, x)
  256. }
  257. ensure256(base)
  258. self.Printf(" = %v", base)
  259. // Pop result back on the stack
  260. stack.Push(base)
  261. case MOD:
  262. require(2)
  263. x, y := stack.Popn()
  264. self.Printf(" %v %% %v", y, x)
  265. base.Mod(y, x)
  266. ensure256(base)
  267. self.Printf(" = %v", base)
  268. stack.Push(base)
  269. case SMOD:
  270. require(2)
  271. x, y := stack.Popn()
  272. self.Printf(" %v %% %v", y, x)
  273. base.Mod(y, x)
  274. ensure256(base)
  275. self.Printf(" = %v", base)
  276. stack.Push(base)
  277. case EXP:
  278. require(2)
  279. x, y := stack.Popn()
  280. self.Printf(" %v ** %v", y, x)
  281. base.Exp(y, x, Pow256)
  282. ensure256(base)
  283. self.Printf(" = %v", base)
  284. stack.Push(base)
  285. case NEG:
  286. require(1)
  287. base.Sub(Pow256, stack.Pop())
  288. stack.Push(base)
  289. case LT:
  290. require(2)
  291. x, y := stack.Popn()
  292. self.Printf(" %v < %v", y, x)
  293. // x < y
  294. if y.Cmp(x) < 0 {
  295. stack.Push(ethutil.BigTrue)
  296. } else {
  297. stack.Push(ethutil.BigFalse)
  298. }
  299. case GT:
  300. require(2)
  301. x, y := stack.Popn()
  302. self.Printf(" %v > %v", y, x)
  303. // x > y
  304. if y.Cmp(x) > 0 {
  305. stack.Push(ethutil.BigTrue)
  306. } else {
  307. stack.Push(ethutil.BigFalse)
  308. }
  309. case SLT:
  310. require(2)
  311. x, y := stack.Popn()
  312. self.Printf(" %v < %v", y, x)
  313. // x < y
  314. if y.Cmp(x) < 0 {
  315. stack.Push(ethutil.BigTrue)
  316. } else {
  317. stack.Push(ethutil.BigFalse)
  318. }
  319. case SGT:
  320. require(2)
  321. x, y := stack.Popn()
  322. self.Printf(" %v > %v", y, x)
  323. // x > y
  324. if y.Cmp(x) > 0 {
  325. stack.Push(ethutil.BigTrue)
  326. } else {
  327. stack.Push(ethutil.BigFalse)
  328. }
  329. case EQ:
  330. require(2)
  331. x, y := stack.Popn()
  332. self.Printf(" %v == %v", y, x)
  333. // x == y
  334. if x.Cmp(y) == 0 {
  335. stack.Push(ethutil.BigTrue)
  336. } else {
  337. stack.Push(ethutil.BigFalse)
  338. }
  339. case NOT:
  340. require(1)
  341. x := stack.Pop()
  342. if x.Cmp(ethutil.BigFalse) > 0 {
  343. stack.Push(ethutil.BigFalse)
  344. } else {
  345. stack.Push(ethutil.BigTrue)
  346. }
  347. // 0x10 range
  348. case AND:
  349. require(2)
  350. x, y := stack.Popn()
  351. self.Printf(" %v & %v", y, x)
  352. stack.Push(base.And(y, x))
  353. case OR:
  354. require(2)
  355. x, y := stack.Popn()
  356. self.Printf(" %v | %v", y, x)
  357. stack.Push(base.Or(y, x))
  358. case XOR:
  359. require(2)
  360. x, y := stack.Popn()
  361. self.Printf(" %v ^ %v", y, x)
  362. stack.Push(base.Xor(y, x))
  363. case BYTE:
  364. require(2)
  365. val, th := stack.Popn()
  366. if th.Cmp(big.NewInt(32)) < 0 && th.Cmp(big.NewInt(int64(len(val.Bytes())))) < 0 {
  367. byt := big.NewInt(int64(ethutil.LeftPadBytes(val.Bytes(), 32)[th.Int64()]))
  368. stack.Push(byt)
  369. self.Printf(" => 0x%x", byt.Bytes())
  370. } else {
  371. stack.Push(ethutil.BigFalse)
  372. }
  373. case ADDMOD:
  374. require(3)
  375. x := stack.Pop()
  376. y := stack.Pop()
  377. z := stack.Pop()
  378. base.Add(x, y)
  379. base.Mod(base, z)
  380. ensure256(base)
  381. self.Printf(" = %v", base)
  382. stack.Push(base)
  383. case MULMOD:
  384. require(3)
  385. x := stack.Pop()
  386. y := stack.Pop()
  387. z := stack.Pop()
  388. base.Mul(x, y)
  389. base.Mod(base, z)
  390. ensure256(base)
  391. self.Printf(" = %v", base)
  392. stack.Push(base)
  393. // 0x20 range
  394. case SHA3:
  395. require(2)
  396. size, offset := stack.Popn()
  397. data := ethcrypto.Sha3Bin(mem.Get(offset.Int64(), size.Int64()))
  398. stack.Push(ethutil.BigD(data))
  399. self.Printf(" => %x", data)
  400. // 0x30 range
  401. case ADDRESS:
  402. stack.Push(ethutil.BigD(closure.Address()))
  403. self.Printf(" => %x", closure.Address())
  404. case BALANCE:
  405. require(1)
  406. addr := stack.Pop().Bytes()
  407. balance := self.env.State().GetBalance(addr)
  408. stack.Push(balance)
  409. self.Printf(" => %v (%x)", balance, addr)
  410. case ORIGIN:
  411. origin := self.env.Origin()
  412. stack.Push(ethutil.BigD(origin))
  413. self.Printf(" => %x", origin)
  414. case CALLER:
  415. caller := closure.caller.Address()
  416. stack.Push(ethutil.BigD(caller))
  417. self.Printf(" => %x", caller)
  418. case CALLVALUE:
  419. value := self.env.Value()
  420. stack.Push(value)
  421. self.Printf(" => %v", value)
  422. case CALLDATALOAD:
  423. require(1)
  424. var (
  425. offset = stack.Pop()
  426. data = make([]byte, 32)
  427. lenData = big.NewInt(int64(len(closure.Args)))
  428. )
  429. if lenData.Cmp(offset) >= 0 {
  430. length := new(big.Int).Add(offset, ethutil.Big32)
  431. length = ethutil.BigMin(length, lenData)
  432. copy(data, closure.Args[offset.Int64():length.Int64()])
  433. }
  434. self.Printf(" => 0x%x", data)
  435. stack.Push(ethutil.BigD(data))
  436. case CALLDATASIZE:
  437. l := int64(len(closure.Args))
  438. stack.Push(big.NewInt(l))
  439. self.Printf(" => %d", l)
  440. case CALLDATACOPY:
  441. var (
  442. size = int64(len(closure.Args))
  443. mOff = stack.Pop().Int64()
  444. cOff = stack.Pop().Int64()
  445. l = stack.Pop().Int64()
  446. )
  447. if cOff > size {
  448. cOff = 0
  449. l = 0
  450. } else if cOff+l > size {
  451. l = 0
  452. }
  453. code := closure.Args[cOff : cOff+l]
  454. mem.Set(mOff, l, code)
  455. case CODESIZE, EXTCODESIZE:
  456. var code []byte
  457. if op == EXTCODECOPY {
  458. addr := stack.Pop().Bytes()
  459. code = self.env.State().GetCode(addr)
  460. } else {
  461. code = closure.Code
  462. }
  463. l := big.NewInt(int64(len(code)))
  464. stack.Push(l)
  465. self.Printf(" => %d", l)
  466. case CODECOPY, EXTCODECOPY:
  467. var code []byte
  468. if op == EXTCODECOPY {
  469. addr := stack.Pop().Bytes()
  470. code = self.env.State().GetCode(addr)
  471. } else {
  472. code = closure.Code
  473. }
  474. var (
  475. size = int64(len(code))
  476. mOff = stack.Pop().Int64()
  477. cOff = stack.Pop().Int64()
  478. l = stack.Pop().Int64()
  479. )
  480. if cOff > size {
  481. cOff = 0
  482. l = 0
  483. } else if cOff+l > size {
  484. l = 0
  485. }
  486. codeCopy := code[cOff : cOff+l]
  487. mem.Set(mOff, l, codeCopy)
  488. case GASPRICE:
  489. stack.Push(closure.Price)
  490. self.Printf(" => %v", closure.Price)
  491. // 0x40 range
  492. case PREVHASH:
  493. prevHash := self.env.PrevHash()
  494. stack.Push(ethutil.BigD(prevHash))
  495. self.Printf(" => 0x%x", prevHash)
  496. case COINBASE:
  497. coinbase := self.env.Coinbase()
  498. stack.Push(ethutil.BigD(coinbase))
  499. self.Printf(" => 0x%x", coinbase)
  500. case TIMESTAMP:
  501. time := self.env.Time()
  502. stack.Push(big.NewInt(time))
  503. self.Printf(" => 0x%x", time)
  504. case NUMBER:
  505. number := self.env.BlockNumber()
  506. stack.Push(number)
  507. self.Printf(" => 0x%x", number.Bytes())
  508. case DIFFICULTY:
  509. difficulty := self.env.Difficulty()
  510. stack.Push(difficulty)
  511. self.Printf(" => 0x%x", difficulty.Bytes())
  512. case GASLIMIT:
  513. // TODO
  514. stack.Push(big.NewInt(0))
  515. // 0x50 range
  516. case PUSH1, PUSH2, PUSH3, PUSH4, PUSH5, PUSH6, PUSH7, PUSH8, PUSH9, PUSH10, PUSH11, PUSH12, PUSH13, PUSH14, PUSH15, PUSH16, PUSH17, PUSH18, PUSH19, PUSH20, PUSH21, PUSH22, PUSH23, PUSH24, PUSH25, PUSH26, PUSH27, PUSH28, PUSH29, PUSH30, PUSH31, PUSH32:
  517. a := big.NewInt(int64(op) - int64(PUSH1) + 1)
  518. pc.Add(pc, ethutil.Big1)
  519. data := closure.Gets(pc, a)
  520. val := ethutil.BigD(data.Bytes())
  521. // Push value to stack
  522. stack.Push(val)
  523. pc.Add(pc, a.Sub(a, big.NewInt(1)))
  524. step += int(op) - int(PUSH1) + 1
  525. self.Printf(" => 0x%x", data.Bytes())
  526. case POP:
  527. require(1)
  528. stack.Pop()
  529. case DUP1, DUP2, DUP3, DUP4, DUP5, DUP6, DUP7, DUP8, DUP9, DUP10, DUP11, DUP12, DUP13, DUP14, DUP15, DUP16:
  530. n := int(op - DUP1)
  531. stack.Dupn(n)
  532. self.Printf(" => [%d] 0x%x", n, stack.Peek().Bytes())
  533. case SWAP1, SWAP2, SWAP3, SWAP4, SWAP5, SWAP6, SWAP7, SWAP8, SWAP9, SWAP10, SWAP11, SWAP12, SWAP13, SWAP14, SWAP15, SWAP16:
  534. n := int(op - SWAP1)
  535. x, y := stack.Swapn(n)
  536. self.Printf(" => [%d] %x [0] %x", n, x.Bytes(), y.Bytes())
  537. case MLOAD:
  538. require(1)
  539. offset := stack.Pop()
  540. val := ethutil.BigD(mem.Get(offset.Int64(), 32))
  541. stack.Push(val)
  542. self.Printf(" => 0x%x", val.Bytes())
  543. case MSTORE: // Store the value at stack top-1 in to memory at location stack top
  544. require(2)
  545. // Pop value of the stack
  546. val, mStart := stack.Popn()
  547. mem.Set(mStart.Int64(), 32, ethutil.BigToBytes(val, 256))
  548. self.Printf(" => 0x%x", val)
  549. case MSTORE8:
  550. require(2)
  551. val, mStart := stack.Popn()
  552. //base.And(val, new(big.Int).SetInt64(0xff))
  553. //mem.Set(mStart.Int64(), 32, ethutil.BigToBytes(base, 256))
  554. mem.store[mStart.Int64()] = byte(val.Int64() & 0xff)
  555. self.Printf(" => 0x%x", val)
  556. case SLOAD:
  557. require(1)
  558. loc := stack.Pop()
  559. val := closure.GetStorage(loc)
  560. stack.Push(val.BigInt())
  561. self.Printf(" {0x%x : 0x%x}", loc.Bytes(), val.Bytes())
  562. case SSTORE:
  563. require(2)
  564. val, loc := stack.Popn()
  565. closure.SetStorage(loc, ethutil.NewValue(val))
  566. closure.message.AddStorageChange(loc.Bytes())
  567. self.Printf(" {0x%x : 0x%x}", loc.Bytes(), val.Bytes())
  568. case JUMP:
  569. require(1)
  570. pc = stack.Pop()
  571. // Reduce pc by one because of the increment that's at the end of this for loop
  572. self.Printf(" ~> %v", pc).Endl()
  573. continue
  574. case JUMPI:
  575. require(2)
  576. cond, pos := stack.Popn()
  577. if cond.Cmp(ethutil.BigTrue) >= 0 {
  578. pc = pos
  579. self.Printf(" ~> %v (t)", pc).Endl()
  580. continue
  581. } else {
  582. self.Printf(" (f)")
  583. }
  584. case PC:
  585. stack.Push(pc)
  586. case MSIZE:
  587. stack.Push(big.NewInt(int64(mem.Len())))
  588. case GAS:
  589. stack.Push(closure.Gas)
  590. // 0x60 range
  591. case CREATE:
  592. require(3)
  593. var (
  594. err error
  595. value = stack.Pop()
  596. size, offset = stack.Popn()
  597. input = mem.Get(offset.Int64(), size.Int64())
  598. gas = new(big.Int).Set(closure.Gas)
  599. // Snapshot the current stack so we are able to
  600. // revert back to it later.
  601. snapshot = self.env.State().Copy()
  602. )
  603. // Generate a new address
  604. addr := ethcrypto.CreateAddress(closure.Address(), closure.object.Nonce)
  605. for i := uint64(0); self.env.State().GetStateObject(addr) != nil; i++ {
  606. ethcrypto.CreateAddress(closure.Address(), closure.object.Nonce+i)
  607. }
  608. closure.object.Nonce++
  609. self.Printf(" (*) %x", addr).Endl()
  610. closure.UseGas(closure.Gas)
  611. msg := NewMessage(self, addr, input, gas, closure.Price, value)
  612. ret, err := msg.Exec(addr, closure)
  613. if err != nil {
  614. stack.Push(ethutil.BigFalse)
  615. // Revert the state as it was before.
  616. self.env.State().Set(snapshot)
  617. self.Printf("CREATE err %v", err)
  618. } else {
  619. msg.object.Code = ret
  620. stack.Push(ethutil.BigD(addr))
  621. }
  622. self.Endl()
  623. // Debug hook
  624. if self.Dbg != nil {
  625. self.Dbg.SetCode(closure.Code)
  626. }
  627. case CALL, CALLSTATELESS:
  628. require(7)
  629. self.Endl()
  630. gas := stack.Pop()
  631. // Pop gas and value of the stack.
  632. value, addr := stack.Popn()
  633. // Pop input size and offset
  634. inSize, inOffset := stack.Popn()
  635. // Pop return size and offset
  636. retSize, retOffset := stack.Popn()
  637. // Get the arguments from the memory
  638. args := mem.Get(inOffset.Int64(), inSize.Int64())
  639. snapshot := self.env.State().Copy()
  640. var executeAddr []byte
  641. if op == CALLSTATELESS {
  642. executeAddr = closure.Address()
  643. } else {
  644. executeAddr = addr.Bytes()
  645. }
  646. msg := NewMessage(self, executeAddr, args, gas, closure.Price, value)
  647. ret, err := msg.Exec(addr.Bytes(), closure)
  648. if err != nil {
  649. stack.Push(ethutil.BigFalse)
  650. self.env.State().Set(snapshot)
  651. } else {
  652. stack.Push(ethutil.BigTrue)
  653. mem.Set(retOffset.Int64(), retSize.Int64(), ret)
  654. }
  655. // Debug hook
  656. if self.Dbg != nil {
  657. self.Dbg.SetCode(closure.Code)
  658. }
  659. case POST:
  660. require(6)
  661. self.Endl()
  662. gas := stack.Pop()
  663. // Pop gas and value of the stack.
  664. value, addr := stack.Popn()
  665. // Pop input size and offset
  666. inSize, inOffset := stack.Popn()
  667. // Get the arguments from the memory
  668. args := mem.Get(inOffset.Int64(), inSize.Int64())
  669. msg := NewMessage(self, addr.Bytes(), args, gas, closure.Price, value)
  670. msg.Postpone()
  671. case RETURN:
  672. require(2)
  673. size, offset := stack.Popn()
  674. ret := mem.Get(offset.Int64(), size.Int64())
  675. self.Printf(" => (%d) 0x%x", len(ret), ret).Endl()
  676. return closure.Return(ret), nil
  677. case SUICIDE:
  678. require(1)
  679. receiver := self.env.State().GetOrNewStateObject(stack.Pop().Bytes())
  680. receiver.AddAmount(closure.object.Balance)
  681. closure.object.MarkForDeletion()
  682. fallthrough
  683. case STOP: // Stop the closure
  684. self.Endl()
  685. return closure.Return(nil), nil
  686. default:
  687. vmlogger.Debugf("(pc) %-3v Invalid opcode %x\n", pc, op)
  688. return closure.Return(nil), fmt.Errorf("Invalid opcode %x", op)
  689. }
  690. pc.Add(pc, ethutil.Big1)
  691. self.Endl()
  692. if self.Dbg != nil {
  693. for _, instrNo := range self.Dbg.BreakPoints() {
  694. if pc.Cmp(big.NewInt(instrNo)) == 0 {
  695. self.Stepping = true
  696. if !self.Dbg.BreakHook(prevStep, op, mem, stack, closure.Object()) {
  697. return nil, nil
  698. }
  699. } else if self.Stepping {
  700. if !self.Dbg.StepHook(prevStep, op, mem, stack, closure.Object()) {
  701. return nil, nil
  702. }
  703. }
  704. }
  705. }
  706. }
  707. }
  708. func (self *Vm) Queue() *list.List {
  709. return self.queue
  710. }
  711. func (self *Vm) Printf(format string, v ...interface{}) *Vm {
  712. if self.Verbose && self.logTy == LogTyPretty {
  713. self.logStr += fmt.Sprintf(format, v...)
  714. }
  715. return self
  716. }
  717. func (self *Vm) Endl() *Vm {
  718. if self.Verbose && self.logTy == LogTyPretty {
  719. vmlogger.Debugln(self.logStr)
  720. self.logStr = ""
  721. }
  722. return self
  723. }
  724. func ensure256(x *big.Int) {
  725. //max, _ := big.NewInt(0).SetString("115792089237316195423570985008687907853269984665640564039457584007913129639936", 0)
  726. //if x.Cmp(max) >= 0 {
  727. d := big.NewInt(1)
  728. d.Lsh(d, 256).Sub(d, big.NewInt(1))
  729. x.And(x, d)
  730. //}
  731. // Could have done this with an OR, but big ints are costly.
  732. if x.Cmp(new(big.Int)) < 0 {
  733. x.SetInt64(0)
  734. }
  735. }
  736. type Message struct {
  737. vm *Vm
  738. closure *Closure
  739. address, input []byte
  740. gas, price, value *big.Int
  741. object *ethstate.StateObject
  742. }
  743. func NewMessage(vm *Vm, address, input []byte, gas, gasPrice, value *big.Int) *Message {
  744. return &Message{vm: vm, address: address, input: input, gas: gas, price: gasPrice, value: value}
  745. }
  746. func (self *Message) Postpone() {
  747. self.vm.queue.PushBack(self)
  748. }
  749. func (self *Message) Addr() []byte {
  750. return self.address
  751. }
  752. func (self *Message) Exec(codeAddr []byte, caller ClosureRef) (ret []byte, err error) {
  753. queue := self.vm.queue
  754. self.vm.queue = list.New()
  755. defer func() {
  756. if err == nil {
  757. queue.PushBackList(self.vm.queue)
  758. }
  759. self.vm.queue = queue
  760. }()
  761. msg := self.vm.env.State().Manifest().AddMessage(&ethstate.Message{
  762. To: self.address, From: caller.Address(),
  763. Input: self.input,
  764. Origin: self.vm.env.Origin(),
  765. Block: self.vm.env.BlockHash(), Timestamp: self.vm.env.Time(), Coinbase: self.vm.env.Coinbase(), Number: self.vm.env.BlockNumber(),
  766. Value: self.value,
  767. })
  768. object := caller.Object()
  769. if object.Balance.Cmp(self.value) < 0 {
  770. caller.ReturnGas(self.gas, self.price)
  771. err = fmt.Errorf("Insufficient funds to transfer value. Req %v, has %v", self.value, object.Balance)
  772. } else {
  773. stateObject := self.vm.env.State().GetOrNewStateObject(self.address)
  774. self.object = stateObject
  775. caller.Object().SubAmount(self.value)
  776. stateObject.AddAmount(self.value)
  777. // Retrieve the executing code
  778. code := self.vm.env.State().GetCode(codeAddr)
  779. // Create a new callable closure
  780. c := NewClosure(msg, caller, object, code, self.gas, self.price)
  781. // Executer the closure and get the return value (if any)
  782. ret, _, err = c.Call(self.vm, self.input)
  783. msg.Output = ret
  784. return ret, err
  785. }
  786. return
  787. }