instructions_test.go 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. package vm
  2. import (
  3. "math/big"
  4. "testing"
  5. "github.com/ethereum/go-ethereum/common"
  6. "github.com/ethereum/go-ethereum/params"
  7. )
  8. func TestByteOp(t *testing.T) {
  9. var (
  10. env = NewEVM(Context{}, nil, params.TestChainConfig, Config{EnableJit: false, ForceJit: false})
  11. stack = newstack()
  12. )
  13. tests := []struct {
  14. v string
  15. th uint64
  16. expected *big.Int
  17. }{
  18. {"ABCDEF0908070605040302010000000000000000000000000000000000000000", 0, big.NewInt(0xAB)},
  19. {"ABCDEF0908070605040302010000000000000000000000000000000000000000", 1, big.NewInt(0xCD)},
  20. {"00CDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff", 0, big.NewInt(0x00)},
  21. {"00CDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff", 1, big.NewInt(0xCD)},
  22. {"0000000000000000000000000000000000000000000000000000000000102030", 31, big.NewInt(0x30)},
  23. {"0000000000000000000000000000000000000000000000000000000000102030", 30, big.NewInt(0x20)},
  24. {"ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff", 32, big.NewInt(0x0)},
  25. {"ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff", 0xFFFFFFFFFFFFFFFF, big.NewInt(0x0)},
  26. }
  27. pc := uint64(0)
  28. for _, test := range tests {
  29. val := new(big.Int).SetBytes(common.Hex2Bytes(test.v))
  30. th := new(big.Int).SetUint64(test.th)
  31. stack.push(val)
  32. stack.push(th)
  33. opByte(&pc, env, nil, nil, stack)
  34. actual := stack.pop()
  35. if actual.Cmp(test.expected) != 0 {
  36. t.Fatalf("Expected [%v] %v:th byte to be %v, was %v.", test.v, test.th, test.expected, actual)
  37. }
  38. }
  39. }
  40. func opBenchmark(bench *testing.B, op func(pc *uint64, evm *EVM, contract *Contract, memory *Memory, stack *Stack) ([]byte, error), args ...string) {
  41. var (
  42. env = NewEVM(Context{}, nil, params.TestChainConfig, Config{EnableJit: false, ForceJit: false})
  43. stack = newstack()
  44. )
  45. // convert args
  46. byteArgs := make([][]byte, len(args))
  47. for i, arg := range args {
  48. byteArgs[i] = common.Hex2Bytes(arg)
  49. }
  50. pc := uint64(0)
  51. bench.ResetTimer()
  52. for i := 0; i < bench.N; i++ {
  53. for _, arg := range byteArgs {
  54. a := new(big.Int).SetBytes(arg)
  55. stack.push(a)
  56. }
  57. op(&pc, env, nil, nil, stack)
  58. stack.pop()
  59. }
  60. }
  61. func BenchmarkOpAdd64(b *testing.B) {
  62. x := "ffffffff"
  63. y := "fd37f3e2bba2c4f"
  64. opBenchmark(b, opAdd, x, y)
  65. }
  66. func BenchmarkOpAdd128(b *testing.B) {
  67. x := "ffffffffffffffff"
  68. y := "f5470b43c6549b016288e9a65629687"
  69. opBenchmark(b, opAdd, x, y)
  70. }
  71. func BenchmarkOpAdd256(b *testing.B) {
  72. x := "0802431afcbce1fc194c9eaa417b2fb67dc75a95db0bc7ec6b1c8af11df6a1da9"
  73. y := "a1f5aac137876480252e5dcac62c354ec0d42b76b0642b6181ed099849ea1d57"
  74. opBenchmark(b, opAdd, x, y)
  75. }
  76. func BenchmarkOpSub64(b *testing.B) {
  77. x := "51022b6317003a9d"
  78. y := "a20456c62e00753a"
  79. opBenchmark(b, opSub, x, y)
  80. }
  81. func BenchmarkOpSub128(b *testing.B) {
  82. x := "4dde30faaacdc14d00327aac314e915d"
  83. y := "9bbc61f5559b829a0064f558629d22ba"
  84. opBenchmark(b, opSub, x, y)
  85. }
  86. func BenchmarkOpSub256(b *testing.B) {
  87. x := "4bfcd8bb2ac462735b48a17580690283980aa2d679f091c64364594df113ea37"
  88. y := "97f9b1765588c4e6b69142eb00d20507301545acf3e1238c86c8b29be227d46e"
  89. opBenchmark(b, opSub, x, y)
  90. }
  91. func BenchmarkOpMul(b *testing.B) {
  92. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  93. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  94. opBenchmark(b, opMul, x, y)
  95. }
  96. func BenchmarkOpDiv256(b *testing.B) {
  97. x := "ff3f9014f20db29ae04af2c2d265de17"
  98. y := "fe7fb0d1f59dfe9492ffbf73683fd1e870eec79504c60144cc7f5fc2bad1e611"
  99. opBenchmark(b, opDiv, x, y)
  100. }
  101. func BenchmarkOpDiv128(b *testing.B) {
  102. x := "fdedc7f10142ff97"
  103. y := "fbdfda0e2ce356173d1993d5f70a2b11"
  104. opBenchmark(b, opDiv, x, y)
  105. }
  106. func BenchmarkOpDiv64(b *testing.B) {
  107. x := "fcb34eb3"
  108. y := "f97180878e839129"
  109. opBenchmark(b, opDiv, x, y)
  110. }
  111. func BenchmarkOpSdiv(b *testing.B) {
  112. x := "ff3f9014f20db29ae04af2c2d265de17"
  113. y := "fe7fb0d1f59dfe9492ffbf73683fd1e870eec79504c60144cc7f5fc2bad1e611"
  114. opBenchmark(b, opSdiv, x, y)
  115. }
  116. func BenchmarkOpMod(b *testing.B) {
  117. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  118. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  119. opBenchmark(b, opMod, x, y)
  120. }
  121. func BenchmarkOpSmod(b *testing.B) {
  122. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  123. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  124. opBenchmark(b, opSmod, x, y)
  125. }
  126. func BenchmarkOpExp(b *testing.B) {
  127. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  128. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  129. opBenchmark(b, opExp, x, y)
  130. }
  131. func BenchmarkOpSignExtend(b *testing.B) {
  132. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  133. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  134. opBenchmark(b, opSignExtend, x, y)
  135. }
  136. func BenchmarkOpLt(b *testing.B) {
  137. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  138. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  139. opBenchmark(b, opLt, x, y)
  140. }
  141. func BenchmarkOpGt(b *testing.B) {
  142. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  143. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  144. opBenchmark(b, opGt, x, y)
  145. }
  146. func BenchmarkOpSlt(b *testing.B) {
  147. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  148. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  149. opBenchmark(b, opSlt, x, y)
  150. }
  151. func BenchmarkOpSgt(b *testing.B) {
  152. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  153. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  154. opBenchmark(b, opSgt, x, y)
  155. }
  156. func BenchmarkOpEq(b *testing.B) {
  157. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  158. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  159. opBenchmark(b, opEq, x, y)
  160. }
  161. func BenchmarkOpAnd(b *testing.B) {
  162. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  163. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  164. opBenchmark(b, opAnd, x, y)
  165. }
  166. func BenchmarkOpOr(b *testing.B) {
  167. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  168. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  169. opBenchmark(b, opOr, x, y)
  170. }
  171. func BenchmarkOpXor(b *testing.B) {
  172. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  173. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  174. opBenchmark(b, opXor, x, y)
  175. }
  176. func BenchmarkOpByte(b *testing.B) {
  177. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  178. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  179. opBenchmark(b, opByte, x, y)
  180. }
  181. func BenchmarkOpAddmod(b *testing.B) {
  182. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  183. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  184. z := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  185. opBenchmark(b, opAddmod, x, y, z)
  186. }
  187. func BenchmarkOpMulmod(b *testing.B) {
  188. x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  189. y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  190. z := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
  191. opBenchmark(b, opMulmod, x, y, z)
  192. }