therubyracer 0.8.1.pre2 → 0.8.1

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of therubyracer might be problematic. Click here for more details.

Files changed (877) hide show
  1. data/Changelog.md +2 -1
  2. data/README.md +6 -3
  3. data/ext/v8/upstream/3.1.8/.gitignore +31 -0
  4. data/ext/v8/upstream/3.1.8/AUTHORS +40 -0
  5. data/ext/v8/upstream/3.1.8/ChangeLog +2566 -0
  6. data/ext/v8/upstream/3.1.8/LICENSE +52 -0
  7. data/ext/v8/upstream/3.1.8/LICENSE.strongtalk +29 -0
  8. data/ext/v8/upstream/3.1.8/LICENSE.v8 +26 -0
  9. data/ext/v8/upstream/3.1.8/LICENSE.valgrind +45 -0
  10. data/ext/v8/upstream/3.1.8/SConstruct +1192 -0
  11. data/ext/v8/upstream/3.1.8/build/README.txt +25 -0
  12. data/ext/v8/upstream/3.1.8/build/all.gyp +18 -0
  13. data/ext/v8/upstream/3.1.8/build/armu.gypi +32 -0
  14. data/ext/v8/upstream/3.1.8/build/common.gypi +82 -0
  15. data/ext/v8/upstream/3.1.8/build/gyp_v8 +145 -0
  16. data/ext/v8/upstream/3.1.8/include/v8-debug.h +384 -0
  17. data/ext/v8/upstream/3.1.8/include/v8-preparser.h +116 -0
  18. data/ext/v8/upstream/3.1.8/include/v8-profiler.h +426 -0
  19. data/ext/v8/upstream/3.1.8/include/v8-testing.h +99 -0
  20. data/ext/v8/upstream/3.1.8/include/v8.h +3846 -0
  21. data/ext/v8/upstream/3.1.8/include/v8stdint.h +53 -0
  22. data/ext/v8/upstream/3.1.8/preparser/preparser-process.cc +206 -0
  23. data/ext/v8/upstream/3.1.8/src/SConscript +356 -0
  24. data/ext/v8/upstream/3.1.8/src/accessors.cc +907 -0
  25. data/ext/v8/upstream/3.1.8/src/accessors.h +121 -0
  26. data/ext/v8/upstream/3.1.8/src/allocation.cc +204 -0
  27. data/ext/v8/upstream/3.1.8/src/allocation.h +176 -0
  28. data/ext/v8/upstream/3.1.8/src/api.cc +5191 -0
  29. data/ext/v8/upstream/3.1.8/src/api.h +508 -0
  30. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/apinatives.js +0 -0
  31. data/ext/v8/upstream/3.1.8/src/apiutils.h +80 -0
  32. data/ext/v8/upstream/3.1.8/src/arguments.h +105 -0
  33. data/ext/v8/upstream/3.1.8/src/arm/assembler-arm-inl.h +352 -0
  34. data/ext/v8/upstream/3.1.8/src/arm/assembler-arm.cc +2756 -0
  35. data/ext/v8/upstream/3.1.8/src/arm/assembler-arm.h +1294 -0
  36. data/ext/v8/upstream/3.1.8/src/arm/builtins-arm.cc +1628 -0
  37. data/ext/v8/upstream/3.1.8/src/arm/code-stubs-arm.cc +6783 -0
  38. data/ext/v8/upstream/3.1.8/src/arm/code-stubs-arm.h +657 -0
  39. data/ext/v8/upstream/3.1.8/src/arm/codegen-arm-inl.h +48 -0
  40. data/ext/v8/upstream/3.1.8/src/arm/codegen-arm.cc +7403 -0
  41. data/ext/v8/upstream/3.1.8/src/arm/codegen-arm.h +595 -0
  42. data/ext/v8/upstream/3.1.8/src/arm/constants-arm.cc +152 -0
  43. data/ext/v8/upstream/3.1.8/src/arm/constants-arm.h +769 -0
  44. data/ext/v8/upstream/3.1.8/src/arm/cpu-arm.cc +147 -0
  45. data/ext/v8/upstream/3.1.8/src/arm/debug-arm.cc +315 -0
  46. data/ext/v8/upstream/3.1.8/src/arm/deoptimizer-arm.cc +700 -0
  47. data/ext/v8/upstream/3.1.8/src/arm/disasm-arm.cc +1439 -0
  48. data/ext/v8/upstream/3.1.8/src/arm/frames-arm.cc +45 -0
  49. data/ext/v8/upstream/3.1.8/src/arm/frames-arm.h +168 -0
  50. data/ext/v8/upstream/3.1.8/src/arm/full-codegen-arm.cc +4230 -0
  51. data/ext/v8/upstream/3.1.8/src/arm/ic-arm.cc +1799 -0
  52. data/ext/v8/upstream/3.1.8/src/arm/jump-target-arm.cc +174 -0
  53. data/ext/v8/upstream/3.1.8/src/arm/lithium-arm.cc +2041 -0
  54. data/ext/v8/upstream/3.1.8/src/arm/lithium-arm.h +2046 -0
  55. data/ext/v8/upstream/3.1.8/src/arm/lithium-codegen-arm.cc +3822 -0
  56. data/ext/v8/upstream/3.1.8/src/arm/lithium-codegen-arm.h +312 -0
  57. data/ext/v8/upstream/3.1.8/src/arm/lithium-gap-resolver-arm.cc +303 -0
  58. data/ext/v8/upstream/3.1.8/src/arm/lithium-gap-resolver-arm.h +84 -0
  59. data/ext/v8/upstream/3.1.8/src/arm/macro-assembler-arm.cc +2701 -0
  60. data/ext/v8/upstream/3.1.8/src/arm/macro-assembler-arm.h +1015 -0
  61. data/ext/v8/upstream/3.1.8/src/arm/regexp-macro-assembler-arm.cc +1280 -0
  62. data/ext/v8/upstream/3.1.8/src/arm/regexp-macro-assembler-arm.h +252 -0
  63. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/arm/register-allocator-arm-inl.h +0 -0
  64. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/arm/register-allocator-arm.cc +0 -0
  65. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/arm/register-allocator-arm.h +0 -0
  66. data/ext/v8/upstream/3.1.8/src/arm/simulator-arm.cc +3165 -0
  67. data/ext/v8/upstream/3.1.8/src/arm/simulator-arm.h +402 -0
  68. data/ext/v8/upstream/3.1.8/src/arm/stub-cache-arm.cc +4077 -0
  69. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/arm/virtual-frame-arm-inl.h +0 -0
  70. data/ext/v8/upstream/3.1.8/src/arm/virtual-frame-arm.cc +843 -0
  71. data/ext/v8/upstream/3.1.8/src/arm/virtual-frame-arm.h +520 -0
  72. data/ext/v8/upstream/3.1.8/src/array.js +1231 -0
  73. data/ext/v8/upstream/3.1.8/src/assembler.cc +973 -0
  74. data/ext/v8/upstream/3.1.8/src/assembler.h +787 -0
  75. data/ext/v8/upstream/3.1.8/src/ast-inl.h +107 -0
  76. data/ext/v8/upstream/3.1.8/src/ast.cc +1067 -0
  77. data/ext/v8/upstream/3.1.8/src/ast.h +2177 -0
  78. data/ext/v8/upstream/3.1.8/src/atomicops.h +165 -0
  79. data/ext/v8/upstream/3.1.8/src/atomicops_internals_arm_gcc.h +145 -0
  80. data/ext/v8/upstream/3.1.8/src/atomicops_internals_x86_gcc.cc +126 -0
  81. data/ext/v8/upstream/3.1.8/src/atomicops_internals_x86_gcc.h +287 -0
  82. data/ext/v8/upstream/3.1.8/src/atomicops_internals_x86_macosx.h +301 -0
  83. data/ext/v8/upstream/3.1.8/src/atomicops_internals_x86_msvc.h +203 -0
  84. data/ext/v8/upstream/3.1.8/src/bignum-dtoa.cc +655 -0
  85. data/ext/v8/upstream/3.1.8/src/bignum-dtoa.h +81 -0
  86. data/ext/v8/upstream/3.1.8/src/bignum.cc +768 -0
  87. data/ext/v8/upstream/3.1.8/src/bignum.h +140 -0
  88. data/ext/v8/upstream/3.1.8/src/bootstrapper.cc +1888 -0
  89. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/bootstrapper.h +0 -0
  90. data/ext/v8/upstream/3.1.8/src/builtins.cc +1586 -0
  91. data/ext/v8/upstream/3.1.8/src/builtins.h +339 -0
  92. data/ext/v8/upstream/3.1.8/src/bytecodes-irregexp.h +105 -0
  93. data/ext/v8/upstream/3.1.8/src/cached-powers.cc +177 -0
  94. data/ext/v8/upstream/3.1.8/src/cached-powers.h +65 -0
  95. data/ext/v8/upstream/3.1.8/src/char-predicates-inl.h +94 -0
  96. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/char-predicates.h +0 -0
  97. data/ext/v8/upstream/3.1.8/src/checks.cc +110 -0
  98. data/ext/v8/upstream/3.1.8/src/checks.h +292 -0
  99. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/circular-queue-inl.h +0 -0
  100. data/ext/v8/upstream/3.1.8/src/circular-queue.cc +122 -0
  101. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/circular-queue.h +0 -0
  102. data/ext/v8/upstream/3.1.8/src/code-stubs.cc +230 -0
  103. data/ext/v8/upstream/3.1.8/src/code-stubs.h +950 -0
  104. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/code.h +0 -0
  105. data/ext/v8/upstream/3.1.8/src/codegen-inl.h +64 -0
  106. data/ext/v8/upstream/3.1.8/src/codegen.cc +495 -0
  107. data/ext/v8/upstream/3.1.8/src/codegen.h +245 -0
  108. data/ext/v8/upstream/3.1.8/src/compilation-cache.cc +654 -0
  109. data/ext/v8/upstream/3.1.8/src/compilation-cache.h +112 -0
  110. data/ext/v8/upstream/3.1.8/src/compiler.cc +806 -0
  111. data/ext/v8/upstream/3.1.8/src/compiler.h +290 -0
  112. data/ext/v8/upstream/3.1.8/src/contexts.cc +320 -0
  113. data/ext/v8/upstream/3.1.8/src/contexts.h +376 -0
  114. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/conversions-inl.h +0 -0
  115. data/ext/v8/upstream/3.1.8/src/conversions.cc +1069 -0
  116. data/ext/v8/upstream/3.1.8/src/conversions.h +122 -0
  117. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/counters.cc +0 -0
  118. data/ext/v8/upstream/3.1.8/src/counters.h +242 -0
  119. data/ext/v8/upstream/3.1.8/src/cpu-profiler-inl.h +100 -0
  120. data/ext/v8/upstream/3.1.8/src/cpu-profiler.cc +554 -0
  121. data/ext/v8/upstream/3.1.8/src/cpu-profiler.h +291 -0
  122. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/cpu.h +0 -0
  123. data/ext/v8/upstream/3.1.8/src/d8-debug.cc +367 -0
  124. data/ext/v8/upstream/3.1.8/src/d8-debug.h +157 -0
  125. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/d8-posix.cc +0 -0
  126. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/d8-readline.cc +0 -0
  127. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/d8-windows.cc +0 -0
  128. data/ext/v8/upstream/3.1.8/src/d8.cc +792 -0
  129. data/ext/v8/upstream/3.1.8/src/d8.gyp +85 -0
  130. data/ext/v8/upstream/3.1.8/src/d8.h +231 -0
  131. data/ext/v8/upstream/3.1.8/src/d8.js +2798 -0
  132. data/ext/v8/upstream/3.1.8/src/data-flow.cc +545 -0
  133. data/ext/v8/upstream/3.1.8/src/data-flow.h +379 -0
  134. data/ext/v8/upstream/3.1.8/src/date.js +1103 -0
  135. data/ext/v8/upstream/3.1.8/src/dateparser-inl.h +125 -0
  136. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/dateparser.cc +0 -0
  137. data/ext/v8/upstream/3.1.8/src/dateparser.h +263 -0
  138. data/ext/v8/upstream/3.1.8/src/debug-agent.cc +446 -0
  139. data/ext/v8/upstream/3.1.8/src/debug-agent.h +131 -0
  140. data/ext/v8/upstream/3.1.8/src/debug-debugger.js +2569 -0
  141. data/ext/v8/upstream/3.1.8/src/debug.cc +3085 -0
  142. data/ext/v8/upstream/3.1.8/src/debug.h +1025 -0
  143. data/ext/v8/upstream/3.1.8/src/deoptimizer.cc +1185 -0
  144. data/ext/v8/upstream/3.1.8/src/deoptimizer.h +529 -0
  145. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/disasm.h +0 -0
  146. data/ext/v8/upstream/3.1.8/src/disassembler.cc +338 -0
  147. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/disassembler.h +0 -0
  148. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/diy-fp.cc +0 -0
  149. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/diy-fp.h +0 -0
  150. data/ext/v8/upstream/3.1.8/src/double.h +238 -0
  151. data/ext/v8/upstream/3.1.8/src/dtoa.cc +103 -0
  152. data/ext/v8/upstream/3.1.8/src/dtoa.h +85 -0
  153. data/ext/v8/upstream/3.1.8/src/execution.cc +735 -0
  154. data/ext/v8/upstream/3.1.8/src/execution.h +322 -0
  155. data/ext/v8/upstream/3.1.8/src/extensions/experimental/experimental.gyp +53 -0
  156. data/ext/v8/upstream/3.1.8/src/extensions/experimental/i18n-extension.cc +264 -0
  157. data/ext/v8/upstream/3.1.8/src/extensions/experimental/i18n-extension.h +64 -0
  158. data/ext/v8/upstream/3.1.8/src/extensions/externalize-string-extension.cc +141 -0
  159. data/ext/v8/upstream/3.1.8/src/extensions/externalize-string-extension.h +50 -0
  160. data/ext/v8/upstream/3.1.8/src/extensions/gc-extension.cc +58 -0
  161. data/ext/v8/upstream/3.1.8/src/extensions/gc-extension.h +49 -0
  162. data/ext/v8/upstream/3.1.8/src/factory.cc +1087 -0
  163. data/ext/v8/upstream/3.1.8/src/factory.h +432 -0
  164. data/ext/v8/upstream/3.1.8/src/fast-dtoa.cc +736 -0
  165. data/ext/v8/upstream/3.1.8/src/fast-dtoa.h +83 -0
  166. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/fixed-dtoa.cc +0 -0
  167. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/fixed-dtoa.h +0 -0
  168. data/ext/v8/upstream/3.1.8/src/flag-definitions.h +552 -0
  169. data/ext/v8/upstream/3.1.8/src/flags.cc +551 -0
  170. data/ext/v8/upstream/3.1.8/src/flags.h +79 -0
  171. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/frame-element.cc +0 -0
  172. data/ext/v8/upstream/3.1.8/src/frame-element.h +277 -0
  173. data/ext/v8/upstream/3.1.8/src/frames-inl.h +210 -0
  174. data/ext/v8/upstream/3.1.8/src/frames.cc +1232 -0
  175. data/ext/v8/upstream/3.1.8/src/frames.h +826 -0
  176. data/ext/v8/upstream/3.1.8/src/full-codegen.cc +1382 -0
  177. data/ext/v8/upstream/3.1.8/src/full-codegen.h +751 -0
  178. data/ext/v8/upstream/3.1.8/src/func-name-inferrer.cc +90 -0
  179. data/ext/v8/upstream/3.1.8/src/func-name-inferrer.h +111 -0
  180. data/ext/v8/upstream/3.1.8/src/gdb-jit.cc +1547 -0
  181. data/ext/v8/upstream/3.1.8/src/gdb-jit.h +138 -0
  182. data/ext/v8/upstream/3.1.8/src/global-handles.cc +534 -0
  183. data/ext/v8/upstream/3.1.8/src/global-handles.h +181 -0
  184. data/ext/v8/upstream/3.1.8/src/globals.h +325 -0
  185. data/ext/v8/upstream/3.1.8/src/handles-inl.h +80 -0
  186. data/ext/v8/upstream/3.1.8/src/handles.cc +910 -0
  187. data/ext/v8/upstream/3.1.8/src/handles.h +424 -0
  188. data/ext/v8/upstream/3.1.8/src/hashmap.cc +230 -0
  189. data/ext/v8/upstream/3.1.8/src/hashmap.h +121 -0
  190. data/ext/v8/upstream/3.1.8/src/heap-inl.h +587 -0
  191. data/ext/v8/upstream/3.1.8/src/heap-profiler.cc +1128 -0
  192. data/ext/v8/upstream/3.1.8/src/heap-profiler.h +381 -0
  193. data/ext/v8/upstream/3.1.8/src/heap.cc +5610 -0
  194. data/ext/v8/upstream/3.1.8/src/heap.h +2218 -0
  195. data/ext/v8/upstream/3.1.8/src/hydrogen-instructions.cc +1490 -0
  196. data/ext/v8/upstream/3.1.8/src/hydrogen-instructions.h +3493 -0
  197. data/ext/v8/upstream/3.1.8/src/hydrogen.cc +6056 -0
  198. data/ext/v8/upstream/3.1.8/src/hydrogen.h +1091 -0
  199. data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32-inl.h +429 -0
  200. data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32.cc +2800 -0
  201. data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32.h +1093 -0
  202. data/ext/v8/upstream/3.1.8/src/ia32/builtins-ia32.cc +1590 -0
  203. data/ext/v8/upstream/3.1.8/src/ia32/code-stubs-ia32.cc +6624 -0
  204. data/ext/v8/upstream/3.1.8/src/ia32/code-stubs-ia32.h +536 -0
  205. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/codegen-ia32-inl.h +0 -0
  206. data/ext/v8/upstream/3.1.8/src/ia32/codegen-ia32.cc +10354 -0
  207. data/ext/v8/upstream/3.1.8/src/ia32/codegen-ia32.h +798 -0
  208. data/ext/v8/upstream/3.1.8/src/ia32/cpu-ia32.cc +87 -0
  209. data/ext/v8/upstream/3.1.8/src/ia32/debug-ia32.cc +309 -0
  210. data/ext/v8/upstream/3.1.8/src/ia32/deoptimizer-ia32.cc +664 -0
  211. data/ext/v8/upstream/3.1.8/src/ia32/disasm-ia32.cc +1597 -0
  212. data/ext/v8/upstream/3.1.8/src/ia32/frames-ia32.cc +45 -0
  213. data/ext/v8/upstream/3.1.8/src/ia32/frames-ia32.h +140 -0
  214. data/ext/v8/upstream/3.1.8/src/ia32/full-codegen-ia32.cc +4278 -0
  215. data/ext/v8/upstream/3.1.8/src/ia32/ic-ia32.cc +1786 -0
  216. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/jump-target-ia32.cc +0 -0
  217. data/ext/v8/upstream/3.1.8/src/ia32/lithium-codegen-ia32.cc +3880 -0
  218. data/ext/v8/upstream/3.1.8/src/ia32/lithium-codegen-ia32.h +309 -0
  219. data/ext/v8/upstream/3.1.8/src/ia32/lithium-gap-resolver-ia32.cc +460 -0
  220. data/ext/v8/upstream/3.1.8/src/ia32/lithium-gap-resolver-ia32.h +110 -0
  221. data/ext/v8/upstream/3.1.8/src/ia32/lithium-ia32.cc +2095 -0
  222. data/ext/v8/upstream/3.1.8/src/ia32/lithium-ia32.h +2127 -0
  223. data/ext/v8/upstream/3.1.8/src/ia32/macro-assembler-ia32.cc +2031 -0
  224. data/ext/v8/upstream/3.1.8/src/ia32/macro-assembler-ia32.h +798 -0
  225. data/ext/v8/upstream/3.1.8/src/ia32/regexp-macro-assembler-ia32.cc +1253 -0
  226. data/ext/v8/upstream/3.1.8/src/ia32/regexp-macro-assembler-ia32.h +215 -0
  227. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/register-allocator-ia32-inl.h +0 -0
  228. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/register-allocator-ia32.cc +0 -0
  229. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/register-allocator-ia32.h +0 -0
  230. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/simulator-ia32.cc +0 -0
  231. data/ext/v8/upstream/3.1.8/src/ia32/simulator-ia32.h +72 -0
  232. data/ext/v8/upstream/3.1.8/src/ia32/stub-cache-ia32.cc +3732 -0
  233. data/ext/v8/upstream/3.1.8/src/ia32/virtual-frame-ia32.cc +1360 -0
  234. data/ext/v8/upstream/3.1.8/src/ia32/virtual-frame-ia32.h +646 -0
  235. data/ext/v8/upstream/3.1.8/src/ic-inl.h +129 -0
  236. data/ext/v8/upstream/3.1.8/src/ic.cc +2333 -0
  237. data/ext/v8/upstream/3.1.8/src/ic.h +639 -0
  238. data/ext/v8/upstream/3.1.8/src/inspector.cc +63 -0
  239. data/ext/v8/upstream/3.1.8/src/inspector.h +62 -0
  240. data/ext/v8/upstream/3.1.8/src/interpreter-irregexp.cc +655 -0
  241. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/interpreter-irregexp.h +0 -0
  242. data/ext/v8/upstream/3.1.8/src/json.js +342 -0
  243. data/ext/v8/upstream/3.1.8/src/jsregexp.cc +5340 -0
  244. data/ext/v8/upstream/3.1.8/src/jsregexp.h +1484 -0
  245. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target-heavy-inl.h +0 -0
  246. data/ext/v8/upstream/3.1.8/src/jump-target-heavy.cc +430 -0
  247. data/ext/v8/upstream/3.1.8/src/jump-target-heavy.h +244 -0
  248. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target-inl.h +0 -0
  249. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target-light-inl.h +0 -0
  250. data/ext/v8/upstream/3.1.8/src/jump-target-light.cc +111 -0
  251. data/ext/v8/upstream/3.1.8/src/jump-target-light.h +193 -0
  252. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target.cc +0 -0
  253. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target.h +0 -0
  254. data/ext/v8/upstream/3.1.8/src/list-inl.h +206 -0
  255. data/ext/v8/upstream/3.1.8/src/list.h +164 -0
  256. data/ext/v8/upstream/3.1.8/src/lithium-allocator-inl.h +140 -0
  257. data/ext/v8/upstream/3.1.8/src/lithium-allocator.cc +2093 -0
  258. data/ext/v8/upstream/3.1.8/src/lithium-allocator.h +644 -0
  259. data/ext/v8/upstream/3.1.8/src/lithium.cc +168 -0
  260. data/ext/v8/upstream/3.1.8/src/lithium.h +592 -0
  261. data/ext/v8/upstream/3.1.8/src/liveedit-debugger.js +1082 -0
  262. data/ext/v8/upstream/3.1.8/src/liveedit.cc +1650 -0
  263. data/ext/v8/upstream/3.1.8/src/liveedit.h +174 -0
  264. data/ext/v8/upstream/3.1.8/src/liveobjectlist-inl.h +126 -0
  265. data/ext/v8/upstream/3.1.8/src/liveobjectlist.cc +2527 -0
  266. data/ext/v8/upstream/3.1.8/src/liveobjectlist.h +322 -0
  267. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/log-inl.h +0 -0
  268. data/ext/v8/upstream/3.1.8/src/log-utils.cc +336 -0
  269. data/ext/v8/upstream/3.1.8/src/log-utils.h +232 -0
  270. data/ext/v8/upstream/3.1.8/src/log.cc +1608 -0
  271. data/ext/v8/upstream/3.1.8/src/log.h +379 -0
  272. data/ext/v8/upstream/3.1.8/src/macro-assembler.h +120 -0
  273. data/ext/v8/upstream/3.1.8/src/macros.py +178 -0
  274. data/ext/v8/upstream/3.1.8/src/mark-compact.cc +2957 -0
  275. data/ext/v8/upstream/3.1.8/src/mark-compact.h +433 -0
  276. data/ext/v8/upstream/3.1.8/src/math.js +264 -0
  277. data/ext/v8/upstream/3.1.8/src/memory.h +82 -0
  278. data/ext/v8/upstream/3.1.8/src/messages.cc +164 -0
  279. data/ext/v8/upstream/3.1.8/src/messages.h +114 -0
  280. data/ext/v8/upstream/3.1.8/src/messages.js +1071 -0
  281. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/assembler-mips-inl.h +0 -0
  282. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/assembler-mips.cc +0 -0
  283. data/ext/v8/upstream/3.1.8/src/mips/assembler-mips.h +667 -0
  284. data/ext/v8/upstream/3.1.8/src/mips/builtins-mips.cc +205 -0
  285. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/codegen-mips-inl.h +0 -0
  286. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/codegen-mips.cc +0 -0
  287. data/ext/v8/upstream/3.1.8/src/mips/codegen-mips.h +431 -0
  288. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/constants-mips.cc +0 -0
  289. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/constants-mips.h +0 -0
  290. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/cpu-mips.cc +0 -0
  291. data/ext/v8/upstream/3.1.8/src/mips/debug-mips.cc +127 -0
  292. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/disasm-mips.cc +0 -0
  293. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/fast-codegen-mips.cc +0 -0
  294. data/ext/v8/upstream/3.1.8/src/mips/frames-mips.cc +96 -0
  295. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/frames-mips.h +0 -0
  296. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/full-codegen-mips.cc +0 -0
  297. data/ext/v8/upstream/3.1.8/src/mips/ic-mips.cc +208 -0
  298. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/jump-target-mips.cc +0 -0
  299. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/macro-assembler-mips.cc +0 -0
  300. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/macro-assembler-mips.h +0 -0
  301. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/register-allocator-mips-inl.h +0 -0
  302. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/register-allocator-mips.cc +0 -0
  303. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/register-allocator-mips.h +0 -0
  304. data/ext/v8/upstream/3.1.8/src/mips/simulator-mips.cc +1650 -0
  305. data/ext/v8/upstream/3.1.8/src/mips/simulator-mips.h +311 -0
  306. data/ext/v8/upstream/3.1.8/src/mips/stub-cache-mips.cc +418 -0
  307. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/virtual-frame-mips.cc +0 -0
  308. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/virtual-frame-mips.h +0 -0
  309. data/ext/v8/upstream/3.1.8/src/mirror-debugger.js +2380 -0
  310. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mksnapshot.cc +0 -0
  311. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/natives.h +0 -0
  312. data/ext/v8/upstream/3.1.8/src/objects-debug.cc +722 -0
  313. data/ext/v8/upstream/3.1.8/src/objects-inl.h +3946 -0
  314. data/ext/v8/upstream/3.1.8/src/objects-printer.cc +801 -0
  315. data/ext/v8/upstream/3.1.8/src/objects-visiting.cc +142 -0
  316. data/ext/v8/upstream/3.1.8/src/objects-visiting.h +401 -0
  317. data/ext/v8/upstream/3.1.8/src/objects.cc +10044 -0
  318. data/ext/v8/upstream/3.1.8/src/objects.h +6571 -0
  319. data/ext/v8/upstream/3.1.8/src/parser.cc +5165 -0
  320. data/ext/v8/upstream/3.1.8/src/parser.h +802 -0
  321. data/ext/v8/upstream/3.1.8/src/platform-cygwin.cc +745 -0
  322. data/ext/v8/upstream/3.1.8/src/platform-freebsd.cc +702 -0
  323. data/ext/v8/upstream/3.1.8/src/platform-linux.cc +981 -0
  324. data/ext/v8/upstream/3.1.8/src/platform-macos.cc +732 -0
  325. data/ext/v8/upstream/3.1.8/src/platform-nullos.cc +498 -0
  326. data/ext/v8/upstream/3.1.8/src/platform-openbsd.cc +657 -0
  327. data/ext/v8/upstream/3.1.8/src/platform-posix.cc +399 -0
  328. data/ext/v8/upstream/3.1.8/src/platform-solaris.cc +714 -0
  329. data/ext/v8/upstream/3.1.8/src/platform-win32.cc +1974 -0
  330. data/ext/v8/upstream/3.1.8/src/platform.h +636 -0
  331. data/ext/v8/upstream/3.1.8/src/preparse-data.cc +183 -0
  332. data/ext/v8/upstream/3.1.8/src/preparse-data.h +249 -0
  333. data/ext/v8/upstream/3.1.8/src/preparser-api.cc +213 -0
  334. data/ext/v8/upstream/3.1.8/src/preparser.cc +1205 -0
  335. data/ext/v8/upstream/3.1.8/src/preparser.h +278 -0
  336. data/ext/v8/upstream/3.1.8/src/prettyprinter.cc +1539 -0
  337. data/ext/v8/upstream/3.1.8/src/prettyprinter.h +223 -0
  338. data/ext/v8/upstream/3.1.8/src/profile-generator-inl.h +128 -0
  339. data/ext/v8/upstream/3.1.8/src/profile-generator.cc +2899 -0
  340. data/ext/v8/upstream/3.1.8/src/profile-generator.h +1151 -0
  341. data/ext/v8/upstream/3.1.8/src/property.cc +96 -0
  342. data/ext/v8/upstream/3.1.8/src/property.h +337 -0
  343. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/regexp-macro-assembler-irregexp-inl.h +0 -0
  344. data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-irregexp.cc +470 -0
  345. data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-irregexp.h +142 -0
  346. data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-tracer.cc +373 -0
  347. data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-tracer.h +104 -0
  348. data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler.cc +257 -0
  349. data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler.h +231 -0
  350. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/regexp-stack.cc +0 -0
  351. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/regexp-stack.h +0 -0
  352. data/ext/v8/upstream/3.1.8/src/regexp.js +483 -0
  353. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/register-allocator-inl.h +0 -0
  354. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/register-allocator.cc +0 -0
  355. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/register-allocator.h +0 -0
  356. data/ext/v8/upstream/3.1.8/src/rewriter.cc +1023 -0
  357. data/ext/v8/upstream/3.1.8/src/rewriter.h +59 -0
  358. data/ext/v8/upstream/3.1.8/src/runtime-profiler.cc +443 -0
  359. data/ext/v8/upstream/3.1.8/src/runtime-profiler.h +77 -0
  360. data/ext/v8/upstream/3.1.8/src/runtime.cc +11592 -0
  361. data/ext/v8/upstream/3.1.8/src/runtime.h +582 -0
  362. data/ext/v8/upstream/3.1.8/src/runtime.js +643 -0
  363. data/ext/v8/upstream/3.1.8/src/safepoint-table.cc +253 -0
  364. data/ext/v8/upstream/3.1.8/src/safepoint-table.h +263 -0
  365. data/ext/v8/upstream/3.1.8/src/scanner-base.cc +971 -0
  366. data/ext/v8/upstream/3.1.8/src/scanner-base.h +653 -0
  367. data/ext/v8/upstream/3.1.8/src/scanner.cc +586 -0
  368. data/ext/v8/upstream/3.1.8/src/scanner.h +194 -0
  369. data/ext/v8/upstream/3.1.8/src/scopeinfo.cc +636 -0
  370. data/ext/v8/upstream/3.1.8/src/scopeinfo.h +238 -0
  371. data/ext/v8/upstream/3.1.8/src/scopes.cc +1063 -0
  372. data/ext/v8/upstream/3.1.8/src/scopes.h +494 -0
  373. data/ext/v8/upstream/3.1.8/src/serialize.cc +1535 -0
  374. data/ext/v8/upstream/3.1.8/src/serialize.h +584 -0
  375. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/shell.h +0 -0
  376. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/simulator.h +0 -0
  377. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/smart-pointer.h +0 -0
  378. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/snapshot-common.cc +0 -0
  379. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/snapshot-empty.cc +0 -0
  380. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/snapshot.h +0 -0
  381. data/ext/v8/upstream/3.1.8/src/spaces-inl.h +524 -0
  382. data/ext/v8/upstream/3.1.8/src/spaces.cc +3254 -0
  383. data/ext/v8/upstream/3.1.8/src/spaces.h +2362 -0
  384. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/splay-tree-inl.h +0 -0
  385. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/splay-tree.h +0 -0
  386. data/ext/v8/upstream/3.1.8/src/string-search.cc +40 -0
  387. data/ext/v8/upstream/3.1.8/src/string-search.h +567 -0
  388. data/ext/v8/upstream/3.1.8/src/string-stream.cc +584 -0
  389. data/ext/v8/upstream/3.1.8/src/string-stream.h +191 -0
  390. data/ext/v8/upstream/3.1.8/src/string.js +915 -0
  391. data/ext/v8/upstream/3.1.8/src/strtod.cc +440 -0
  392. data/ext/v8/upstream/3.1.8/src/strtod.h +40 -0
  393. data/ext/v8/upstream/3.1.8/src/stub-cache.cc +1878 -0
  394. data/ext/v8/upstream/3.1.8/src/stub-cache.h +849 -0
  395. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/third_party/valgrind/valgrind.h +0 -0
  396. data/ext/v8/upstream/3.1.8/src/token.cc +63 -0
  397. data/ext/v8/upstream/3.1.8/src/token.h +288 -0
  398. data/ext/v8/upstream/3.1.8/src/top.cc +1152 -0
  399. data/ext/v8/upstream/3.1.8/src/top.h +608 -0
  400. data/ext/v8/upstream/3.1.8/src/type-info.cc +406 -0
  401. data/ext/v8/upstream/3.1.8/src/type-info.h +283 -0
  402. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/unbound-queue-inl.h +0 -0
  403. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/unbound-queue.h +0 -0
  404. data/ext/v8/upstream/3.1.8/src/unicode-inl.h +238 -0
  405. data/ext/v8/upstream/3.1.8/src/unicode.cc +1624 -0
  406. data/ext/v8/upstream/3.1.8/src/unicode.h +280 -0
  407. data/ext/v8/upstream/3.1.8/src/uri.js +402 -0
  408. data/ext/v8/upstream/3.1.8/src/utils.cc +371 -0
  409. data/ext/v8/upstream/3.1.8/src/utils.h +793 -0
  410. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/v8-counters.cc +0 -0
  411. data/ext/v8/upstream/3.1.8/src/v8-counters.h +290 -0
  412. data/ext/v8/upstream/3.1.8/src/v8.cc +270 -0
  413. data/ext/v8/upstream/3.1.8/src/v8.h +127 -0
  414. data/ext/v8/upstream/3.1.8/src/v8checks.h +64 -0
  415. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/v8dll-main.cc +0 -0
  416. data/ext/v8/upstream/3.1.8/src/v8globals.h +480 -0
  417. data/ext/v8/upstream/3.1.8/src/v8natives.js +1252 -0
  418. data/ext/v8/upstream/3.1.8/src/v8preparserdll-main.cc +39 -0
  419. data/ext/v8/upstream/3.1.8/src/v8threads.cc +440 -0
  420. data/ext/v8/upstream/3.1.8/src/v8threads.h +157 -0
  421. data/ext/v8/upstream/3.1.8/src/v8utils.h +354 -0
  422. data/ext/v8/upstream/3.1.8/src/variables.cc +132 -0
  423. data/ext/v8/upstream/3.1.8/src/variables.h +212 -0
  424. data/ext/v8/upstream/3.1.8/src/version.cc +95 -0
  425. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/version.h +0 -0
  426. data/ext/v8/upstream/3.1.8/src/virtual-frame-heavy-inl.h +190 -0
  427. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame-heavy.cc +0 -0
  428. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame-inl.h +0 -0
  429. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame-light-inl.h +0 -0
  430. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame-light.cc +0 -0
  431. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame.cc +0 -0
  432. data/ext/v8/upstream/3.1.8/src/virtual-frame.h +59 -0
  433. data/ext/v8/upstream/3.1.8/src/vm-state-inl.h +134 -0
  434. data/ext/v8/upstream/3.1.8/src/vm-state.h +68 -0
  435. data/ext/v8/upstream/3.1.8/src/win32-headers.h +95 -0
  436. data/ext/v8/upstream/3.1.8/src/x64/assembler-x64-inl.h +455 -0
  437. data/ext/v8/upstream/3.1.8/src/x64/assembler-x64.cc +3162 -0
  438. data/ext/v8/upstream/3.1.8/src/x64/assembler-x64.h +1584 -0
  439. data/ext/v8/upstream/3.1.8/src/x64/builtins-x64.cc +1492 -0
  440. data/ext/v8/upstream/3.1.8/src/x64/code-stubs-x64.cc +5150 -0
  441. data/ext/v8/upstream/3.1.8/src/x64/code-stubs-x64.h +519 -0
  442. data/ext/v8/upstream/3.1.8/src/x64/codegen-x64-inl.h +46 -0
  443. data/ext/v8/upstream/3.1.8/src/x64/codegen-x64.cc +8835 -0
  444. data/ext/v8/upstream/3.1.8/src/x64/codegen-x64.h +750 -0
  445. data/ext/v8/upstream/3.1.8/src/x64/cpu-x64.cc +86 -0
  446. data/ext/v8/upstream/3.1.8/src/x64/debug-x64.cc +316 -0
  447. data/ext/v8/upstream/3.1.8/src/x64/deoptimizer-x64.cc +781 -0
  448. data/ext/v8/upstream/3.1.8/src/x64/disasm-x64.cc +1737 -0
  449. data/ext/v8/upstream/3.1.8/src/x64/frames-x64.cc +45 -0
  450. data/ext/v8/upstream/3.1.8/src/x64/frames-x64.h +130 -0
  451. data/ext/v8/upstream/3.1.8/src/x64/full-codegen-x64.cc +3984 -0
  452. data/ext/v8/upstream/3.1.8/src/x64/ic-x64.cc +1761 -0
  453. data/ext/v8/upstream/3.1.8/src/x64/jump-target-x64.cc +437 -0
  454. data/ext/v8/upstream/3.1.8/src/x64/lithium-codegen-x64.cc +3639 -0
  455. data/ext/v8/upstream/3.1.8/src/x64/lithium-codegen-x64.h +305 -0
  456. data/ext/v8/upstream/3.1.8/src/x64/lithium-gap-resolver-x64.cc +320 -0
  457. data/ext/v8/upstream/3.1.8/src/x64/lithium-gap-resolver-x64.h +74 -0
  458. data/ext/v8/upstream/3.1.8/src/x64/lithium-x64.cc +2044 -0
  459. data/ext/v8/upstream/3.1.8/src/x64/lithium-x64.h +2052 -0
  460. data/ext/v8/upstream/3.1.8/src/x64/macro-assembler-x64.cc +2660 -0
  461. data/ext/v8/upstream/3.1.8/src/x64/macro-assembler-x64.h +1852 -0
  462. data/ext/v8/upstream/3.1.8/src/x64/regexp-macro-assembler-x64.cc +1382 -0
  463. data/ext/v8/upstream/3.1.8/src/x64/regexp-macro-assembler-x64.h +278 -0
  464. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/x64/register-allocator-x64-inl.h +0 -0
  465. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/x64/register-allocator-x64.cc +0 -0
  466. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/x64/register-allocator-x64.h +0 -0
  467. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/x64/simulator-x64.cc +0 -0
  468. data/ext/v8/upstream/3.1.8/src/x64/simulator-x64.h +71 -0
  469. data/ext/v8/upstream/3.1.8/src/x64/stub-cache-x64.cc +3509 -0
  470. data/ext/v8/upstream/3.1.8/src/x64/virtual-frame-x64.cc +1292 -0
  471. data/ext/v8/upstream/3.1.8/src/x64/virtual-frame-x64.h +593 -0
  472. data/ext/v8/upstream/3.1.8/src/zone-inl.h +83 -0
  473. data/ext/v8/upstream/3.1.8/src/zone.cc +195 -0
  474. data/ext/v8/upstream/3.1.8/src/zone.h +233 -0
  475. data/ext/v8/upstream/3.1.8/tools/codemap.js +265 -0
  476. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/consarray.js +0 -0
  477. data/ext/v8/upstream/3.1.8/tools/csvparser.js +78 -0
  478. data/ext/v8/upstream/3.1.8/tools/disasm.py +92 -0
  479. data/ext/v8/upstream/3.1.8/tools/gc-nvp-trace-processor.py +328 -0
  480. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/generate-ten-powers.scm +0 -0
  481. data/ext/v8/upstream/3.1.8/tools/grokdump.py +840 -0
  482. data/ext/v8/upstream/3.1.8/tools/gyp/v8.gyp +869 -0
  483. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/js2c.py +0 -0
  484. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/jsmin.py +0 -0
  485. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/linux-tick-processor +0 -0
  486. data/ext/v8/upstream/3.1.8/tools/ll_prof.py +919 -0
  487. data/ext/v8/upstream/3.1.8/tools/logreader.js +185 -0
  488. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/mac-nm +0 -0
  489. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/mac-tick-processor +0 -0
  490. data/ext/v8/upstream/3.1.8/tools/oom_dump/README +31 -0
  491. data/ext/v8/upstream/3.1.8/tools/oom_dump/SConstruct +42 -0
  492. data/ext/v8/upstream/3.1.8/tools/oom_dump/oom_dump.cc +288 -0
  493. data/ext/v8/upstream/3.1.8/tools/presubmit.py +305 -0
  494. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/process-heap-prof.py +0 -0
  495. data/ext/v8/upstream/3.1.8/tools/profile.js +751 -0
  496. data/ext/v8/upstream/3.1.8/tools/profile_view.js +219 -0
  497. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/run-valgrind.py +0 -0
  498. data/ext/v8/upstream/3.1.8/tools/splaytree.js +316 -0
  499. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/stats-viewer.py +0 -0
  500. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/tickprocessor-driver.js +0 -0
  501. data/ext/v8/upstream/3.1.8/tools/tickprocessor.js +863 -0
  502. data/ext/v8/upstream/3.1.8/tools/utils.py +96 -0
  503. data/ext/v8/upstream/3.1.8/tools/visual_studio/README.txt +70 -0
  504. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/arm.vsprops +0 -0
  505. data/ext/v8/upstream/3.1.8/tools/visual_studio/common.vsprops +34 -0
  506. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/d8.vcproj +0 -0
  507. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/d8_arm.vcproj +0 -0
  508. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/d8_x64.vcproj +0 -0
  509. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/d8js2c.cmd +0 -0
  510. data/ext/v8/upstream/3.1.8/tools/visual_studio/debug.vsprops +17 -0
  511. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/ia32.vsprops +0 -0
  512. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/js2c.cmd +0 -0
  513. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/release.vsprops +0 -0
  514. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8.sln +0 -0
  515. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8.vcproj +0 -0
  516. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_arm.sln +0 -0
  517. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_arm.vcproj +0 -0
  518. data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base.vcproj +1296 -0
  519. data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base_arm.vcproj +1234 -0
  520. data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base_x64.vcproj +1296 -0
  521. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_cctest.vcproj +0 -0
  522. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_cctest_arm.vcproj +0 -0
  523. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_cctest_x64.vcproj +0 -0
  524. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_mksnapshot.vcproj +0 -0
  525. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_mksnapshot_x64.vcproj +0 -0
  526. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_process_sample.vcproj +0 -0
  527. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_process_sample_arm.vcproj +0 -0
  528. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_process_sample_x64.vcproj +0 -0
  529. data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_shell_sample.vcproj +147 -0
  530. data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_shell_sample_arm.vcproj +147 -0
  531. data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_shell_sample_x64.vcproj +163 -0
  532. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_snapshot.vcproj +0 -0
  533. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_snapshot_cc.vcproj +0 -0
  534. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_snapshot_cc_x64.vcproj +0 -0
  535. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_snapshot_x64.vcproj +0 -0
  536. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_x64.sln +0 -0
  537. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_x64.vcproj +0 -0
  538. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/x64.vsprops +0 -0
  539. data/ext/v8/upstream/3.1.8/tools/windows-tick-processor.bat +30 -0
  540. data/ext/v8/upstream/Makefile +2 -1
  541. data/ext/v8/v8_template.cpp +2 -2
  542. data/lib/v8/version.rb +1 -1
  543. data/spec/redjs/jsapi_spec.rb +2 -2
  544. metadata +552 -490
  545. data/ext/v8/upstream/2.3.3/.gitignore +0 -26
  546. data/ext/v8/upstream/2.3.3/AUTHORS +0 -31
  547. data/ext/v8/upstream/2.3.3/ChangeLog +0 -1916
  548. data/ext/v8/upstream/2.3.3/LICENSE +0 -55
  549. data/ext/v8/upstream/2.3.3/SConstruct +0 -1154
  550. data/ext/v8/upstream/2.3.3/include/v8-debug.h +0 -381
  551. data/ext/v8/upstream/2.3.3/include/v8-profiler.h +0 -353
  552. data/ext/v8/upstream/2.3.3/include/v8.h +0 -3616
  553. data/ext/v8/upstream/2.3.3/src/SConscript +0 -330
  554. data/ext/v8/upstream/2.3.3/src/accessors.cc +0 -661
  555. data/ext/v8/upstream/2.3.3/src/accessors.h +0 -114
  556. data/ext/v8/upstream/2.3.3/src/allocation.cc +0 -198
  557. data/ext/v8/upstream/2.3.3/src/allocation.h +0 -169
  558. data/ext/v8/upstream/2.3.3/src/api.cc +0 -4795
  559. data/ext/v8/upstream/2.3.3/src/api.h +0 -485
  560. data/ext/v8/upstream/2.3.3/src/apiutils.h +0 -69
  561. data/ext/v8/upstream/2.3.3/src/arguments.h +0 -96
  562. data/ext/v8/upstream/2.3.3/src/arm/assembler-arm-inl.h +0 -305
  563. data/ext/v8/upstream/2.3.3/src/arm/assembler-arm.cc +0 -2580
  564. data/ext/v8/upstream/2.3.3/src/arm/assembler-arm.h +0 -1275
  565. data/ext/v8/upstream/2.3.3/src/arm/builtins-arm.cc +0 -1320
  566. data/ext/v8/upstream/2.3.3/src/arm/codegen-arm-inl.h +0 -48
  567. data/ext/v8/upstream/2.3.3/src/arm/codegen-arm.cc +0 -11398
  568. data/ext/v8/upstream/2.3.3/src/arm/codegen-arm.h +0 -1102
  569. data/ext/v8/upstream/2.3.3/src/arm/constants-arm.cc +0 -154
  570. data/ext/v8/upstream/2.3.3/src/arm/constants-arm.h +0 -388
  571. data/ext/v8/upstream/2.3.3/src/arm/cpu-arm.cc +0 -142
  572. data/ext/v8/upstream/2.3.3/src/arm/debug-arm.cc +0 -309
  573. data/ext/v8/upstream/2.3.3/src/arm/disasm-arm.cc +0 -1459
  574. data/ext/v8/upstream/2.3.3/src/arm/fast-codegen-arm.cc +0 -241
  575. data/ext/v8/upstream/2.3.3/src/arm/frames-arm.cc +0 -123
  576. data/ext/v8/upstream/2.3.3/src/arm/frames-arm.h +0 -162
  577. data/ext/v8/upstream/2.3.3/src/arm/full-codegen-arm.cc +0 -3178
  578. data/ext/v8/upstream/2.3.3/src/arm/ic-arm.cc +0 -2258
  579. data/ext/v8/upstream/2.3.3/src/arm/jump-target-arm.cc +0 -164
  580. data/ext/v8/upstream/2.3.3/src/arm/macro-assembler-arm.cc +0 -1892
  581. data/ext/v8/upstream/2.3.3/src/arm/macro-assembler-arm.h +0 -727
  582. data/ext/v8/upstream/2.3.3/src/arm/regexp-macro-assembler-arm.cc +0 -1261
  583. data/ext/v8/upstream/2.3.3/src/arm/regexp-macro-assembler-arm.h +0 -266
  584. data/ext/v8/upstream/2.3.3/src/arm/simulator-arm.cc +0 -2822
  585. data/ext/v8/upstream/2.3.3/src/arm/simulator-arm.h +0 -361
  586. data/ext/v8/upstream/2.3.3/src/arm/stub-cache-arm.cc +0 -2387
  587. data/ext/v8/upstream/2.3.3/src/arm/virtual-frame-arm.cc +0 -834
  588. data/ext/v8/upstream/2.3.3/src/arm/virtual-frame-arm.h +0 -519
  589. data/ext/v8/upstream/2.3.3/src/array.js +0 -1127
  590. data/ext/v8/upstream/2.3.3/src/assembler.cc +0 -801
  591. data/ext/v8/upstream/2.3.3/src/assembler.h +0 -573
  592. data/ext/v8/upstream/2.3.3/src/ast-inl.h +0 -81
  593. data/ext/v8/upstream/2.3.3/src/ast.cc +0 -1152
  594. data/ext/v8/upstream/2.3.3/src/ast.h +0 -2106
  595. data/ext/v8/upstream/2.3.3/src/bootstrapper.cc +0 -1819
  596. data/ext/v8/upstream/2.3.3/src/builtins.cc +0 -1529
  597. data/ext/v8/upstream/2.3.3/src/builtins.h +0 -263
  598. data/ext/v8/upstream/2.3.3/src/bytecodes-irregexp.h +0 -104
  599. data/ext/v8/upstream/2.3.3/src/cached-powers.h +0 -119
  600. data/ext/v8/upstream/2.3.3/src/char-predicates-inl.h +0 -86
  601. data/ext/v8/upstream/2.3.3/src/checks.cc +0 -100
  602. data/ext/v8/upstream/2.3.3/src/checks.h +0 -310
  603. data/ext/v8/upstream/2.3.3/src/circular-queue.cc +0 -121
  604. data/ext/v8/upstream/2.3.3/src/code-stubs.cc +0 -177
  605. data/ext/v8/upstream/2.3.3/src/code-stubs.h +0 -177
  606. data/ext/v8/upstream/2.3.3/src/codegen-inl.h +0 -60
  607. data/ext/v8/upstream/2.3.3/src/codegen.cc +0 -516
  608. data/ext/v8/upstream/2.3.3/src/codegen.h +0 -897
  609. data/ext/v8/upstream/2.3.3/src/compilation-cache.cc +0 -562
  610. data/ext/v8/upstream/2.3.3/src/compilation-cache.h +0 -102
  611. data/ext/v8/upstream/2.3.3/src/compiler.cc +0 -654
  612. data/ext/v8/upstream/2.3.3/src/compiler.h +0 -299
  613. data/ext/v8/upstream/2.3.3/src/contexts.cc +0 -256
  614. data/ext/v8/upstream/2.3.3/src/contexts.h +0 -342
  615. data/ext/v8/upstream/2.3.3/src/conversions.cc +0 -1119
  616. data/ext/v8/upstream/2.3.3/src/conversions.h +0 -123
  617. data/ext/v8/upstream/2.3.3/src/counters.h +0 -239
  618. data/ext/v8/upstream/2.3.3/src/cpu-profiler-inl.h +0 -100
  619. data/ext/v8/upstream/2.3.3/src/cpu-profiler.cc +0 -538
  620. data/ext/v8/upstream/2.3.3/src/cpu-profiler.h +0 -285
  621. data/ext/v8/upstream/2.3.3/src/d8-debug.cc +0 -356
  622. data/ext/v8/upstream/2.3.3/src/d8-debug.h +0 -155
  623. data/ext/v8/upstream/2.3.3/src/d8.cc +0 -783
  624. data/ext/v8/upstream/2.3.3/src/d8.h +0 -227
  625. data/ext/v8/upstream/2.3.3/src/d8.js +0 -1683
  626. data/ext/v8/upstream/2.3.3/src/data-flow.cc +0 -758
  627. data/ext/v8/upstream/2.3.3/src/data-flow.h +0 -278
  628. data/ext/v8/upstream/2.3.3/src/date.js +0 -1059
  629. data/ext/v8/upstream/2.3.3/src/dateparser-inl.h +0 -123
  630. data/ext/v8/upstream/2.3.3/src/dateparser.h +0 -244
  631. data/ext/v8/upstream/2.3.3/src/debug-agent.cc +0 -427
  632. data/ext/v8/upstream/2.3.3/src/debug-agent.h +0 -129
  633. data/ext/v8/upstream/2.3.3/src/debug-debugger.js +0 -2227
  634. data/ext/v8/upstream/2.3.3/src/debug.cc +0 -3005
  635. data/ext/v8/upstream/2.3.3/src/debug.h +0 -993
  636. data/ext/v8/upstream/2.3.3/src/disassembler.cc +0 -312
  637. data/ext/v8/upstream/2.3.3/src/double.h +0 -169
  638. data/ext/v8/upstream/2.3.3/src/dtoa-config.c +0 -92
  639. data/ext/v8/upstream/2.3.3/src/dtoa.cc +0 -77
  640. data/ext/v8/upstream/2.3.3/src/dtoa.h +0 -81
  641. data/ext/v8/upstream/2.3.3/src/execution.cc +0 -809
  642. data/ext/v8/upstream/2.3.3/src/execution.h +0 -336
  643. data/ext/v8/upstream/2.3.3/src/factory.cc +0 -1003
  644. data/ext/v8/upstream/2.3.3/src/factory.h +0 -410
  645. data/ext/v8/upstream/2.3.3/src/fast-codegen.cc +0 -746
  646. data/ext/v8/upstream/2.3.3/src/fast-codegen.h +0 -161
  647. data/ext/v8/upstream/2.3.3/src/fast-dtoa.cc +0 -505
  648. data/ext/v8/upstream/2.3.3/src/fast-dtoa.h +0 -58
  649. data/ext/v8/upstream/2.3.3/src/flag-definitions.h +0 -455
  650. data/ext/v8/upstream/2.3.3/src/flags.cc +0 -551
  651. data/ext/v8/upstream/2.3.3/src/flags.h +0 -81
  652. data/ext/v8/upstream/2.3.3/src/flow-graph.cc +0 -763
  653. data/ext/v8/upstream/2.3.3/src/flow-graph.h +0 -180
  654. data/ext/v8/upstream/2.3.3/src/frame-element.h +0 -273
  655. data/ext/v8/upstream/2.3.3/src/frames-inl.h +0 -217
  656. data/ext/v8/upstream/2.3.3/src/frames.cc +0 -826
  657. data/ext/v8/upstream/2.3.3/src/frames.h +0 -682
  658. data/ext/v8/upstream/2.3.3/src/full-codegen.cc +0 -1443
  659. data/ext/v8/upstream/2.3.3/src/full-codegen.h +0 -548
  660. data/ext/v8/upstream/2.3.3/src/func-name-inferrer.cc +0 -76
  661. data/ext/v8/upstream/2.3.3/src/func-name-inferrer.h +0 -135
  662. data/ext/v8/upstream/2.3.3/src/global-handles.cc +0 -520
  663. data/ext/v8/upstream/2.3.3/src/global-handles.h +0 -180
  664. data/ext/v8/upstream/2.3.3/src/globals.h +0 -669
  665. data/ext/v8/upstream/2.3.3/src/handles-inl.h +0 -76
  666. data/ext/v8/upstream/2.3.3/src/handles.cc +0 -825
  667. data/ext/v8/upstream/2.3.3/src/handles.h +0 -393
  668. data/ext/v8/upstream/2.3.3/src/hashmap.cc +0 -226
  669. data/ext/v8/upstream/2.3.3/src/hashmap.h +0 -120
  670. data/ext/v8/upstream/2.3.3/src/heap-inl.h +0 -493
  671. data/ext/v8/upstream/2.3.3/src/heap-profiler.cc +0 -779
  672. data/ext/v8/upstream/2.3.3/src/heap-profiler.h +0 -323
  673. data/ext/v8/upstream/2.3.3/src/heap.cc +0 -4994
  674. data/ext/v8/upstream/2.3.3/src/heap.h +0 -1984
  675. data/ext/v8/upstream/2.3.3/src/ia32/assembler-ia32-inl.h +0 -360
  676. data/ext/v8/upstream/2.3.3/src/ia32/assembler-ia32.cc +0 -2600
  677. data/ext/v8/upstream/2.3.3/src/ia32/assembler-ia32.h +0 -969
  678. data/ext/v8/upstream/2.3.3/src/ia32/builtins-ia32.cc +0 -1261
  679. data/ext/v8/upstream/2.3.3/src/ia32/codegen-ia32.cc +0 -13968
  680. data/ext/v8/upstream/2.3.3/src/ia32/codegen-ia32.h +0 -1097
  681. data/ext/v8/upstream/2.3.3/src/ia32/cpu-ia32.cc +0 -83
  682. data/ext/v8/upstream/2.3.3/src/ia32/debug-ia32.cc +0 -309
  683. data/ext/v8/upstream/2.3.3/src/ia32/disasm-ia32.cc +0 -1471
  684. data/ext/v8/upstream/2.3.3/src/ia32/fast-codegen-ia32.cc +0 -954
  685. data/ext/v8/upstream/2.3.3/src/ia32/fast-codegen-ia32.h +0 -155
  686. data/ext/v8/upstream/2.3.3/src/ia32/frames-ia32.cc +0 -115
  687. data/ext/v8/upstream/2.3.3/src/ia32/frames-ia32.h +0 -135
  688. data/ext/v8/upstream/2.3.3/src/ia32/full-codegen-ia32.cc +0 -3281
  689. data/ext/v8/upstream/2.3.3/src/ia32/ic-ia32.cc +0 -1966
  690. data/ext/v8/upstream/2.3.3/src/ia32/macro-assembler-ia32.cc +0 -1610
  691. data/ext/v8/upstream/2.3.3/src/ia32/macro-assembler-ia32.h +0 -610
  692. data/ext/v8/upstream/2.3.3/src/ia32/regexp-macro-assembler-ia32.cc +0 -1247
  693. data/ext/v8/upstream/2.3.3/src/ia32/regexp-macro-assembler-ia32.h +0 -214
  694. data/ext/v8/upstream/2.3.3/src/ia32/simulator-ia32.h +0 -62
  695. data/ext/v8/upstream/2.3.3/src/ia32/stub-cache-ia32.cc +0 -2750
  696. data/ext/v8/upstream/2.3.3/src/ia32/virtual-frame-ia32.cc +0 -1334
  697. data/ext/v8/upstream/2.3.3/src/ia32/virtual-frame-ia32.h +0 -627
  698. data/ext/v8/upstream/2.3.3/src/ic-inl.h +0 -120
  699. data/ext/v8/upstream/2.3.3/src/ic.cc +0 -1827
  700. data/ext/v8/upstream/2.3.3/src/ic.h +0 -515
  701. data/ext/v8/upstream/2.3.3/src/interpreter-irregexp.cc +0 -646
  702. data/ext/v8/upstream/2.3.3/src/json.js +0 -268
  703. data/ext/v8/upstream/2.3.3/src/jsregexp.cc +0 -5283
  704. data/ext/v8/upstream/2.3.3/src/jsregexp.h +0 -1463
  705. data/ext/v8/upstream/2.3.3/src/jump-target-heavy.cc +0 -429
  706. data/ext/v8/upstream/2.3.3/src/jump-target-heavy.h +0 -244
  707. data/ext/v8/upstream/2.3.3/src/jump-target-light.cc +0 -110
  708. data/ext/v8/upstream/2.3.3/src/jump-target-light.h +0 -192
  709. data/ext/v8/upstream/2.3.3/src/list-inl.h +0 -166
  710. data/ext/v8/upstream/2.3.3/src/list.h +0 -159
  711. data/ext/v8/upstream/2.3.3/src/liveedit-debugger.js +0 -1057
  712. data/ext/v8/upstream/2.3.3/src/liveedit.cc +0 -1480
  713. data/ext/v8/upstream/2.3.3/src/liveedit.h +0 -170
  714. data/ext/v8/upstream/2.3.3/src/log-utils.cc +0 -497
  715. data/ext/v8/upstream/2.3.3/src/log-utils.h +0 -289
  716. data/ext/v8/upstream/2.3.3/src/log.cc +0 -1561
  717. data/ext/v8/upstream/2.3.3/src/log.h +0 -384
  718. data/ext/v8/upstream/2.3.3/src/macro-assembler.h +0 -86
  719. data/ext/v8/upstream/2.3.3/src/macros.py +0 -177
  720. data/ext/v8/upstream/2.3.3/src/mark-compact.cc +0 -2330
  721. data/ext/v8/upstream/2.3.3/src/mark-compact.h +0 -451
  722. data/ext/v8/upstream/2.3.3/src/math.js +0 -264
  723. data/ext/v8/upstream/2.3.3/src/memory.h +0 -74
  724. data/ext/v8/upstream/2.3.3/src/messages.cc +0 -183
  725. data/ext/v8/upstream/2.3.3/src/messages.h +0 -113
  726. data/ext/v8/upstream/2.3.3/src/messages.js +0 -982
  727. data/ext/v8/upstream/2.3.3/src/mips/assembler-mips.h +0 -668
  728. data/ext/v8/upstream/2.3.3/src/mips/builtins-mips.cc +0 -205
  729. data/ext/v8/upstream/2.3.3/src/mips/codegen-mips.h +0 -434
  730. data/ext/v8/upstream/2.3.3/src/mips/debug-mips.cc +0 -131
  731. data/ext/v8/upstream/2.3.3/src/mips/frames-mips.cc +0 -102
  732. data/ext/v8/upstream/2.3.3/src/mips/ic-mips.cc +0 -220
  733. data/ext/v8/upstream/2.3.3/src/mips/simulator-mips.cc +0 -1651
  734. data/ext/v8/upstream/2.3.3/src/mips/simulator-mips.h +0 -311
  735. data/ext/v8/upstream/2.3.3/src/mips/stub-cache-mips.cc +0 -403
  736. data/ext/v8/upstream/2.3.3/src/mirror-debugger.js +0 -2380
  737. data/ext/v8/upstream/2.3.3/src/objects-debug.cc +0 -1366
  738. data/ext/v8/upstream/2.3.3/src/objects-inl.h +0 -3333
  739. data/ext/v8/upstream/2.3.3/src/objects.cc +0 -8820
  740. data/ext/v8/upstream/2.3.3/src/objects.h +0 -5373
  741. data/ext/v8/upstream/2.3.3/src/oprofile-agent.cc +0 -108
  742. data/ext/v8/upstream/2.3.3/src/oprofile-agent.h +0 -77
  743. data/ext/v8/upstream/2.3.3/src/parser.cc +0 -5207
  744. data/ext/v8/upstream/2.3.3/src/parser.h +0 -197
  745. data/ext/v8/upstream/2.3.3/src/platform-freebsd.cc +0 -667
  746. data/ext/v8/upstream/2.3.3/src/platform-linux.cc +0 -862
  747. data/ext/v8/upstream/2.3.3/src/platform-macos.cc +0 -665
  748. data/ext/v8/upstream/2.3.3/src/platform-nullos.cc +0 -454
  749. data/ext/v8/upstream/2.3.3/src/platform-openbsd.cc +0 -622
  750. data/ext/v8/upstream/2.3.3/src/platform-posix.cc +0 -362
  751. data/ext/v8/upstream/2.3.3/src/platform-solaris.cc +0 -653
  752. data/ext/v8/upstream/2.3.3/src/platform-win32.cc +0 -1911
  753. data/ext/v8/upstream/2.3.3/src/platform.h +0 -577
  754. data/ext/v8/upstream/2.3.3/src/powers-ten.h +0 -2461
  755. data/ext/v8/upstream/2.3.3/src/prettyprinter.cc +0 -1531
  756. data/ext/v8/upstream/2.3.3/src/prettyprinter.h +0 -221
  757. data/ext/v8/upstream/2.3.3/src/profile-generator-inl.h +0 -148
  758. data/ext/v8/upstream/2.3.3/src/profile-generator.cc +0 -1830
  759. data/ext/v8/upstream/2.3.3/src/profile-generator.h +0 -853
  760. data/ext/v8/upstream/2.3.3/src/property.cc +0 -96
  761. data/ext/v8/upstream/2.3.3/src/property.h +0 -315
  762. data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler-irregexp.cc +0 -464
  763. data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler-irregexp.h +0 -141
  764. data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler-tracer.cc +0 -356
  765. data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler-tracer.h +0 -103
  766. data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler.cc +0 -261
  767. data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler.h +0 -228
  768. data/ext/v8/upstream/2.3.3/src/regexp.js +0 -549
  769. data/ext/v8/upstream/2.3.3/src/rewriter.cc +0 -1038
  770. data/ext/v8/upstream/2.3.3/src/rewriter.h +0 -54
  771. data/ext/v8/upstream/2.3.3/src/runtime.cc +0 -10599
  772. data/ext/v8/upstream/2.3.3/src/runtime.h +0 -459
  773. data/ext/v8/upstream/2.3.3/src/runtime.js +0 -629
  774. data/ext/v8/upstream/2.3.3/src/scanner.cc +0 -1346
  775. data/ext/v8/upstream/2.3.3/src/scanner.h +0 -503
  776. data/ext/v8/upstream/2.3.3/src/scopeinfo.cc +0 -637
  777. data/ext/v8/upstream/2.3.3/src/scopeinfo.h +0 -233
  778. data/ext/v8/upstream/2.3.3/src/scopes.cc +0 -962
  779. data/ext/v8/upstream/2.3.3/src/scopes.h +0 -400
  780. data/ext/v8/upstream/2.3.3/src/serialize.cc +0 -1461
  781. data/ext/v8/upstream/2.3.3/src/serialize.h +0 -581
  782. data/ext/v8/upstream/2.3.3/src/spaces-inl.h +0 -483
  783. data/ext/v8/upstream/2.3.3/src/spaces.cc +0 -2901
  784. data/ext/v8/upstream/2.3.3/src/spaces.h +0 -2197
  785. data/ext/v8/upstream/2.3.3/src/string-stream.cc +0 -584
  786. data/ext/v8/upstream/2.3.3/src/string-stream.h +0 -189
  787. data/ext/v8/upstream/2.3.3/src/string.js +0 -1006
  788. data/ext/v8/upstream/2.3.3/src/stub-cache.cc +0 -1379
  789. data/ext/v8/upstream/2.3.3/src/stub-cache.h +0 -756
  790. data/ext/v8/upstream/2.3.3/src/third_party/dtoa/COPYING +0 -15
  791. data/ext/v8/upstream/2.3.3/src/third_party/dtoa/dtoa.c +0 -3334
  792. data/ext/v8/upstream/2.3.3/src/token.cc +0 -56
  793. data/ext/v8/upstream/2.3.3/src/token.h +0 -270
  794. data/ext/v8/upstream/2.3.3/src/top.cc +0 -1067
  795. data/ext/v8/upstream/2.3.3/src/top.h +0 -463
  796. data/ext/v8/upstream/2.3.3/src/type-info.cc +0 -53
  797. data/ext/v8/upstream/2.3.3/src/type-info.h +0 -244
  798. data/ext/v8/upstream/2.3.3/src/unicode-inl.h +0 -238
  799. data/ext/v8/upstream/2.3.3/src/unicode.cc +0 -749
  800. data/ext/v8/upstream/2.3.3/src/unicode.h +0 -279
  801. data/ext/v8/upstream/2.3.3/src/uri.js +0 -415
  802. data/ext/v8/upstream/2.3.3/src/utils.cc +0 -285
  803. data/ext/v8/upstream/2.3.3/src/utils.h +0 -745
  804. data/ext/v8/upstream/2.3.3/src/v8-counters.h +0 -250
  805. data/ext/v8/upstream/2.3.3/src/v8.cc +0 -228
  806. data/ext/v8/upstream/2.3.3/src/v8.h +0 -121
  807. data/ext/v8/upstream/2.3.3/src/v8natives.js +0 -1188
  808. data/ext/v8/upstream/2.3.3/src/v8threads.cc +0 -461
  809. data/ext/v8/upstream/2.3.3/src/v8threads.h +0 -159
  810. data/ext/v8/upstream/2.3.3/src/variables.cc +0 -119
  811. data/ext/v8/upstream/2.3.3/src/variables.h +0 -205
  812. data/ext/v8/upstream/2.3.3/src/version.cc +0 -88
  813. data/ext/v8/upstream/2.3.3/src/virtual-frame-heavy-inl.h +0 -192
  814. data/ext/v8/upstream/2.3.3/src/virtual-frame.h +0 -46
  815. data/ext/v8/upstream/2.3.3/src/vm-state-inl.h +0 -137
  816. data/ext/v8/upstream/2.3.3/src/vm-state.cc +0 -39
  817. data/ext/v8/upstream/2.3.3/src/vm-state.h +0 -77
  818. data/ext/v8/upstream/2.3.3/src/x64/assembler-x64-inl.h +0 -400
  819. data/ext/v8/upstream/2.3.3/src/x64/assembler-x64.cc +0 -2963
  820. data/ext/v8/upstream/2.3.3/src/x64/assembler-x64.h +0 -1438
  821. data/ext/v8/upstream/2.3.3/src/x64/builtins-x64.cc +0 -1296
  822. data/ext/v8/upstream/2.3.3/src/x64/codegen-x64-inl.h +0 -46
  823. data/ext/v8/upstream/2.3.3/src/x64/codegen-x64.cc +0 -12491
  824. data/ext/v8/upstream/2.3.3/src/x64/codegen-x64.h +0 -1090
  825. data/ext/v8/upstream/2.3.3/src/x64/cpu-x64.cc +0 -83
  826. data/ext/v8/upstream/2.3.3/src/x64/debug-x64.cc +0 -267
  827. data/ext/v8/upstream/2.3.3/src/x64/disasm-x64.cc +0 -1696
  828. data/ext/v8/upstream/2.3.3/src/x64/fast-codegen-x64.cc +0 -250
  829. data/ext/v8/upstream/2.3.3/src/x64/frames-x64.cc +0 -113
  830. data/ext/v8/upstream/2.3.3/src/x64/frames-x64.h +0 -125
  831. data/ext/v8/upstream/2.3.3/src/x64/full-codegen-x64.cc +0 -3270
  832. data/ext/v8/upstream/2.3.3/src/x64/ic-x64.cc +0 -1907
  833. data/ext/v8/upstream/2.3.3/src/x64/jump-target-x64.cc +0 -437
  834. data/ext/v8/upstream/2.3.3/src/x64/macro-assembler-x64.cc +0 -2793
  835. data/ext/v8/upstream/2.3.3/src/x64/macro-assembler-x64.h +0 -916
  836. data/ext/v8/upstream/2.3.3/src/x64/regexp-macro-assembler-x64.cc +0 -1374
  837. data/ext/v8/upstream/2.3.3/src/x64/regexp-macro-assembler-x64.h +0 -277
  838. data/ext/v8/upstream/2.3.3/src/x64/simulator-x64.h +0 -63
  839. data/ext/v8/upstream/2.3.3/src/x64/stub-cache-x64.cc +0 -2560
  840. data/ext/v8/upstream/2.3.3/src/x64/virtual-frame-x64.cc +0 -1264
  841. data/ext/v8/upstream/2.3.3/src/x64/virtual-frame-x64.h +0 -590
  842. data/ext/v8/upstream/2.3.3/src/zone-inl.h +0 -82
  843. data/ext/v8/upstream/2.3.3/src/zone.cc +0 -194
  844. data/ext/v8/upstream/2.3.3/src/zone.h +0 -221
  845. data/ext/v8/upstream/2.3.3/tools/codemap.js +0 -270
  846. data/ext/v8/upstream/2.3.3/tools/csvparser.js +0 -83
  847. data/ext/v8/upstream/2.3.3/tools/gc-nvp-trace-processor.py +0 -317
  848. data/ext/v8/upstream/2.3.3/tools/gyp/v8.gyp +0 -749
  849. data/ext/v8/upstream/2.3.3/tools/linux-tick-processor.py +0 -78
  850. data/ext/v8/upstream/2.3.3/tools/logreader.js +0 -338
  851. data/ext/v8/upstream/2.3.3/tools/oprofile/annotate +0 -7
  852. data/ext/v8/upstream/2.3.3/tools/oprofile/common +0 -19
  853. data/ext/v8/upstream/2.3.3/tools/oprofile/dump +0 -7
  854. data/ext/v8/upstream/2.3.3/tools/oprofile/report +0 -7
  855. data/ext/v8/upstream/2.3.3/tools/oprofile/reset +0 -7
  856. data/ext/v8/upstream/2.3.3/tools/oprofile/run +0 -14
  857. data/ext/v8/upstream/2.3.3/tools/oprofile/shutdown +0 -7
  858. data/ext/v8/upstream/2.3.3/tools/oprofile/start +0 -7
  859. data/ext/v8/upstream/2.3.3/tools/presubmit.py +0 -299
  860. data/ext/v8/upstream/2.3.3/tools/profile.js +0 -691
  861. data/ext/v8/upstream/2.3.3/tools/profile_view.js +0 -224
  862. data/ext/v8/upstream/2.3.3/tools/splaytree.js +0 -322
  863. data/ext/v8/upstream/2.3.3/tools/splaytree.py +0 -226
  864. data/ext/v8/upstream/2.3.3/tools/tickprocessor.js +0 -862
  865. data/ext/v8/upstream/2.3.3/tools/tickprocessor.py +0 -571
  866. data/ext/v8/upstream/2.3.3/tools/utils.py +0 -88
  867. data/ext/v8/upstream/2.3.3/tools/visual_studio/README.txt +0 -71
  868. data/ext/v8/upstream/2.3.3/tools/visual_studio/common.vsprops +0 -34
  869. data/ext/v8/upstream/2.3.3/tools/visual_studio/debug.vsprops +0 -17
  870. data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_base.vcproj +0 -1143
  871. data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_base_arm.vcproj +0 -1115
  872. data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_base_x64.vcproj +0 -1096
  873. data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_shell_sample.vcproj +0 -145
  874. data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_shell_sample_arm.vcproj +0 -145
  875. data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_shell_sample_x64.vcproj +0 -161
  876. data/ext/v8/upstream/2.3.3/tools/windows-tick-processor.bat +0 -29
  877. data/ext/v8/upstream/2.3.3/tools/windows-tick-processor.py +0 -137
@@ -0,0 +1,1737 @@
1
+ // Copyright 2011 the V8 project authors. All rights reserved.
2
+ // Redistribution and use in source and binary forms, with or without
3
+ // modification, are permitted provided that the following conditions are
4
+ // met:
5
+ //
6
+ // * Redistributions of source code must retain the above copyright
7
+ // notice, this list of conditions and the following disclaimer.
8
+ // * Redistributions in binary form must reproduce the above
9
+ // copyright notice, this list of conditions and the following
10
+ // disclaimer in the documentation and/or other materials provided
11
+ // with the distribution.
12
+ // * Neither the name of Google Inc. nor the names of its
13
+ // contributors may be used to endorse or promote products derived
14
+ // from this software without specific prior written permission.
15
+ //
16
+ // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17
+ // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18
+ // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19
+ // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20
+ // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21
+ // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22
+ // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23
+ // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24
+ // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25
+ // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26
+ // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
+
28
+ #include <assert.h>
29
+ #include <stdio.h>
30
+ #include <stdarg.h>
31
+
32
+ #include "v8.h"
33
+
34
+ #if defined(V8_TARGET_ARCH_X64)
35
+
36
+ #include "disasm.h"
37
+
38
+ namespace disasm {
39
+
40
+ enum OperandType {
41
+ UNSET_OP_ORDER = 0,
42
+ // Operand size decides between 16, 32 and 64 bit operands.
43
+ REG_OPER_OP_ORDER = 1, // Register destination, operand source.
44
+ OPER_REG_OP_ORDER = 2, // Operand destination, register source.
45
+ // Fixed 8-bit operands.
46
+ BYTE_SIZE_OPERAND_FLAG = 4,
47
+ BYTE_REG_OPER_OP_ORDER = REG_OPER_OP_ORDER | BYTE_SIZE_OPERAND_FLAG,
48
+ BYTE_OPER_REG_OP_ORDER = OPER_REG_OP_ORDER | BYTE_SIZE_OPERAND_FLAG
49
+ };
50
+
51
+ //------------------------------------------------------------------
52
+ // Tables
53
+ //------------------------------------------------------------------
54
+ struct ByteMnemonic {
55
+ int b; // -1 terminates, otherwise must be in range (0..255)
56
+ OperandType op_order_;
57
+ const char* mnem;
58
+ };
59
+
60
+
61
+ static ByteMnemonic two_operands_instr[] = {
62
+ { 0x00, BYTE_OPER_REG_OP_ORDER, "add" },
63
+ { 0x01, OPER_REG_OP_ORDER, "add" },
64
+ { 0x02, BYTE_REG_OPER_OP_ORDER, "add" },
65
+ { 0x03, REG_OPER_OP_ORDER, "add" },
66
+ { 0x08, BYTE_OPER_REG_OP_ORDER, "or" },
67
+ { 0x09, OPER_REG_OP_ORDER, "or" },
68
+ { 0x0A, BYTE_REG_OPER_OP_ORDER, "or" },
69
+ { 0x0B, REG_OPER_OP_ORDER, "or" },
70
+ { 0x10, BYTE_OPER_REG_OP_ORDER, "adc" },
71
+ { 0x11, OPER_REG_OP_ORDER, "adc" },
72
+ { 0x12, BYTE_REG_OPER_OP_ORDER, "adc" },
73
+ { 0x13, REG_OPER_OP_ORDER, "adc" },
74
+ { 0x18, BYTE_OPER_REG_OP_ORDER, "sbb" },
75
+ { 0x19, OPER_REG_OP_ORDER, "sbb" },
76
+ { 0x1A, BYTE_REG_OPER_OP_ORDER, "sbb" },
77
+ { 0x1B, REG_OPER_OP_ORDER, "sbb" },
78
+ { 0x20, BYTE_OPER_REG_OP_ORDER, "and" },
79
+ { 0x21, OPER_REG_OP_ORDER, "and" },
80
+ { 0x22, BYTE_REG_OPER_OP_ORDER, "and" },
81
+ { 0x23, REG_OPER_OP_ORDER, "and" },
82
+ { 0x28, BYTE_OPER_REG_OP_ORDER, "sub" },
83
+ { 0x29, OPER_REG_OP_ORDER, "sub" },
84
+ { 0x2A, BYTE_REG_OPER_OP_ORDER, "sub" },
85
+ { 0x2B, REG_OPER_OP_ORDER, "sub" },
86
+ { 0x30, BYTE_OPER_REG_OP_ORDER, "xor" },
87
+ { 0x31, OPER_REG_OP_ORDER, "xor" },
88
+ { 0x32, BYTE_REG_OPER_OP_ORDER, "xor" },
89
+ { 0x33, REG_OPER_OP_ORDER, "xor" },
90
+ { 0x38, BYTE_OPER_REG_OP_ORDER, "cmp" },
91
+ { 0x39, OPER_REG_OP_ORDER, "cmp" },
92
+ { 0x3A, BYTE_REG_OPER_OP_ORDER, "cmp" },
93
+ { 0x3B, REG_OPER_OP_ORDER, "cmp" },
94
+ { 0x63, REG_OPER_OP_ORDER, "movsxlq" },
95
+ { 0x84, BYTE_REG_OPER_OP_ORDER, "test" },
96
+ { 0x85, REG_OPER_OP_ORDER, "test" },
97
+ { 0x86, BYTE_REG_OPER_OP_ORDER, "xchg" },
98
+ { 0x87, REG_OPER_OP_ORDER, "xchg" },
99
+ { 0x88, BYTE_OPER_REG_OP_ORDER, "mov" },
100
+ { 0x89, OPER_REG_OP_ORDER, "mov" },
101
+ { 0x8A, BYTE_REG_OPER_OP_ORDER, "mov" },
102
+ { 0x8B, REG_OPER_OP_ORDER, "mov" },
103
+ { 0x8D, REG_OPER_OP_ORDER, "lea" },
104
+ { -1, UNSET_OP_ORDER, "" }
105
+ };
106
+
107
+
108
+ static ByteMnemonic zero_operands_instr[] = {
109
+ { 0xC3, UNSET_OP_ORDER, "ret" },
110
+ { 0xC9, UNSET_OP_ORDER, "leave" },
111
+ { 0xF4, UNSET_OP_ORDER, "hlt" },
112
+ { 0xCC, UNSET_OP_ORDER, "int3" },
113
+ { 0x60, UNSET_OP_ORDER, "pushad" },
114
+ { 0x61, UNSET_OP_ORDER, "popad" },
115
+ { 0x9C, UNSET_OP_ORDER, "pushfd" },
116
+ { 0x9D, UNSET_OP_ORDER, "popfd" },
117
+ { 0x9E, UNSET_OP_ORDER, "sahf" },
118
+ { 0x99, UNSET_OP_ORDER, "cdq" },
119
+ { 0x9B, UNSET_OP_ORDER, "fwait" },
120
+ { 0xA4, UNSET_OP_ORDER, "movs" },
121
+ { 0xA5, UNSET_OP_ORDER, "movs" },
122
+ { 0xA6, UNSET_OP_ORDER, "cmps" },
123
+ { 0xA7, UNSET_OP_ORDER, "cmps" },
124
+ { -1, UNSET_OP_ORDER, "" }
125
+ };
126
+
127
+
128
+ static ByteMnemonic call_jump_instr[] = {
129
+ { 0xE8, UNSET_OP_ORDER, "call" },
130
+ { 0xE9, UNSET_OP_ORDER, "jmp" },
131
+ { -1, UNSET_OP_ORDER, "" }
132
+ };
133
+
134
+
135
+ static ByteMnemonic short_immediate_instr[] = {
136
+ { 0x05, UNSET_OP_ORDER, "add" },
137
+ { 0x0D, UNSET_OP_ORDER, "or" },
138
+ { 0x15, UNSET_OP_ORDER, "adc" },
139
+ { 0x1D, UNSET_OP_ORDER, "sbb" },
140
+ { 0x25, UNSET_OP_ORDER, "and" },
141
+ { 0x2D, UNSET_OP_ORDER, "sub" },
142
+ { 0x35, UNSET_OP_ORDER, "xor" },
143
+ { 0x3D, UNSET_OP_ORDER, "cmp" },
144
+ { -1, UNSET_OP_ORDER, "" }
145
+ };
146
+
147
+
148
+ static const char* conditional_code_suffix[] = {
149
+ "o", "no", "c", "nc", "z", "nz", "na", "a",
150
+ "s", "ns", "pe", "po", "l", "ge", "le", "g"
151
+ };
152
+
153
+
154
+ enum InstructionType {
155
+ NO_INSTR,
156
+ ZERO_OPERANDS_INSTR,
157
+ TWO_OPERANDS_INSTR,
158
+ JUMP_CONDITIONAL_SHORT_INSTR,
159
+ REGISTER_INSTR,
160
+ PUSHPOP_INSTR, // Has implicit 64-bit operand size.
161
+ MOVE_REG_INSTR,
162
+ CALL_JUMP_INSTR,
163
+ SHORT_IMMEDIATE_INSTR
164
+ };
165
+
166
+
167
+ enum Prefixes {
168
+ ESCAPE_PREFIX = 0x0F,
169
+ OPERAND_SIZE_OVERRIDE_PREFIX = 0x66,
170
+ ADDRESS_SIZE_OVERRIDE_PREFIX = 0x67,
171
+ REPNE_PREFIX = 0xF2,
172
+ REP_PREFIX = 0xF3,
173
+ REPEQ_PREFIX = REP_PREFIX
174
+ };
175
+
176
+
177
+ struct InstructionDesc {
178
+ const char* mnem;
179
+ InstructionType type;
180
+ OperandType op_order_;
181
+ bool byte_size_operation; // Fixed 8-bit operation.
182
+ };
183
+
184
+
185
+ class InstructionTable {
186
+ public:
187
+ InstructionTable();
188
+ const InstructionDesc& Get(byte x) const {
189
+ return instructions_[x];
190
+ }
191
+
192
+ private:
193
+ InstructionDesc instructions_[256];
194
+ void Clear();
195
+ void Init();
196
+ void CopyTable(ByteMnemonic bm[], InstructionType type);
197
+ void SetTableRange(InstructionType type, byte start, byte end, bool byte_size,
198
+ const char* mnem);
199
+ void AddJumpConditionalShort();
200
+ };
201
+
202
+
203
+ InstructionTable::InstructionTable() {
204
+ Clear();
205
+ Init();
206
+ }
207
+
208
+
209
+ void InstructionTable::Clear() {
210
+ for (int i = 0; i < 256; i++) {
211
+ instructions_[i].mnem = "(bad)";
212
+ instructions_[i].type = NO_INSTR;
213
+ instructions_[i].op_order_ = UNSET_OP_ORDER;
214
+ instructions_[i].byte_size_operation = false;
215
+ }
216
+ }
217
+
218
+
219
+ void InstructionTable::Init() {
220
+ CopyTable(two_operands_instr, TWO_OPERANDS_INSTR);
221
+ CopyTable(zero_operands_instr, ZERO_OPERANDS_INSTR);
222
+ CopyTable(call_jump_instr, CALL_JUMP_INSTR);
223
+ CopyTable(short_immediate_instr, SHORT_IMMEDIATE_INSTR);
224
+ AddJumpConditionalShort();
225
+ SetTableRange(PUSHPOP_INSTR, 0x50, 0x57, false, "push");
226
+ SetTableRange(PUSHPOP_INSTR, 0x58, 0x5F, false, "pop");
227
+ SetTableRange(MOVE_REG_INSTR, 0xB8, 0xBF, false, "mov");
228
+ }
229
+
230
+
231
+ void InstructionTable::CopyTable(ByteMnemonic bm[], InstructionType type) {
232
+ for (int i = 0; bm[i].b >= 0; i++) {
233
+ InstructionDesc* id = &instructions_[bm[i].b];
234
+ id->mnem = bm[i].mnem;
235
+ OperandType op_order = bm[i].op_order_;
236
+ id->op_order_ =
237
+ static_cast<OperandType>(op_order & ~BYTE_SIZE_OPERAND_FLAG);
238
+ ASSERT_EQ(NO_INSTR, id->type); // Information not already entered
239
+ id->type = type;
240
+ id->byte_size_operation = ((op_order & BYTE_SIZE_OPERAND_FLAG) != 0);
241
+ }
242
+ }
243
+
244
+
245
+ void InstructionTable::SetTableRange(InstructionType type,
246
+ byte start,
247
+ byte end,
248
+ bool byte_size,
249
+ const char* mnem) {
250
+ for (byte b = start; b <= end; b++) {
251
+ InstructionDesc* id = &instructions_[b];
252
+ ASSERT_EQ(NO_INSTR, id->type); // Information not already entered
253
+ id->mnem = mnem;
254
+ id->type = type;
255
+ id->byte_size_operation = byte_size;
256
+ }
257
+ }
258
+
259
+
260
+ void InstructionTable::AddJumpConditionalShort() {
261
+ for (byte b = 0x70; b <= 0x7F; b++) {
262
+ InstructionDesc* id = &instructions_[b];
263
+ ASSERT_EQ(NO_INSTR, id->type); // Information not already entered
264
+ id->mnem = NULL; // Computed depending on condition code.
265
+ id->type = JUMP_CONDITIONAL_SHORT_INSTR;
266
+ }
267
+ }
268
+
269
+
270
+ static InstructionTable instruction_table;
271
+
272
+ static InstructionDesc cmov_instructions[16] = {
273
+ {"cmovo", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
274
+ {"cmovno", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
275
+ {"cmovc", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
276
+ {"cmovnc", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
277
+ {"cmovz", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
278
+ {"cmovnz", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
279
+ {"cmovna", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
280
+ {"cmova", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
281
+ {"cmovs", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
282
+ {"cmovns", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
283
+ {"cmovpe", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
284
+ {"cmovpo", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
285
+ {"cmovl", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
286
+ {"cmovge", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
287
+ {"cmovle", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false},
288
+ {"cmovg", TWO_OPERANDS_INSTR, REG_OPER_OP_ORDER, false}
289
+ };
290
+
291
+ //------------------------------------------------------------------------------
292
+ // DisassemblerX64 implementation.
293
+
294
+ enum UnimplementedOpcodeAction {
295
+ CONTINUE_ON_UNIMPLEMENTED_OPCODE,
296
+ ABORT_ON_UNIMPLEMENTED_OPCODE
297
+ };
298
+
299
+ // A new DisassemblerX64 object is created to disassemble each instruction.
300
+ // The object can only disassemble a single instruction.
301
+ class DisassemblerX64 {
302
+ public:
303
+ DisassemblerX64(const NameConverter& converter,
304
+ UnimplementedOpcodeAction unimplemented_action =
305
+ ABORT_ON_UNIMPLEMENTED_OPCODE)
306
+ : converter_(converter),
307
+ tmp_buffer_pos_(0),
308
+ abort_on_unimplemented_(
309
+ unimplemented_action == ABORT_ON_UNIMPLEMENTED_OPCODE),
310
+ rex_(0),
311
+ operand_size_(0),
312
+ group_1_prefix_(0),
313
+ byte_size_operand_(false) {
314
+ tmp_buffer_[0] = '\0';
315
+ }
316
+
317
+ virtual ~DisassemblerX64() {
318
+ }
319
+
320
+ // Writes one disassembled instruction into 'buffer' (0-terminated).
321
+ // Returns the length of the disassembled machine instruction in bytes.
322
+ int InstructionDecode(v8::internal::Vector<char> buffer, byte* instruction);
323
+
324
+ private:
325
+ enum OperandSize {
326
+ BYTE_SIZE = 0,
327
+ WORD_SIZE = 1,
328
+ DOUBLEWORD_SIZE = 2,
329
+ QUADWORD_SIZE = 3
330
+ };
331
+
332
+ const NameConverter& converter_;
333
+ v8::internal::EmbeddedVector<char, 128> tmp_buffer_;
334
+ unsigned int tmp_buffer_pos_;
335
+ bool abort_on_unimplemented_;
336
+ // Prefixes parsed
337
+ byte rex_;
338
+ byte operand_size_; // 0x66 or (if no group 3 prefix is present) 0x0.
339
+ byte group_1_prefix_; // 0xF2, 0xF3, or (if no group 1 prefix is present) 0.
340
+ // Byte size operand override.
341
+ bool byte_size_operand_;
342
+
343
+ void setRex(byte rex) {
344
+ ASSERT_EQ(0x40, rex & 0xF0);
345
+ rex_ = rex;
346
+ }
347
+
348
+ bool rex() { return rex_ != 0; }
349
+
350
+ bool rex_b() { return (rex_ & 0x01) != 0; }
351
+
352
+ // Actual number of base register given the low bits and the rex.b state.
353
+ int base_reg(int low_bits) { return low_bits | ((rex_ & 0x01) << 3); }
354
+
355
+ bool rex_x() { return (rex_ & 0x02) != 0; }
356
+
357
+ bool rex_r() { return (rex_ & 0x04) != 0; }
358
+
359
+ bool rex_w() { return (rex_ & 0x08) != 0; }
360
+
361
+ OperandSize operand_size() {
362
+ if (byte_size_operand_) return BYTE_SIZE;
363
+ if (rex_w()) return QUADWORD_SIZE;
364
+ if (operand_size_ != 0) return WORD_SIZE;
365
+ return DOUBLEWORD_SIZE;
366
+ }
367
+
368
+ char operand_size_code() {
369
+ return "bwlq"[operand_size()];
370
+ }
371
+
372
+ const char* NameOfCPURegister(int reg) const {
373
+ return converter_.NameOfCPURegister(reg);
374
+ }
375
+
376
+ const char* NameOfByteCPURegister(int reg) const {
377
+ return converter_.NameOfByteCPURegister(reg);
378
+ }
379
+
380
+ const char* NameOfXMMRegister(int reg) const {
381
+ return converter_.NameOfXMMRegister(reg);
382
+ }
383
+
384
+ const char* NameOfAddress(byte* addr) const {
385
+ return converter_.NameOfAddress(addr);
386
+ }
387
+
388
+ // Disassembler helper functions.
389
+ void get_modrm(byte data,
390
+ int* mod,
391
+ int* regop,
392
+ int* rm) {
393
+ *mod = (data >> 6) & 3;
394
+ *regop = ((data & 0x38) >> 3) | (rex_r() ? 8 : 0);
395
+ *rm = (data & 7) | (rex_b() ? 8 : 0);
396
+ }
397
+
398
+ void get_sib(byte data,
399
+ int* scale,
400
+ int* index,
401
+ int* base) {
402
+ *scale = (data >> 6) & 3;
403
+ *index = ((data >> 3) & 7) | (rex_x() ? 8 : 0);
404
+ *base = (data & 7) | (rex_b() ? 8 : 0);
405
+ }
406
+
407
+ typedef const char* (DisassemblerX64::*RegisterNameMapping)(int reg) const;
408
+
409
+ int PrintRightOperandHelper(byte* modrmp,
410
+ RegisterNameMapping register_name);
411
+ int PrintRightOperand(byte* modrmp);
412
+ int PrintRightByteOperand(byte* modrmp);
413
+ int PrintRightXMMOperand(byte* modrmp);
414
+ int PrintOperands(const char* mnem,
415
+ OperandType op_order,
416
+ byte* data);
417
+ int PrintImmediate(byte* data, OperandSize size);
418
+ int PrintImmediateOp(byte* data);
419
+ const char* TwoByteMnemonic(byte opcode);
420
+ int TwoByteOpcodeInstruction(byte* data);
421
+ int F6F7Instruction(byte* data);
422
+ int ShiftInstruction(byte* data);
423
+ int JumpShort(byte* data);
424
+ int JumpConditional(byte* data);
425
+ int JumpConditionalShort(byte* data);
426
+ int SetCC(byte* data);
427
+ int FPUInstruction(byte* data);
428
+ int MemoryFPUInstruction(int escape_opcode, int regop, byte* modrm_start);
429
+ int RegisterFPUInstruction(int escape_opcode, byte modrm_byte);
430
+ void AppendToBuffer(const char* format, ...);
431
+
432
+ void UnimplementedInstruction() {
433
+ if (abort_on_unimplemented_) {
434
+ CHECK(false);
435
+ } else {
436
+ AppendToBuffer("'Unimplemented Instruction'");
437
+ }
438
+ }
439
+ };
440
+
441
+
442
+ void DisassemblerX64::AppendToBuffer(const char* format, ...) {
443
+ v8::internal::Vector<char> buf = tmp_buffer_ + tmp_buffer_pos_;
444
+ va_list args;
445
+ va_start(args, format);
446
+ int result = v8::internal::OS::VSNPrintF(buf, format, args);
447
+ va_end(args);
448
+ tmp_buffer_pos_ += result;
449
+ }
450
+
451
+
452
+ int DisassemblerX64::PrintRightOperandHelper(
453
+ byte* modrmp,
454
+ RegisterNameMapping register_name) {
455
+ int mod, regop, rm;
456
+ get_modrm(*modrmp, &mod, &regop, &rm);
457
+ switch (mod) {
458
+ case 0:
459
+ if ((rm & 7) == 5) {
460
+ int32_t disp = *reinterpret_cast<int32_t*>(modrmp + 1);
461
+ AppendToBuffer("[0x%x]", disp);
462
+ return 5;
463
+ } else if ((rm & 7) == 4) {
464
+ // Codes for SIB byte.
465
+ byte sib = *(modrmp + 1);
466
+ int scale, index, base;
467
+ get_sib(sib, &scale, &index, &base);
468
+ if (index == 4 && (base & 7) == 4 && scale == 0 /*times_1*/) {
469
+ // index == rsp means no index. Only use sib byte with no index for
470
+ // rsp and r12 base.
471
+ AppendToBuffer("[%s]", NameOfCPURegister(base));
472
+ return 2;
473
+ } else if (base == 5) {
474
+ // base == rbp means no base register (when mod == 0).
475
+ int32_t disp = *reinterpret_cast<int32_t*>(modrmp + 2);
476
+ AppendToBuffer("[%s*%d+0x%x]",
477
+ NameOfCPURegister(index),
478
+ 1 << scale, disp);
479
+ return 6;
480
+ } else if (index != 4 && base != 5) {
481
+ // [base+index*scale]
482
+ AppendToBuffer("[%s+%s*%d]",
483
+ NameOfCPURegister(base),
484
+ NameOfCPURegister(index),
485
+ 1 << scale);
486
+ return 2;
487
+ } else {
488
+ UnimplementedInstruction();
489
+ return 1;
490
+ }
491
+ } else {
492
+ AppendToBuffer("[%s]", NameOfCPURegister(rm));
493
+ return 1;
494
+ }
495
+ break;
496
+ case 1: // fall through
497
+ case 2:
498
+ if ((rm & 7) == 4) {
499
+ byte sib = *(modrmp + 1);
500
+ int scale, index, base;
501
+ get_sib(sib, &scale, &index, &base);
502
+ int disp = (mod == 2) ? *reinterpret_cast<int32_t*>(modrmp + 2)
503
+ : *reinterpret_cast<char*>(modrmp + 2);
504
+ if (index == 4 && (base & 7) == 4 && scale == 0 /*times_1*/) {
505
+ if (-disp > 0) {
506
+ AppendToBuffer("[%s-0x%x]", NameOfCPURegister(base), -disp);
507
+ } else {
508
+ AppendToBuffer("[%s+0x%x]", NameOfCPURegister(base), disp);
509
+ }
510
+ } else {
511
+ if (-disp > 0) {
512
+ AppendToBuffer("[%s+%s*%d-0x%x]",
513
+ NameOfCPURegister(base),
514
+ NameOfCPURegister(index),
515
+ 1 << scale,
516
+ -disp);
517
+ } else {
518
+ AppendToBuffer("[%s+%s*%d+0x%x]",
519
+ NameOfCPURegister(base),
520
+ NameOfCPURegister(index),
521
+ 1 << scale,
522
+ disp);
523
+ }
524
+ }
525
+ return mod == 2 ? 6 : 3;
526
+ } else {
527
+ // No sib.
528
+ int disp = (mod == 2) ? *reinterpret_cast<int32_t*>(modrmp + 1)
529
+ : *reinterpret_cast<char*>(modrmp + 1);
530
+ if (-disp > 0) {
531
+ AppendToBuffer("[%s-0x%x]", NameOfCPURegister(rm), -disp);
532
+ } else {
533
+ AppendToBuffer("[%s+0x%x]", NameOfCPURegister(rm), disp);
534
+ }
535
+ return (mod == 2) ? 5 : 2;
536
+ }
537
+ break;
538
+ case 3:
539
+ AppendToBuffer("%s", (this->*register_name)(rm));
540
+ return 1;
541
+ default:
542
+ UnimplementedInstruction();
543
+ return 1;
544
+ }
545
+ UNREACHABLE();
546
+ }
547
+
548
+
549
+ int DisassemblerX64::PrintImmediate(byte* data, OperandSize size) {
550
+ int64_t value;
551
+ int count;
552
+ switch (size) {
553
+ case BYTE_SIZE:
554
+ value = *data;
555
+ count = 1;
556
+ break;
557
+ case WORD_SIZE:
558
+ value = *reinterpret_cast<int16_t*>(data);
559
+ count = 2;
560
+ break;
561
+ case DOUBLEWORD_SIZE:
562
+ value = *reinterpret_cast<uint32_t*>(data);
563
+ count = 4;
564
+ break;
565
+ case QUADWORD_SIZE:
566
+ value = *reinterpret_cast<int32_t*>(data);
567
+ count = 4;
568
+ break;
569
+ default:
570
+ UNREACHABLE();
571
+ value = 0; // Initialize variables on all paths to satisfy the compiler.
572
+ count = 0;
573
+ }
574
+ AppendToBuffer("%" V8_PTR_PREFIX "x", value);
575
+ return count;
576
+ }
577
+
578
+
579
+ int DisassemblerX64::PrintRightOperand(byte* modrmp) {
580
+ return PrintRightOperandHelper(modrmp,
581
+ &DisassemblerX64::NameOfCPURegister);
582
+ }
583
+
584
+
585
+ int DisassemblerX64::PrintRightByteOperand(byte* modrmp) {
586
+ return PrintRightOperandHelper(modrmp,
587
+ &DisassemblerX64::NameOfByteCPURegister);
588
+ }
589
+
590
+
591
+ int DisassemblerX64::PrintRightXMMOperand(byte* modrmp) {
592
+ return PrintRightOperandHelper(modrmp,
593
+ &DisassemblerX64::NameOfXMMRegister);
594
+ }
595
+
596
+
597
+ // Returns number of bytes used including the current *data.
598
+ // Writes instruction's mnemonic, left and right operands to 'tmp_buffer_'.
599
+ int DisassemblerX64::PrintOperands(const char* mnem,
600
+ OperandType op_order,
601
+ byte* data) {
602
+ byte modrm = *data;
603
+ int mod, regop, rm;
604
+ get_modrm(modrm, &mod, &regop, &rm);
605
+ int advance = 0;
606
+ const char* register_name =
607
+ byte_size_operand_ ? NameOfByteCPURegister(regop)
608
+ : NameOfCPURegister(regop);
609
+ switch (op_order) {
610
+ case REG_OPER_OP_ORDER: {
611
+ AppendToBuffer("%s%c %s,",
612
+ mnem,
613
+ operand_size_code(),
614
+ register_name);
615
+ advance = byte_size_operand_ ? PrintRightByteOperand(data)
616
+ : PrintRightOperand(data);
617
+ break;
618
+ }
619
+ case OPER_REG_OP_ORDER: {
620
+ AppendToBuffer("%s%c ", mnem, operand_size_code());
621
+ advance = byte_size_operand_ ? PrintRightByteOperand(data)
622
+ : PrintRightOperand(data);
623
+ AppendToBuffer(",%s", register_name);
624
+ break;
625
+ }
626
+ default:
627
+ UNREACHABLE();
628
+ break;
629
+ }
630
+ return advance;
631
+ }
632
+
633
+
634
+ // Returns number of bytes used by machine instruction, including *data byte.
635
+ // Writes immediate instructions to 'tmp_buffer_'.
636
+ int DisassemblerX64::PrintImmediateOp(byte* data) {
637
+ bool byte_size_immediate = (*data & 0x02) != 0;
638
+ byte modrm = *(data + 1);
639
+ int mod, regop, rm;
640
+ get_modrm(modrm, &mod, &regop, &rm);
641
+ const char* mnem = "Imm???";
642
+ switch (regop) {
643
+ case 0:
644
+ mnem = "add";
645
+ break;
646
+ case 1:
647
+ mnem = "or";
648
+ break;
649
+ case 2:
650
+ mnem = "adc";
651
+ break;
652
+ case 4:
653
+ mnem = "and";
654
+ break;
655
+ case 5:
656
+ mnem = "sub";
657
+ break;
658
+ case 6:
659
+ mnem = "xor";
660
+ break;
661
+ case 7:
662
+ mnem = "cmp";
663
+ break;
664
+ default:
665
+ UnimplementedInstruction();
666
+ }
667
+ AppendToBuffer("%s%c ", mnem, operand_size_code());
668
+ int count = PrintRightOperand(data + 1);
669
+ AppendToBuffer(",0x");
670
+ OperandSize immediate_size = byte_size_immediate ? BYTE_SIZE : operand_size();
671
+ count += PrintImmediate(data + 1 + count, immediate_size);
672
+ return 1 + count;
673
+ }
674
+
675
+
676
+ // Returns number of bytes used, including *data.
677
+ int DisassemblerX64::F6F7Instruction(byte* data) {
678
+ ASSERT(*data == 0xF7 || *data == 0xF6);
679
+ byte modrm = *(data + 1);
680
+ int mod, regop, rm;
681
+ get_modrm(modrm, &mod, &regop, &rm);
682
+ if (mod == 3 && regop != 0) {
683
+ const char* mnem = NULL;
684
+ switch (regop) {
685
+ case 2:
686
+ mnem = "not";
687
+ break;
688
+ case 3:
689
+ mnem = "neg";
690
+ break;
691
+ case 4:
692
+ mnem = "mul";
693
+ break;
694
+ case 7:
695
+ mnem = "idiv";
696
+ break;
697
+ default:
698
+ UnimplementedInstruction();
699
+ }
700
+ AppendToBuffer("%s%c %s",
701
+ mnem,
702
+ operand_size_code(),
703
+ NameOfCPURegister(rm));
704
+ return 2;
705
+ } else if (regop == 0) {
706
+ AppendToBuffer("test%c ", operand_size_code());
707
+ int count = PrintRightOperand(data + 1); // Use name of 64-bit register.
708
+ AppendToBuffer(",0x");
709
+ count += PrintImmediate(data + 1 + count, operand_size());
710
+ return 1 + count;
711
+ } else {
712
+ UnimplementedInstruction();
713
+ return 2;
714
+ }
715
+ }
716
+
717
+
718
+ int DisassemblerX64::ShiftInstruction(byte* data) {
719
+ byte op = *data & (~1);
720
+ if (op != 0xD0 && op != 0xD2 && op != 0xC0) {
721
+ UnimplementedInstruction();
722
+ return 1;
723
+ }
724
+ byte modrm = *(data + 1);
725
+ int mod, regop, rm;
726
+ get_modrm(modrm, &mod, &regop, &rm);
727
+ regop &= 0x7; // The REX.R bit does not affect the operation.
728
+ int imm8 = -1;
729
+ int num_bytes = 2;
730
+ if (mod != 3) {
731
+ UnimplementedInstruction();
732
+ return num_bytes;
733
+ }
734
+ const char* mnem = NULL;
735
+ switch (regop) {
736
+ case 0:
737
+ mnem = "rol";
738
+ break;
739
+ case 1:
740
+ mnem = "ror";
741
+ break;
742
+ case 2:
743
+ mnem = "rcl";
744
+ break;
745
+ case 3:
746
+ mnem = "rcr";
747
+ break;
748
+ case 4:
749
+ mnem = "shl";
750
+ break;
751
+ case 5:
752
+ mnem = "shr";
753
+ break;
754
+ case 7:
755
+ mnem = "sar";
756
+ break;
757
+ default:
758
+ UnimplementedInstruction();
759
+ return num_bytes;
760
+ }
761
+ ASSERT_NE(NULL, mnem);
762
+ if (op == 0xD0) {
763
+ imm8 = 1;
764
+ } else if (op == 0xC0) {
765
+ imm8 = *(data + 2);
766
+ num_bytes = 3;
767
+ }
768
+ AppendToBuffer("%s%c %s,",
769
+ mnem,
770
+ operand_size_code(),
771
+ byte_size_operand_ ? NameOfByteCPURegister(rm)
772
+ : NameOfCPURegister(rm));
773
+ if (op == 0xD2) {
774
+ AppendToBuffer("cl");
775
+ } else {
776
+ AppendToBuffer("%d", imm8);
777
+ }
778
+ return num_bytes;
779
+ }
780
+
781
+
782
+ // Returns number of bytes used, including *data.
783
+ int DisassemblerX64::JumpShort(byte* data) {
784
+ ASSERT_EQ(0xEB, *data);
785
+ byte b = *(data + 1);
786
+ byte* dest = data + static_cast<int8_t>(b) + 2;
787
+ AppendToBuffer("jmp %s", NameOfAddress(dest));
788
+ return 2;
789
+ }
790
+
791
+
792
+ // Returns number of bytes used, including *data.
793
+ int DisassemblerX64::JumpConditional(byte* data) {
794
+ ASSERT_EQ(0x0F, *data);
795
+ byte cond = *(data + 1) & 0x0F;
796
+ byte* dest = data + *reinterpret_cast<int32_t*>(data + 2) + 6;
797
+ const char* mnem = conditional_code_suffix[cond];
798
+ AppendToBuffer("j%s %s", mnem, NameOfAddress(dest));
799
+ return 6; // includes 0x0F
800
+ }
801
+
802
+
803
+ // Returns number of bytes used, including *data.
804
+ int DisassemblerX64::JumpConditionalShort(byte* data) {
805
+ byte cond = *data & 0x0F;
806
+ byte b = *(data + 1);
807
+ byte* dest = data + static_cast<int8_t>(b) + 2;
808
+ const char* mnem = conditional_code_suffix[cond];
809
+ AppendToBuffer("j%s %s", mnem, NameOfAddress(dest));
810
+ return 2;
811
+ }
812
+
813
+
814
+ // Returns number of bytes used, including *data.
815
+ int DisassemblerX64::SetCC(byte* data) {
816
+ ASSERT_EQ(0x0F, *data);
817
+ byte cond = *(data + 1) & 0x0F;
818
+ const char* mnem = conditional_code_suffix[cond];
819
+ AppendToBuffer("set%s%c ", mnem, operand_size_code());
820
+ PrintRightByteOperand(data + 2);
821
+ return 3; // includes 0x0F
822
+ }
823
+
824
+
825
+ // Returns number of bytes used, including *data.
826
+ int DisassemblerX64::FPUInstruction(byte* data) {
827
+ byte escape_opcode = *data;
828
+ ASSERT_EQ(0xD8, escape_opcode & 0xF8);
829
+ byte modrm_byte = *(data+1);
830
+
831
+ if (modrm_byte >= 0xC0) {
832
+ return RegisterFPUInstruction(escape_opcode, modrm_byte);
833
+ } else {
834
+ return MemoryFPUInstruction(escape_opcode, modrm_byte, data+1);
835
+ }
836
+ }
837
+
838
+ int DisassemblerX64::MemoryFPUInstruction(int escape_opcode,
839
+ int modrm_byte,
840
+ byte* modrm_start) {
841
+ const char* mnem = "?";
842
+ int regop = (modrm_byte >> 3) & 0x7; // reg/op field of modrm byte.
843
+ switch (escape_opcode) {
844
+ case 0xD9: switch (regop) {
845
+ case 0: mnem = "fld_s"; break;
846
+ case 3: mnem = "fstp_s"; break;
847
+ case 7: mnem = "fstcw"; break;
848
+ default: UnimplementedInstruction();
849
+ }
850
+ break;
851
+
852
+ case 0xDB: switch (regop) {
853
+ case 0: mnem = "fild_s"; break;
854
+ case 1: mnem = "fisttp_s"; break;
855
+ case 2: mnem = "fist_s"; break;
856
+ case 3: mnem = "fistp_s"; break;
857
+ default: UnimplementedInstruction();
858
+ }
859
+ break;
860
+
861
+ case 0xDD: switch (regop) {
862
+ case 0: mnem = "fld_d"; break;
863
+ case 3: mnem = "fstp_d"; break;
864
+ default: UnimplementedInstruction();
865
+ }
866
+ break;
867
+
868
+ case 0xDF: switch (regop) {
869
+ case 5: mnem = "fild_d"; break;
870
+ case 7: mnem = "fistp_d"; break;
871
+ default: UnimplementedInstruction();
872
+ }
873
+ break;
874
+
875
+ default: UnimplementedInstruction();
876
+ }
877
+ AppendToBuffer("%s ", mnem);
878
+ int count = PrintRightOperand(modrm_start);
879
+ return count + 1;
880
+ }
881
+
882
+ int DisassemblerX64::RegisterFPUInstruction(int escape_opcode,
883
+ byte modrm_byte) {
884
+ bool has_register = false; // Is the FPU register encoded in modrm_byte?
885
+ const char* mnem = "?";
886
+
887
+ switch (escape_opcode) {
888
+ case 0xD8:
889
+ UnimplementedInstruction();
890
+ break;
891
+
892
+ case 0xD9:
893
+ switch (modrm_byte & 0xF8) {
894
+ case 0xC0:
895
+ mnem = "fld";
896
+ has_register = true;
897
+ break;
898
+ case 0xC8:
899
+ mnem = "fxch";
900
+ has_register = true;
901
+ break;
902
+ default:
903
+ switch (modrm_byte) {
904
+ case 0xE0: mnem = "fchs"; break;
905
+ case 0xE1: mnem = "fabs"; break;
906
+ case 0xE4: mnem = "ftst"; break;
907
+ case 0xE8: mnem = "fld1"; break;
908
+ case 0xEB: mnem = "fldpi"; break;
909
+ case 0xED: mnem = "fldln2"; break;
910
+ case 0xEE: mnem = "fldz"; break;
911
+ case 0xF1: mnem = "fyl2x"; break;
912
+ case 0xF5: mnem = "fprem1"; break;
913
+ case 0xF7: mnem = "fincstp"; break;
914
+ case 0xF8: mnem = "fprem"; break;
915
+ case 0xFE: mnem = "fsin"; break;
916
+ case 0xFF: mnem = "fcos"; break;
917
+ default: UnimplementedInstruction();
918
+ }
919
+ }
920
+ break;
921
+
922
+ case 0xDA:
923
+ if (modrm_byte == 0xE9) {
924
+ mnem = "fucompp";
925
+ } else {
926
+ UnimplementedInstruction();
927
+ }
928
+ break;
929
+
930
+ case 0xDB:
931
+ if ((modrm_byte & 0xF8) == 0xE8) {
932
+ mnem = "fucomi";
933
+ has_register = true;
934
+ } else if (modrm_byte == 0xE2) {
935
+ mnem = "fclex";
936
+ } else {
937
+ UnimplementedInstruction();
938
+ }
939
+ break;
940
+
941
+ case 0xDC:
942
+ has_register = true;
943
+ switch (modrm_byte & 0xF8) {
944
+ case 0xC0: mnem = "fadd"; break;
945
+ case 0xE8: mnem = "fsub"; break;
946
+ case 0xC8: mnem = "fmul"; break;
947
+ case 0xF8: mnem = "fdiv"; break;
948
+ default: UnimplementedInstruction();
949
+ }
950
+ break;
951
+
952
+ case 0xDD:
953
+ has_register = true;
954
+ switch (modrm_byte & 0xF8) {
955
+ case 0xC0: mnem = "ffree"; break;
956
+ case 0xD8: mnem = "fstp"; break;
957
+ default: UnimplementedInstruction();
958
+ }
959
+ break;
960
+
961
+ case 0xDE:
962
+ if (modrm_byte == 0xD9) {
963
+ mnem = "fcompp";
964
+ } else {
965
+ has_register = true;
966
+ switch (modrm_byte & 0xF8) {
967
+ case 0xC0: mnem = "faddp"; break;
968
+ case 0xE8: mnem = "fsubp"; break;
969
+ case 0xC8: mnem = "fmulp"; break;
970
+ case 0xF8: mnem = "fdivp"; break;
971
+ default: UnimplementedInstruction();
972
+ }
973
+ }
974
+ break;
975
+
976
+ case 0xDF:
977
+ if (modrm_byte == 0xE0) {
978
+ mnem = "fnstsw_ax";
979
+ } else if ((modrm_byte & 0xF8) == 0xE8) {
980
+ mnem = "fucomip";
981
+ has_register = true;
982
+ }
983
+ break;
984
+
985
+ default: UnimplementedInstruction();
986
+ }
987
+
988
+ if (has_register) {
989
+ AppendToBuffer("%s st%d", mnem, modrm_byte & 0x7);
990
+ } else {
991
+ AppendToBuffer("%s", mnem);
992
+ }
993
+ return 2;
994
+ }
995
+
996
+
997
+
998
+ // Handle all two-byte opcodes, which start with 0x0F.
999
+ // These instructions may be affected by an 0x66, 0xF2, or 0xF3 prefix.
1000
+ // We do not use any three-byte opcodes, which start with 0x0F38 or 0x0F3A.
1001
+ int DisassemblerX64::TwoByteOpcodeInstruction(byte* data) {
1002
+ byte opcode = *(data + 1);
1003
+ byte* current = data + 2;
1004
+ // At return, "current" points to the start of the next instruction.
1005
+ const char* mnemonic = TwoByteMnemonic(opcode);
1006
+ if (operand_size_ == 0x66) {
1007
+ // 0x66 0x0F prefix.
1008
+ int mod, regop, rm;
1009
+ if (opcode == 0x3A) {
1010
+ byte third_byte = *current;
1011
+ current = data + 3;
1012
+ if (third_byte == 0x17) {
1013
+ get_modrm(*current, &mod, &regop, &rm);
1014
+ AppendToBuffer("extractps "); // reg/m32, xmm, imm8
1015
+ current += PrintRightOperand(current);
1016
+ AppendToBuffer(", %s, %d", NameOfCPURegister(regop), (*current) & 3);
1017
+ current += 1;
1018
+ } else {
1019
+ UnimplementedInstruction();
1020
+ }
1021
+ } else {
1022
+ get_modrm(*current, &mod, &regop, &rm);
1023
+ if (opcode == 0x6E) {
1024
+ AppendToBuffer("mov%c %s,",
1025
+ rex_w() ? 'q' : 'd',
1026
+ NameOfXMMRegister(regop));
1027
+ current += PrintRightOperand(current);
1028
+ } else if (opcode == 0x6F) {
1029
+ AppendToBuffer("movdqa %s,",
1030
+ NameOfXMMRegister(regop));
1031
+ current += PrintRightOperand(current);
1032
+ } else if (opcode == 0x7E) {
1033
+ AppendToBuffer("mov%c ",
1034
+ rex_w() ? 'q' : 'd');
1035
+ current += PrintRightOperand(current);
1036
+ AppendToBuffer(", %s", NameOfXMMRegister(regop));
1037
+ } else if (opcode == 0x7F) {
1038
+ AppendToBuffer("movdqa ");
1039
+ current += PrintRightOperand(current);
1040
+ AppendToBuffer(", %s", NameOfXMMRegister(regop));
1041
+ } else {
1042
+ const char* mnemonic = "?";
1043
+ if (opcode == 0x50) {
1044
+ mnemonic = "movmskpd";
1045
+ } else if (opcode == 0x54) {
1046
+ mnemonic = "andpd";
1047
+ } else if (opcode == 0x56) {
1048
+ mnemonic = "orpd";
1049
+ } else if (opcode == 0x57) {
1050
+ mnemonic = "xorpd";
1051
+ } else if (opcode == 0x2E) {
1052
+ mnemonic = "ucomisd";
1053
+ } else if (opcode == 0x2F) {
1054
+ mnemonic = "comisd";
1055
+ } else {
1056
+ UnimplementedInstruction();
1057
+ }
1058
+ AppendToBuffer("%s %s,", mnemonic, NameOfXMMRegister(regop));
1059
+ current += PrintRightXMMOperand(current);
1060
+ }
1061
+ }
1062
+ } else if (group_1_prefix_ == 0xF2) {
1063
+ // Beginning of instructions with prefix 0xF2.
1064
+
1065
+ if (opcode == 0x11 || opcode == 0x10) {
1066
+ // MOVSD: Move scalar double-precision fp to/from/between XMM registers.
1067
+ AppendToBuffer("movsd ");
1068
+ int mod, regop, rm;
1069
+ get_modrm(*current, &mod, &regop, &rm);
1070
+ if (opcode == 0x11) {
1071
+ current += PrintRightOperand(current);
1072
+ AppendToBuffer(",%s", NameOfXMMRegister(regop));
1073
+ } else {
1074
+ AppendToBuffer("%s,", NameOfXMMRegister(regop));
1075
+ current += PrintRightOperand(current);
1076
+ }
1077
+ } else if (opcode == 0x2A) {
1078
+ // CVTSI2SD: integer to XMM double conversion.
1079
+ int mod, regop, rm;
1080
+ get_modrm(*current, &mod, &regop, &rm);
1081
+ AppendToBuffer("%sd %s,", mnemonic, NameOfXMMRegister(regop));
1082
+ current += PrintRightOperand(current);
1083
+ } else if (opcode == 0x2C) {
1084
+ // CVTTSD2SI:
1085
+ // Convert with truncation scalar double-precision FP to integer.
1086
+ int mod, regop, rm;
1087
+ get_modrm(*current, &mod, &regop, &rm);
1088
+ AppendToBuffer("cvttsd2si%c %s,",
1089
+ operand_size_code(), NameOfCPURegister(regop));
1090
+ current += PrintRightXMMOperand(current);
1091
+ } else if (opcode == 0x2D) {
1092
+ // CVTSD2SI: Convert scalar double-precision FP to integer.
1093
+ int mod, regop, rm;
1094
+ get_modrm(*current, &mod, &regop, &rm);
1095
+ AppendToBuffer("cvtsd2si%c %s,",
1096
+ operand_size_code(), NameOfCPURegister(regop));
1097
+ current += PrintRightXMMOperand(current);
1098
+ } else if ((opcode & 0xF8) == 0x58 || opcode == 0x51) {
1099
+ // XMM arithmetic. Mnemonic was retrieved at the start of this function.
1100
+ int mod, regop, rm;
1101
+ get_modrm(*current, &mod, &regop, &rm);
1102
+ AppendToBuffer("%s %s,", mnemonic, NameOfXMMRegister(regop));
1103
+ current += PrintRightXMMOperand(current);
1104
+ } else {
1105
+ UnimplementedInstruction();
1106
+ }
1107
+ } else if (group_1_prefix_ == 0xF3) {
1108
+ // Instructions with prefix 0xF3.
1109
+ if (opcode == 0x11 || opcode == 0x10) {
1110
+ // MOVSS: Move scalar double-precision fp to/from/between XMM registers.
1111
+ AppendToBuffer("movss ");
1112
+ int mod, regop, rm;
1113
+ get_modrm(*current, &mod, &regop, &rm);
1114
+ if (opcode == 0x11) {
1115
+ current += PrintRightOperand(current);
1116
+ AppendToBuffer(",%s", NameOfXMMRegister(regop));
1117
+ } else {
1118
+ AppendToBuffer("%s,", NameOfXMMRegister(regop));
1119
+ current += PrintRightOperand(current);
1120
+ }
1121
+ } else if (opcode == 0x2A) {
1122
+ // CVTSI2SS: integer to XMM single conversion.
1123
+ int mod, regop, rm;
1124
+ get_modrm(*current, &mod, &regop, &rm);
1125
+ AppendToBuffer("%ss %s,", mnemonic, NameOfXMMRegister(regop));
1126
+ current += PrintRightOperand(current);
1127
+ } else if (opcode == 0x2C) {
1128
+ // CVTTSS2SI:
1129
+ // Convert with truncation scalar single-precision FP to dword integer.
1130
+ int mod, regop, rm;
1131
+ get_modrm(*current, &mod, &regop, &rm);
1132
+ AppendToBuffer("cvttss2si%c %s,",
1133
+ operand_size_code(), NameOfCPURegister(regop));
1134
+ current += PrintRightXMMOperand(current);
1135
+ } else if (opcode == 0x5A) {
1136
+ // CVTSS2SD:
1137
+ // Convert scalar single-precision FP to scalar double-precision FP.
1138
+ int mod, regop, rm;
1139
+ get_modrm(*current, &mod, &regop, &rm);
1140
+ AppendToBuffer("cvtss2sd %s,", NameOfXMMRegister(regop));
1141
+ current += PrintRightXMMOperand(current);
1142
+ } else {
1143
+ UnimplementedInstruction();
1144
+ }
1145
+ } else if (opcode == 0x1F) {
1146
+ // NOP
1147
+ int mod, regop, rm;
1148
+ get_modrm(*current, &mod, &regop, &rm);
1149
+ current++;
1150
+ if (regop == 4) { // SIB byte present.
1151
+ current++;
1152
+ }
1153
+ if (mod == 1) { // Byte displacement.
1154
+ current += 1;
1155
+ } else if (mod == 2) { // 32-bit displacement.
1156
+ current += 4;
1157
+ } // else no immediate displacement.
1158
+ AppendToBuffer("nop");
1159
+ } else if (opcode == 0xA2 || opcode == 0x31) {
1160
+ // RDTSC or CPUID
1161
+ AppendToBuffer("%s", mnemonic);
1162
+
1163
+ } else if ((opcode & 0xF0) == 0x40) {
1164
+ // CMOVcc: conditional move.
1165
+ int condition = opcode & 0x0F;
1166
+ const InstructionDesc& idesc = cmov_instructions[condition];
1167
+ byte_size_operand_ = idesc.byte_size_operation;
1168
+ current += PrintOperands(idesc.mnem, idesc.op_order_, current);
1169
+
1170
+ } else if ((opcode & 0xF0) == 0x80) {
1171
+ // Jcc: Conditional jump (branch).
1172
+ current = data + JumpConditional(data);
1173
+
1174
+ } else if (opcode == 0xBE || opcode == 0xBF || opcode == 0xB6 ||
1175
+ opcode == 0xB7 || opcode == 0xAF) {
1176
+ // Size-extending moves, IMUL.
1177
+ current += PrintOperands(mnemonic, REG_OPER_OP_ORDER, current);
1178
+
1179
+ } else if ((opcode & 0xF0) == 0x90) {
1180
+ // SETcc: Set byte on condition. Needs pointer to beginning of instruction.
1181
+ current = data + SetCC(data);
1182
+
1183
+ } else if (opcode == 0xAB || opcode == 0xA5 || opcode == 0xAD) {
1184
+ // SHLD, SHRD (double-precision shift), BTS (bit set).
1185
+ AppendToBuffer("%s ", mnemonic);
1186
+ int mod, regop, rm;
1187
+ get_modrm(*current, &mod, &regop, &rm);
1188
+ current += PrintRightOperand(current);
1189
+ if (opcode == 0xAB) {
1190
+ AppendToBuffer(",%s", NameOfCPURegister(regop));
1191
+ } else {
1192
+ AppendToBuffer(",%s,cl", NameOfCPURegister(regop));
1193
+ }
1194
+ } else {
1195
+ UnimplementedInstruction();
1196
+ }
1197
+ return static_cast<int>(current - data);
1198
+ }
1199
+
1200
+
1201
+ // Mnemonics for two-byte opcode instructions starting with 0x0F.
1202
+ // The argument is the second byte of the two-byte opcode.
1203
+ // Returns NULL if the instruction is not handled here.
1204
+ const char* DisassemblerX64::TwoByteMnemonic(byte opcode) {
1205
+ switch (opcode) {
1206
+ case 0x1F:
1207
+ return "nop";
1208
+ case 0x2A: // F2/F3 prefix.
1209
+ return "cvtsi2s";
1210
+ case 0x31:
1211
+ return "rdtsc";
1212
+ case 0x51: // F2 prefix.
1213
+ return "sqrtsd";
1214
+ case 0x58: // F2 prefix.
1215
+ return "addsd";
1216
+ case 0x59: // F2 prefix.
1217
+ return "mulsd";
1218
+ case 0x5C: // F2 prefix.
1219
+ return "subsd";
1220
+ case 0x5E: // F2 prefix.
1221
+ return "divsd";
1222
+ case 0xA2:
1223
+ return "cpuid";
1224
+ case 0xA5:
1225
+ return "shld";
1226
+ case 0xAB:
1227
+ return "bts";
1228
+ case 0xAD:
1229
+ return "shrd";
1230
+ case 0xAF:
1231
+ return "imul";
1232
+ case 0xB6:
1233
+ return "movzxb";
1234
+ case 0xB7:
1235
+ return "movzxw";
1236
+ case 0xBE:
1237
+ return "movsxb";
1238
+ case 0xBF:
1239
+ return "movsxw";
1240
+ default:
1241
+ return NULL;
1242
+ }
1243
+ }
1244
+
1245
+
1246
+ // Disassembles the instruction at instr, and writes it into out_buffer.
1247
+ int DisassemblerX64::InstructionDecode(v8::internal::Vector<char> out_buffer,
1248
+ byte* instr) {
1249
+ tmp_buffer_pos_ = 0; // starting to write as position 0
1250
+ byte* data = instr;
1251
+ bool processed = true; // Will be set to false if the current instruction
1252
+ // is not in 'instructions' table.
1253
+ byte current;
1254
+
1255
+ // Scan for prefixes.
1256
+ while (true) {
1257
+ current = *data;
1258
+ if (current == OPERAND_SIZE_OVERRIDE_PREFIX) { // Group 3 prefix.
1259
+ operand_size_ = current;
1260
+ } else if ((current & 0xF0) == 0x40) { // REX prefix.
1261
+ setRex(current);
1262
+ if (rex_w()) AppendToBuffer("REX.W ");
1263
+ } else if ((current & 0xFE) == 0xF2) { // Group 1 prefix (0xF2 or 0xF3).
1264
+ group_1_prefix_ = current;
1265
+ } else { // Not a prefix - an opcode.
1266
+ break;
1267
+ }
1268
+ data++;
1269
+ }
1270
+
1271
+ const InstructionDesc& idesc = instruction_table.Get(current);
1272
+ byte_size_operand_ = idesc.byte_size_operation;
1273
+ switch (idesc.type) {
1274
+ case ZERO_OPERANDS_INSTR:
1275
+ if (current >= 0xA4 && current <= 0xA7) {
1276
+ // String move or compare operations.
1277
+ if (group_1_prefix_ == REP_PREFIX) {
1278
+ // REP.
1279
+ AppendToBuffer("rep ");
1280
+ }
1281
+ if (rex_w()) AppendToBuffer("REX.W ");
1282
+ AppendToBuffer("%s%c", idesc.mnem, operand_size_code());
1283
+ } else {
1284
+ AppendToBuffer("%s", idesc.mnem, operand_size_code());
1285
+ }
1286
+ data++;
1287
+ break;
1288
+
1289
+ case TWO_OPERANDS_INSTR:
1290
+ data++;
1291
+ data += PrintOperands(idesc.mnem, idesc.op_order_, data);
1292
+ break;
1293
+
1294
+ case JUMP_CONDITIONAL_SHORT_INSTR:
1295
+ data += JumpConditionalShort(data);
1296
+ break;
1297
+
1298
+ case REGISTER_INSTR:
1299
+ AppendToBuffer("%s%c %s",
1300
+ idesc.mnem,
1301
+ operand_size_code(),
1302
+ NameOfCPURegister(base_reg(current & 0x07)));
1303
+ data++;
1304
+ break;
1305
+ case PUSHPOP_INSTR:
1306
+ AppendToBuffer("%s %s",
1307
+ idesc.mnem,
1308
+ NameOfCPURegister(base_reg(current & 0x07)));
1309
+ data++;
1310
+ break;
1311
+ case MOVE_REG_INSTR: {
1312
+ byte* addr = NULL;
1313
+ switch (operand_size()) {
1314
+ case WORD_SIZE:
1315
+ addr = reinterpret_cast<byte*>(*reinterpret_cast<int16_t*>(data + 1));
1316
+ data += 3;
1317
+ break;
1318
+ case DOUBLEWORD_SIZE:
1319
+ addr = reinterpret_cast<byte*>(*reinterpret_cast<int32_t*>(data + 1));
1320
+ data += 5;
1321
+ break;
1322
+ case QUADWORD_SIZE:
1323
+ addr = reinterpret_cast<byte*>(*reinterpret_cast<int64_t*>(data + 1));
1324
+ data += 9;
1325
+ break;
1326
+ default:
1327
+ UNREACHABLE();
1328
+ }
1329
+ AppendToBuffer("mov%c %s,%s",
1330
+ operand_size_code(),
1331
+ NameOfCPURegister(base_reg(current & 0x07)),
1332
+ NameOfAddress(addr));
1333
+ break;
1334
+ }
1335
+
1336
+ case CALL_JUMP_INSTR: {
1337
+ byte* addr = data + *reinterpret_cast<int32_t*>(data + 1) + 5;
1338
+ AppendToBuffer("%s %s", idesc.mnem, NameOfAddress(addr));
1339
+ data += 5;
1340
+ break;
1341
+ }
1342
+
1343
+ case SHORT_IMMEDIATE_INSTR: {
1344
+ byte* addr =
1345
+ reinterpret_cast<byte*>(*reinterpret_cast<int32_t*>(data + 1));
1346
+ AppendToBuffer("%s rax, %s", idesc.mnem, NameOfAddress(addr));
1347
+ data += 5;
1348
+ break;
1349
+ }
1350
+
1351
+ case NO_INSTR:
1352
+ processed = false;
1353
+ break;
1354
+
1355
+ default:
1356
+ UNIMPLEMENTED(); // This type is not implemented.
1357
+ }
1358
+
1359
+ // The first byte didn't match any of the simple opcodes, so we
1360
+ // need to do special processing on it.
1361
+ if (!processed) {
1362
+ switch (*data) {
1363
+ case 0xC2:
1364
+ AppendToBuffer("ret 0x%x", *reinterpret_cast<uint16_t*>(data + 1));
1365
+ data += 3;
1366
+ break;
1367
+
1368
+ case 0x69: // fall through
1369
+ case 0x6B: {
1370
+ int mod, regop, rm;
1371
+ get_modrm(*(data + 1), &mod, &regop, &rm);
1372
+ int32_t imm = *data == 0x6B ? *(data + 2)
1373
+ : *reinterpret_cast<int32_t*>(data + 2);
1374
+ AppendToBuffer("imul%c %s,%s,0x%x",
1375
+ operand_size_code(),
1376
+ NameOfCPURegister(regop),
1377
+ NameOfCPURegister(rm), imm);
1378
+ data += 2 + (*data == 0x6B ? 1 : 4);
1379
+ break;
1380
+ }
1381
+
1382
+ case 0x81: // fall through
1383
+ case 0x83: // 0x81 with sign extension bit set
1384
+ data += PrintImmediateOp(data);
1385
+ break;
1386
+
1387
+ case 0x0F:
1388
+ data += TwoByteOpcodeInstruction(data);
1389
+ break;
1390
+
1391
+ case 0x8F: {
1392
+ data++;
1393
+ int mod, regop, rm;
1394
+ get_modrm(*data, &mod, &regop, &rm);
1395
+ if (regop == 0) {
1396
+ AppendToBuffer("pop ");
1397
+ data += PrintRightOperand(data);
1398
+ }
1399
+ }
1400
+ break;
1401
+
1402
+ case 0xFF: {
1403
+ data++;
1404
+ int mod, regop, rm;
1405
+ get_modrm(*data, &mod, &regop, &rm);
1406
+ const char* mnem = NULL;
1407
+ switch (regop) {
1408
+ case 0:
1409
+ mnem = "inc";
1410
+ break;
1411
+ case 1:
1412
+ mnem = "dec";
1413
+ break;
1414
+ case 2:
1415
+ mnem = "call";
1416
+ break;
1417
+ case 4:
1418
+ mnem = "jmp";
1419
+ break;
1420
+ case 6:
1421
+ mnem = "push";
1422
+ break;
1423
+ default:
1424
+ mnem = "???";
1425
+ }
1426
+ AppendToBuffer(((regop <= 1) ? "%s%c " : "%s "),
1427
+ mnem,
1428
+ operand_size_code());
1429
+ data += PrintRightOperand(data);
1430
+ }
1431
+ break;
1432
+
1433
+ case 0xC7: // imm32, fall through
1434
+ case 0xC6: // imm8
1435
+ {
1436
+ bool is_byte = *data == 0xC6;
1437
+ data++;
1438
+
1439
+ AppendToBuffer("mov%c ", is_byte ? 'b' : operand_size_code());
1440
+ data += PrintRightOperand(data);
1441
+ int32_t imm = is_byte ? *data : *reinterpret_cast<int32_t*>(data);
1442
+ AppendToBuffer(",0x%x", imm);
1443
+ data += is_byte ? 1 : 4;
1444
+ }
1445
+ break;
1446
+
1447
+ case 0x80: {
1448
+ data++;
1449
+ AppendToBuffer("cmpb ");
1450
+ data += PrintRightOperand(data);
1451
+ int32_t imm = *data;
1452
+ AppendToBuffer(",0x%x", imm);
1453
+ data++;
1454
+ }
1455
+ break;
1456
+
1457
+ case 0x88: // 8bit, fall through
1458
+ case 0x89: // 32bit
1459
+ {
1460
+ bool is_byte = *data == 0x88;
1461
+ int mod, regop, rm;
1462
+ data++;
1463
+ get_modrm(*data, &mod, &regop, &rm);
1464
+ AppendToBuffer("mov%c ", is_byte ? 'b' : operand_size_code());
1465
+ data += PrintRightOperand(data);
1466
+ AppendToBuffer(",%s", NameOfCPURegister(regop));
1467
+ }
1468
+ break;
1469
+
1470
+ case 0x90:
1471
+ case 0x91:
1472
+ case 0x92:
1473
+ case 0x93:
1474
+ case 0x94:
1475
+ case 0x95:
1476
+ case 0x96:
1477
+ case 0x97: {
1478
+ int reg = (*data & 0x7) | (rex_b() ? 8 : 0);
1479
+ if (reg == 0) {
1480
+ AppendToBuffer("nop"); // Common name for xchg rax,rax.
1481
+ } else {
1482
+ AppendToBuffer("xchg%c rax, %s",
1483
+ operand_size_code(),
1484
+ NameOfCPURegister(reg));
1485
+ }
1486
+ data++;
1487
+ }
1488
+ break;
1489
+
1490
+ case 0xFE: {
1491
+ data++;
1492
+ int mod, regop, rm;
1493
+ get_modrm(*data, &mod, &regop, &rm);
1494
+ if (regop == 1) {
1495
+ AppendToBuffer("decb ");
1496
+ data += PrintRightOperand(data);
1497
+ } else {
1498
+ UnimplementedInstruction();
1499
+ }
1500
+ }
1501
+ break;
1502
+
1503
+ case 0x68:
1504
+ AppendToBuffer("push 0x%x", *reinterpret_cast<int32_t*>(data + 1));
1505
+ data += 5;
1506
+ break;
1507
+
1508
+ case 0x6A:
1509
+ AppendToBuffer("push 0x%x", *reinterpret_cast<int8_t*>(data + 1));
1510
+ data += 2;
1511
+ break;
1512
+
1513
+ case 0xA1: // Fall through.
1514
+ case 0xA3:
1515
+ switch (operand_size()) {
1516
+ case DOUBLEWORD_SIZE: {
1517
+ const char* memory_location = NameOfAddress(
1518
+ reinterpret_cast<byte*>(
1519
+ *reinterpret_cast<int32_t*>(data + 1)));
1520
+ if (*data == 0xA1) { // Opcode 0xA1
1521
+ AppendToBuffer("movzxlq rax,(%s)", memory_location);
1522
+ } else { // Opcode 0xA3
1523
+ AppendToBuffer("movzxlq (%s),rax", memory_location);
1524
+ }
1525
+ data += 5;
1526
+ break;
1527
+ }
1528
+ case QUADWORD_SIZE: {
1529
+ // New x64 instruction mov rax,(imm_64).
1530
+ const char* memory_location = NameOfAddress(
1531
+ *reinterpret_cast<byte**>(data + 1));
1532
+ if (*data == 0xA1) { // Opcode 0xA1
1533
+ AppendToBuffer("movq rax,(%s)", memory_location);
1534
+ } else { // Opcode 0xA3
1535
+ AppendToBuffer("movq (%s),rax", memory_location);
1536
+ }
1537
+ data += 9;
1538
+ break;
1539
+ }
1540
+ default:
1541
+ UnimplementedInstruction();
1542
+ data += 2;
1543
+ }
1544
+ break;
1545
+
1546
+ case 0xA8:
1547
+ AppendToBuffer("test al,0x%x", *reinterpret_cast<uint8_t*>(data + 1));
1548
+ data += 2;
1549
+ break;
1550
+
1551
+ case 0xA9: {
1552
+ int64_t value = 0;
1553
+ switch (operand_size()) {
1554
+ case WORD_SIZE:
1555
+ value = *reinterpret_cast<uint16_t*>(data + 1);
1556
+ data += 3;
1557
+ break;
1558
+ case DOUBLEWORD_SIZE:
1559
+ value = *reinterpret_cast<uint32_t*>(data + 1);
1560
+ data += 5;
1561
+ break;
1562
+ case QUADWORD_SIZE:
1563
+ value = *reinterpret_cast<int32_t*>(data + 1);
1564
+ data += 5;
1565
+ break;
1566
+ default:
1567
+ UNREACHABLE();
1568
+ }
1569
+ AppendToBuffer("test%c rax,0x%"V8_PTR_PREFIX"x",
1570
+ operand_size_code(),
1571
+ value);
1572
+ break;
1573
+ }
1574
+ case 0xD1: // fall through
1575
+ case 0xD3: // fall through
1576
+ case 0xC1:
1577
+ data += ShiftInstruction(data);
1578
+ break;
1579
+ case 0xD0: // fall through
1580
+ case 0xD2: // fall through
1581
+ case 0xC0:
1582
+ byte_size_operand_ = true;
1583
+ data += ShiftInstruction(data);
1584
+ break;
1585
+
1586
+ case 0xD9: // fall through
1587
+ case 0xDA: // fall through
1588
+ case 0xDB: // fall through
1589
+ case 0xDC: // fall through
1590
+ case 0xDD: // fall through
1591
+ case 0xDE: // fall through
1592
+ case 0xDF:
1593
+ data += FPUInstruction(data);
1594
+ break;
1595
+
1596
+ case 0xEB:
1597
+ data += JumpShort(data);
1598
+ break;
1599
+
1600
+ case 0xF6:
1601
+ byte_size_operand_ = true; // fall through
1602
+ case 0xF7:
1603
+ data += F6F7Instruction(data);
1604
+ break;
1605
+
1606
+ default:
1607
+ UnimplementedInstruction();
1608
+ data += 1;
1609
+ }
1610
+ } // !processed
1611
+
1612
+ if (tmp_buffer_pos_ < sizeof tmp_buffer_) {
1613
+ tmp_buffer_[tmp_buffer_pos_] = '\0';
1614
+ }
1615
+
1616
+ int instr_len = static_cast<int>(data - instr);
1617
+ ASSERT(instr_len > 0); // Ensure progress.
1618
+
1619
+ int outp = 0;
1620
+ // Instruction bytes.
1621
+ for (byte* bp = instr; bp < data; bp++) {
1622
+ outp += v8::internal::OS::SNPrintF(out_buffer + outp, "%02x", *bp);
1623
+ }
1624
+ for (int i = 6 - instr_len; i >= 0; i--) {
1625
+ outp += v8::internal::OS::SNPrintF(out_buffer + outp, " ");
1626
+ }
1627
+
1628
+ outp += v8::internal::OS::SNPrintF(out_buffer + outp, " %s",
1629
+ tmp_buffer_.start());
1630
+ return instr_len;
1631
+ }
1632
+
1633
+ //------------------------------------------------------------------------------
1634
+
1635
+
1636
+ static const char* cpu_regs[16] = {
1637
+ "rax", "rcx", "rdx", "rbx", "rsp", "rbp", "rsi", "rdi",
1638
+ "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15"
1639
+ };
1640
+
1641
+
1642
+ static const char* byte_cpu_regs[16] = {
1643
+ "al", "cl", "dl", "bl", "spl", "bpl", "sil", "dil",
1644
+ "r8l", "r9l", "r10l", "r11l", "r12l", "r13l", "r14l", "r15l"
1645
+ };
1646
+
1647
+
1648
+ static const char* xmm_regs[16] = {
1649
+ "xmm0", "xmm1", "xmm2", "xmm3", "xmm4", "xmm5", "xmm6", "xmm7",
1650
+ "xmm8", "xmm9", "xmm10", "xmm11", "xmm12", "xmm13", "xmm14", "xmm15"
1651
+ };
1652
+
1653
+
1654
+ const char* NameConverter::NameOfAddress(byte* addr) const {
1655
+ static v8::internal::EmbeddedVector<char, 32> tmp_buffer;
1656
+ v8::internal::OS::SNPrintF(tmp_buffer, "%p", addr);
1657
+ return tmp_buffer.start();
1658
+ }
1659
+
1660
+
1661
+ const char* NameConverter::NameOfConstant(byte* addr) const {
1662
+ return NameOfAddress(addr);
1663
+ }
1664
+
1665
+
1666
+ const char* NameConverter::NameOfCPURegister(int reg) const {
1667
+ if (0 <= reg && reg < 16)
1668
+ return cpu_regs[reg];
1669
+ return "noreg";
1670
+ }
1671
+
1672
+
1673
+ const char* NameConverter::NameOfByteCPURegister(int reg) const {
1674
+ if (0 <= reg && reg < 16)
1675
+ return byte_cpu_regs[reg];
1676
+ return "noreg";
1677
+ }
1678
+
1679
+
1680
+ const char* NameConverter::NameOfXMMRegister(int reg) const {
1681
+ if (0 <= reg && reg < 16)
1682
+ return xmm_regs[reg];
1683
+ return "noxmmreg";
1684
+ }
1685
+
1686
+
1687
+ const char* NameConverter::NameInCode(byte* addr) const {
1688
+ // X64 does not embed debug strings at the moment.
1689
+ UNREACHABLE();
1690
+ return "";
1691
+ }
1692
+
1693
+ //------------------------------------------------------------------------------
1694
+
1695
+ Disassembler::Disassembler(const NameConverter& converter)
1696
+ : converter_(converter) { }
1697
+
1698
+ Disassembler::~Disassembler() { }
1699
+
1700
+
1701
+ int Disassembler::InstructionDecode(v8::internal::Vector<char> buffer,
1702
+ byte* instruction) {
1703
+ DisassemblerX64 d(converter_, CONTINUE_ON_UNIMPLEMENTED_OPCODE);
1704
+ return d.InstructionDecode(buffer, instruction);
1705
+ }
1706
+
1707
+
1708
+ // The X64 assembler does not use constant pools.
1709
+ int Disassembler::ConstantPoolSizeAt(byte* instruction) {
1710
+ return -1;
1711
+ }
1712
+
1713
+
1714
+ void Disassembler::Disassemble(FILE* f, byte* begin, byte* end) {
1715
+ NameConverter converter;
1716
+ Disassembler d(converter);
1717
+ for (byte* pc = begin; pc < end;) {
1718
+ v8::internal::EmbeddedVector<char, 128> buffer;
1719
+ buffer[0] = '\0';
1720
+ byte* prev_pc = pc;
1721
+ pc += d.InstructionDecode(buffer, pc);
1722
+ fprintf(f, "%p", prev_pc);
1723
+ fprintf(f, " ");
1724
+
1725
+ for (byte* bp = prev_pc; bp < pc; bp++) {
1726
+ fprintf(f, "%02x", *bp);
1727
+ }
1728
+ for (int i = 6 - static_cast<int>(pc - prev_pc); i >= 0; i--) {
1729
+ fprintf(f, " ");
1730
+ }
1731
+ fprintf(f, " %s\n", buffer.start());
1732
+ }
1733
+ }
1734
+
1735
+ } // namespace disasm
1736
+
1737
+ #endif // V8_TARGET_ARCH_X64