therubyracer 0.9.0beta2 → 0.9.0beta3

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