therubyracer 0.8.1.pre2 → 0.8.1

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

Potentially problematic release.


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

Files changed (877) hide show
  1. data/Changelog.md +2 -1
  2. data/README.md +6 -3
  3. data/ext/v8/upstream/3.1.8/.gitignore +31 -0
  4. data/ext/v8/upstream/3.1.8/AUTHORS +40 -0
  5. data/ext/v8/upstream/3.1.8/ChangeLog +2566 -0
  6. data/ext/v8/upstream/3.1.8/LICENSE +52 -0
  7. data/ext/v8/upstream/3.1.8/LICENSE.strongtalk +29 -0
  8. data/ext/v8/upstream/3.1.8/LICENSE.v8 +26 -0
  9. data/ext/v8/upstream/3.1.8/LICENSE.valgrind +45 -0
  10. data/ext/v8/upstream/3.1.8/SConstruct +1192 -0
  11. data/ext/v8/upstream/3.1.8/build/README.txt +25 -0
  12. data/ext/v8/upstream/3.1.8/build/all.gyp +18 -0
  13. data/ext/v8/upstream/3.1.8/build/armu.gypi +32 -0
  14. data/ext/v8/upstream/3.1.8/build/common.gypi +82 -0
  15. data/ext/v8/upstream/3.1.8/build/gyp_v8 +145 -0
  16. data/ext/v8/upstream/3.1.8/include/v8-debug.h +384 -0
  17. data/ext/v8/upstream/3.1.8/include/v8-preparser.h +116 -0
  18. data/ext/v8/upstream/3.1.8/include/v8-profiler.h +426 -0
  19. data/ext/v8/upstream/3.1.8/include/v8-testing.h +99 -0
  20. data/ext/v8/upstream/3.1.8/include/v8.h +3846 -0
  21. data/ext/v8/upstream/3.1.8/include/v8stdint.h +53 -0
  22. data/ext/v8/upstream/3.1.8/preparser/preparser-process.cc +206 -0
  23. data/ext/v8/upstream/3.1.8/src/SConscript +356 -0
  24. data/ext/v8/upstream/3.1.8/src/accessors.cc +907 -0
  25. data/ext/v8/upstream/3.1.8/src/accessors.h +121 -0
  26. data/ext/v8/upstream/3.1.8/src/allocation.cc +204 -0
  27. data/ext/v8/upstream/3.1.8/src/allocation.h +176 -0
  28. data/ext/v8/upstream/3.1.8/src/api.cc +5191 -0
  29. data/ext/v8/upstream/3.1.8/src/api.h +508 -0
  30. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/apinatives.js +0 -0
  31. data/ext/v8/upstream/3.1.8/src/apiutils.h +80 -0
  32. data/ext/v8/upstream/3.1.8/src/arguments.h +105 -0
  33. data/ext/v8/upstream/3.1.8/src/arm/assembler-arm-inl.h +352 -0
  34. data/ext/v8/upstream/3.1.8/src/arm/assembler-arm.cc +2756 -0
  35. data/ext/v8/upstream/3.1.8/src/arm/assembler-arm.h +1294 -0
  36. data/ext/v8/upstream/3.1.8/src/arm/builtins-arm.cc +1628 -0
  37. data/ext/v8/upstream/3.1.8/src/arm/code-stubs-arm.cc +6783 -0
  38. data/ext/v8/upstream/3.1.8/src/arm/code-stubs-arm.h +657 -0
  39. data/ext/v8/upstream/3.1.8/src/arm/codegen-arm-inl.h +48 -0
  40. data/ext/v8/upstream/3.1.8/src/arm/codegen-arm.cc +7403 -0
  41. data/ext/v8/upstream/3.1.8/src/arm/codegen-arm.h +595 -0
  42. data/ext/v8/upstream/3.1.8/src/arm/constants-arm.cc +152 -0
  43. data/ext/v8/upstream/3.1.8/src/arm/constants-arm.h +769 -0
  44. data/ext/v8/upstream/3.1.8/src/arm/cpu-arm.cc +147 -0
  45. data/ext/v8/upstream/3.1.8/src/arm/debug-arm.cc +315 -0
  46. data/ext/v8/upstream/3.1.8/src/arm/deoptimizer-arm.cc +700 -0
  47. data/ext/v8/upstream/3.1.8/src/arm/disasm-arm.cc +1439 -0
  48. data/ext/v8/upstream/3.1.8/src/arm/frames-arm.cc +45 -0
  49. data/ext/v8/upstream/3.1.8/src/arm/frames-arm.h +168 -0
  50. data/ext/v8/upstream/3.1.8/src/arm/full-codegen-arm.cc +4230 -0
  51. data/ext/v8/upstream/3.1.8/src/arm/ic-arm.cc +1799 -0
  52. data/ext/v8/upstream/3.1.8/src/arm/jump-target-arm.cc +174 -0
  53. data/ext/v8/upstream/3.1.8/src/arm/lithium-arm.cc +2041 -0
  54. data/ext/v8/upstream/3.1.8/src/arm/lithium-arm.h +2046 -0
  55. data/ext/v8/upstream/3.1.8/src/arm/lithium-codegen-arm.cc +3822 -0
  56. data/ext/v8/upstream/3.1.8/src/arm/lithium-codegen-arm.h +312 -0
  57. data/ext/v8/upstream/3.1.8/src/arm/lithium-gap-resolver-arm.cc +303 -0
  58. data/ext/v8/upstream/3.1.8/src/arm/lithium-gap-resolver-arm.h +84 -0
  59. data/ext/v8/upstream/3.1.8/src/arm/macro-assembler-arm.cc +2701 -0
  60. data/ext/v8/upstream/3.1.8/src/arm/macro-assembler-arm.h +1015 -0
  61. data/ext/v8/upstream/3.1.8/src/arm/regexp-macro-assembler-arm.cc +1280 -0
  62. data/ext/v8/upstream/3.1.8/src/arm/regexp-macro-assembler-arm.h +252 -0
  63. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/arm/register-allocator-arm-inl.h +0 -0
  64. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/arm/register-allocator-arm.cc +0 -0
  65. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/arm/register-allocator-arm.h +0 -0
  66. data/ext/v8/upstream/3.1.8/src/arm/simulator-arm.cc +3165 -0
  67. data/ext/v8/upstream/3.1.8/src/arm/simulator-arm.h +402 -0
  68. data/ext/v8/upstream/3.1.8/src/arm/stub-cache-arm.cc +4077 -0
  69. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/arm/virtual-frame-arm-inl.h +0 -0
  70. data/ext/v8/upstream/3.1.8/src/arm/virtual-frame-arm.cc +843 -0
  71. data/ext/v8/upstream/3.1.8/src/arm/virtual-frame-arm.h +520 -0
  72. data/ext/v8/upstream/3.1.8/src/array.js +1231 -0
  73. data/ext/v8/upstream/3.1.8/src/assembler.cc +973 -0
  74. data/ext/v8/upstream/3.1.8/src/assembler.h +787 -0
  75. data/ext/v8/upstream/3.1.8/src/ast-inl.h +107 -0
  76. data/ext/v8/upstream/3.1.8/src/ast.cc +1067 -0
  77. data/ext/v8/upstream/3.1.8/src/ast.h +2177 -0
  78. data/ext/v8/upstream/3.1.8/src/atomicops.h +165 -0
  79. data/ext/v8/upstream/3.1.8/src/atomicops_internals_arm_gcc.h +145 -0
  80. data/ext/v8/upstream/3.1.8/src/atomicops_internals_x86_gcc.cc +126 -0
  81. data/ext/v8/upstream/3.1.8/src/atomicops_internals_x86_gcc.h +287 -0
  82. data/ext/v8/upstream/3.1.8/src/atomicops_internals_x86_macosx.h +301 -0
  83. data/ext/v8/upstream/3.1.8/src/atomicops_internals_x86_msvc.h +203 -0
  84. data/ext/v8/upstream/3.1.8/src/bignum-dtoa.cc +655 -0
  85. data/ext/v8/upstream/3.1.8/src/bignum-dtoa.h +81 -0
  86. data/ext/v8/upstream/3.1.8/src/bignum.cc +768 -0
  87. data/ext/v8/upstream/3.1.8/src/bignum.h +140 -0
  88. data/ext/v8/upstream/3.1.8/src/bootstrapper.cc +1888 -0
  89. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/bootstrapper.h +0 -0
  90. data/ext/v8/upstream/3.1.8/src/builtins.cc +1586 -0
  91. data/ext/v8/upstream/3.1.8/src/builtins.h +339 -0
  92. data/ext/v8/upstream/3.1.8/src/bytecodes-irregexp.h +105 -0
  93. data/ext/v8/upstream/3.1.8/src/cached-powers.cc +177 -0
  94. data/ext/v8/upstream/3.1.8/src/cached-powers.h +65 -0
  95. data/ext/v8/upstream/3.1.8/src/char-predicates-inl.h +94 -0
  96. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/char-predicates.h +0 -0
  97. data/ext/v8/upstream/3.1.8/src/checks.cc +110 -0
  98. data/ext/v8/upstream/3.1.8/src/checks.h +292 -0
  99. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/circular-queue-inl.h +0 -0
  100. data/ext/v8/upstream/3.1.8/src/circular-queue.cc +122 -0
  101. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/circular-queue.h +0 -0
  102. data/ext/v8/upstream/3.1.8/src/code-stubs.cc +230 -0
  103. data/ext/v8/upstream/3.1.8/src/code-stubs.h +950 -0
  104. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/code.h +0 -0
  105. data/ext/v8/upstream/3.1.8/src/codegen-inl.h +64 -0
  106. data/ext/v8/upstream/3.1.8/src/codegen.cc +495 -0
  107. data/ext/v8/upstream/3.1.8/src/codegen.h +245 -0
  108. data/ext/v8/upstream/3.1.8/src/compilation-cache.cc +654 -0
  109. data/ext/v8/upstream/3.1.8/src/compilation-cache.h +112 -0
  110. data/ext/v8/upstream/3.1.8/src/compiler.cc +806 -0
  111. data/ext/v8/upstream/3.1.8/src/compiler.h +290 -0
  112. data/ext/v8/upstream/3.1.8/src/contexts.cc +320 -0
  113. data/ext/v8/upstream/3.1.8/src/contexts.h +376 -0
  114. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/conversions-inl.h +0 -0
  115. data/ext/v8/upstream/3.1.8/src/conversions.cc +1069 -0
  116. data/ext/v8/upstream/3.1.8/src/conversions.h +122 -0
  117. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/counters.cc +0 -0
  118. data/ext/v8/upstream/3.1.8/src/counters.h +242 -0
  119. data/ext/v8/upstream/3.1.8/src/cpu-profiler-inl.h +100 -0
  120. data/ext/v8/upstream/3.1.8/src/cpu-profiler.cc +554 -0
  121. data/ext/v8/upstream/3.1.8/src/cpu-profiler.h +291 -0
  122. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/cpu.h +0 -0
  123. data/ext/v8/upstream/3.1.8/src/d8-debug.cc +367 -0
  124. data/ext/v8/upstream/3.1.8/src/d8-debug.h +157 -0
  125. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/d8-posix.cc +0 -0
  126. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/d8-readline.cc +0 -0
  127. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/d8-windows.cc +0 -0
  128. data/ext/v8/upstream/3.1.8/src/d8.cc +792 -0
  129. data/ext/v8/upstream/3.1.8/src/d8.gyp +85 -0
  130. data/ext/v8/upstream/3.1.8/src/d8.h +231 -0
  131. data/ext/v8/upstream/3.1.8/src/d8.js +2798 -0
  132. data/ext/v8/upstream/3.1.8/src/data-flow.cc +545 -0
  133. data/ext/v8/upstream/3.1.8/src/data-flow.h +379 -0
  134. data/ext/v8/upstream/3.1.8/src/date.js +1103 -0
  135. data/ext/v8/upstream/3.1.8/src/dateparser-inl.h +125 -0
  136. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/dateparser.cc +0 -0
  137. data/ext/v8/upstream/3.1.8/src/dateparser.h +263 -0
  138. data/ext/v8/upstream/3.1.8/src/debug-agent.cc +446 -0
  139. data/ext/v8/upstream/3.1.8/src/debug-agent.h +131 -0
  140. data/ext/v8/upstream/3.1.8/src/debug-debugger.js +2569 -0
  141. data/ext/v8/upstream/3.1.8/src/debug.cc +3085 -0
  142. data/ext/v8/upstream/3.1.8/src/debug.h +1025 -0
  143. data/ext/v8/upstream/3.1.8/src/deoptimizer.cc +1185 -0
  144. data/ext/v8/upstream/3.1.8/src/deoptimizer.h +529 -0
  145. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/disasm.h +0 -0
  146. data/ext/v8/upstream/3.1.8/src/disassembler.cc +338 -0
  147. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/disassembler.h +0 -0
  148. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/diy-fp.cc +0 -0
  149. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/diy-fp.h +0 -0
  150. data/ext/v8/upstream/3.1.8/src/double.h +238 -0
  151. data/ext/v8/upstream/3.1.8/src/dtoa.cc +103 -0
  152. data/ext/v8/upstream/3.1.8/src/dtoa.h +85 -0
  153. data/ext/v8/upstream/3.1.8/src/execution.cc +735 -0
  154. data/ext/v8/upstream/3.1.8/src/execution.h +322 -0
  155. data/ext/v8/upstream/3.1.8/src/extensions/experimental/experimental.gyp +53 -0
  156. data/ext/v8/upstream/3.1.8/src/extensions/experimental/i18n-extension.cc +264 -0
  157. data/ext/v8/upstream/3.1.8/src/extensions/experimental/i18n-extension.h +64 -0
  158. data/ext/v8/upstream/3.1.8/src/extensions/externalize-string-extension.cc +141 -0
  159. data/ext/v8/upstream/3.1.8/src/extensions/externalize-string-extension.h +50 -0
  160. data/ext/v8/upstream/3.1.8/src/extensions/gc-extension.cc +58 -0
  161. data/ext/v8/upstream/3.1.8/src/extensions/gc-extension.h +49 -0
  162. data/ext/v8/upstream/3.1.8/src/factory.cc +1087 -0
  163. data/ext/v8/upstream/3.1.8/src/factory.h +432 -0
  164. data/ext/v8/upstream/3.1.8/src/fast-dtoa.cc +736 -0
  165. data/ext/v8/upstream/3.1.8/src/fast-dtoa.h +83 -0
  166. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/fixed-dtoa.cc +0 -0
  167. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/fixed-dtoa.h +0 -0
  168. data/ext/v8/upstream/3.1.8/src/flag-definitions.h +552 -0
  169. data/ext/v8/upstream/3.1.8/src/flags.cc +551 -0
  170. data/ext/v8/upstream/3.1.8/src/flags.h +79 -0
  171. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/frame-element.cc +0 -0
  172. data/ext/v8/upstream/3.1.8/src/frame-element.h +277 -0
  173. data/ext/v8/upstream/3.1.8/src/frames-inl.h +210 -0
  174. data/ext/v8/upstream/3.1.8/src/frames.cc +1232 -0
  175. data/ext/v8/upstream/3.1.8/src/frames.h +826 -0
  176. data/ext/v8/upstream/3.1.8/src/full-codegen.cc +1382 -0
  177. data/ext/v8/upstream/3.1.8/src/full-codegen.h +751 -0
  178. data/ext/v8/upstream/3.1.8/src/func-name-inferrer.cc +90 -0
  179. data/ext/v8/upstream/3.1.8/src/func-name-inferrer.h +111 -0
  180. data/ext/v8/upstream/3.1.8/src/gdb-jit.cc +1547 -0
  181. data/ext/v8/upstream/3.1.8/src/gdb-jit.h +138 -0
  182. data/ext/v8/upstream/3.1.8/src/global-handles.cc +534 -0
  183. data/ext/v8/upstream/3.1.8/src/global-handles.h +181 -0
  184. data/ext/v8/upstream/3.1.8/src/globals.h +325 -0
  185. data/ext/v8/upstream/3.1.8/src/handles-inl.h +80 -0
  186. data/ext/v8/upstream/3.1.8/src/handles.cc +910 -0
  187. data/ext/v8/upstream/3.1.8/src/handles.h +424 -0
  188. data/ext/v8/upstream/3.1.8/src/hashmap.cc +230 -0
  189. data/ext/v8/upstream/3.1.8/src/hashmap.h +121 -0
  190. data/ext/v8/upstream/3.1.8/src/heap-inl.h +587 -0
  191. data/ext/v8/upstream/3.1.8/src/heap-profiler.cc +1128 -0
  192. data/ext/v8/upstream/3.1.8/src/heap-profiler.h +381 -0
  193. data/ext/v8/upstream/3.1.8/src/heap.cc +5610 -0
  194. data/ext/v8/upstream/3.1.8/src/heap.h +2218 -0
  195. data/ext/v8/upstream/3.1.8/src/hydrogen-instructions.cc +1490 -0
  196. data/ext/v8/upstream/3.1.8/src/hydrogen-instructions.h +3493 -0
  197. data/ext/v8/upstream/3.1.8/src/hydrogen.cc +6056 -0
  198. data/ext/v8/upstream/3.1.8/src/hydrogen.h +1091 -0
  199. data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32-inl.h +429 -0
  200. data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32.cc +2800 -0
  201. data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32.h +1093 -0
  202. data/ext/v8/upstream/3.1.8/src/ia32/builtins-ia32.cc +1590 -0
  203. data/ext/v8/upstream/3.1.8/src/ia32/code-stubs-ia32.cc +6624 -0
  204. data/ext/v8/upstream/3.1.8/src/ia32/code-stubs-ia32.h +536 -0
  205. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/codegen-ia32-inl.h +0 -0
  206. data/ext/v8/upstream/3.1.8/src/ia32/codegen-ia32.cc +10354 -0
  207. data/ext/v8/upstream/3.1.8/src/ia32/codegen-ia32.h +798 -0
  208. data/ext/v8/upstream/3.1.8/src/ia32/cpu-ia32.cc +87 -0
  209. data/ext/v8/upstream/3.1.8/src/ia32/debug-ia32.cc +309 -0
  210. data/ext/v8/upstream/3.1.8/src/ia32/deoptimizer-ia32.cc +664 -0
  211. data/ext/v8/upstream/3.1.8/src/ia32/disasm-ia32.cc +1597 -0
  212. data/ext/v8/upstream/3.1.8/src/ia32/frames-ia32.cc +45 -0
  213. data/ext/v8/upstream/3.1.8/src/ia32/frames-ia32.h +140 -0
  214. data/ext/v8/upstream/3.1.8/src/ia32/full-codegen-ia32.cc +4278 -0
  215. data/ext/v8/upstream/3.1.8/src/ia32/ic-ia32.cc +1786 -0
  216. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/jump-target-ia32.cc +0 -0
  217. data/ext/v8/upstream/3.1.8/src/ia32/lithium-codegen-ia32.cc +3880 -0
  218. data/ext/v8/upstream/3.1.8/src/ia32/lithium-codegen-ia32.h +309 -0
  219. data/ext/v8/upstream/3.1.8/src/ia32/lithium-gap-resolver-ia32.cc +460 -0
  220. data/ext/v8/upstream/3.1.8/src/ia32/lithium-gap-resolver-ia32.h +110 -0
  221. data/ext/v8/upstream/3.1.8/src/ia32/lithium-ia32.cc +2095 -0
  222. data/ext/v8/upstream/3.1.8/src/ia32/lithium-ia32.h +2127 -0
  223. data/ext/v8/upstream/3.1.8/src/ia32/macro-assembler-ia32.cc +2031 -0
  224. data/ext/v8/upstream/3.1.8/src/ia32/macro-assembler-ia32.h +798 -0
  225. data/ext/v8/upstream/3.1.8/src/ia32/regexp-macro-assembler-ia32.cc +1253 -0
  226. data/ext/v8/upstream/3.1.8/src/ia32/regexp-macro-assembler-ia32.h +215 -0
  227. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/register-allocator-ia32-inl.h +0 -0
  228. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/register-allocator-ia32.cc +0 -0
  229. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/register-allocator-ia32.h +0 -0
  230. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/ia32/simulator-ia32.cc +0 -0
  231. data/ext/v8/upstream/3.1.8/src/ia32/simulator-ia32.h +72 -0
  232. data/ext/v8/upstream/3.1.8/src/ia32/stub-cache-ia32.cc +3732 -0
  233. data/ext/v8/upstream/3.1.8/src/ia32/virtual-frame-ia32.cc +1360 -0
  234. data/ext/v8/upstream/3.1.8/src/ia32/virtual-frame-ia32.h +646 -0
  235. data/ext/v8/upstream/3.1.8/src/ic-inl.h +129 -0
  236. data/ext/v8/upstream/3.1.8/src/ic.cc +2333 -0
  237. data/ext/v8/upstream/3.1.8/src/ic.h +639 -0
  238. data/ext/v8/upstream/3.1.8/src/inspector.cc +63 -0
  239. data/ext/v8/upstream/3.1.8/src/inspector.h +62 -0
  240. data/ext/v8/upstream/3.1.8/src/interpreter-irregexp.cc +655 -0
  241. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/interpreter-irregexp.h +0 -0
  242. data/ext/v8/upstream/3.1.8/src/json.js +342 -0
  243. data/ext/v8/upstream/3.1.8/src/jsregexp.cc +5340 -0
  244. data/ext/v8/upstream/3.1.8/src/jsregexp.h +1484 -0
  245. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target-heavy-inl.h +0 -0
  246. data/ext/v8/upstream/3.1.8/src/jump-target-heavy.cc +430 -0
  247. data/ext/v8/upstream/3.1.8/src/jump-target-heavy.h +244 -0
  248. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target-inl.h +0 -0
  249. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target-light-inl.h +0 -0
  250. data/ext/v8/upstream/3.1.8/src/jump-target-light.cc +111 -0
  251. data/ext/v8/upstream/3.1.8/src/jump-target-light.h +193 -0
  252. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target.cc +0 -0
  253. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/jump-target.h +0 -0
  254. data/ext/v8/upstream/3.1.8/src/list-inl.h +206 -0
  255. data/ext/v8/upstream/3.1.8/src/list.h +164 -0
  256. data/ext/v8/upstream/3.1.8/src/lithium-allocator-inl.h +140 -0
  257. data/ext/v8/upstream/3.1.8/src/lithium-allocator.cc +2093 -0
  258. data/ext/v8/upstream/3.1.8/src/lithium-allocator.h +644 -0
  259. data/ext/v8/upstream/3.1.8/src/lithium.cc +168 -0
  260. data/ext/v8/upstream/3.1.8/src/lithium.h +592 -0
  261. data/ext/v8/upstream/3.1.8/src/liveedit-debugger.js +1082 -0
  262. data/ext/v8/upstream/3.1.8/src/liveedit.cc +1650 -0
  263. data/ext/v8/upstream/3.1.8/src/liveedit.h +174 -0
  264. data/ext/v8/upstream/3.1.8/src/liveobjectlist-inl.h +126 -0
  265. data/ext/v8/upstream/3.1.8/src/liveobjectlist.cc +2527 -0
  266. data/ext/v8/upstream/3.1.8/src/liveobjectlist.h +322 -0
  267. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/log-inl.h +0 -0
  268. data/ext/v8/upstream/3.1.8/src/log-utils.cc +336 -0
  269. data/ext/v8/upstream/3.1.8/src/log-utils.h +232 -0
  270. data/ext/v8/upstream/3.1.8/src/log.cc +1608 -0
  271. data/ext/v8/upstream/3.1.8/src/log.h +379 -0
  272. data/ext/v8/upstream/3.1.8/src/macro-assembler.h +120 -0
  273. data/ext/v8/upstream/3.1.8/src/macros.py +178 -0
  274. data/ext/v8/upstream/3.1.8/src/mark-compact.cc +2957 -0
  275. data/ext/v8/upstream/3.1.8/src/mark-compact.h +433 -0
  276. data/ext/v8/upstream/3.1.8/src/math.js +264 -0
  277. data/ext/v8/upstream/3.1.8/src/memory.h +82 -0
  278. data/ext/v8/upstream/3.1.8/src/messages.cc +164 -0
  279. data/ext/v8/upstream/3.1.8/src/messages.h +114 -0
  280. data/ext/v8/upstream/3.1.8/src/messages.js +1071 -0
  281. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/assembler-mips-inl.h +0 -0
  282. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/assembler-mips.cc +0 -0
  283. data/ext/v8/upstream/3.1.8/src/mips/assembler-mips.h +667 -0
  284. data/ext/v8/upstream/3.1.8/src/mips/builtins-mips.cc +205 -0
  285. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/codegen-mips-inl.h +0 -0
  286. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/codegen-mips.cc +0 -0
  287. data/ext/v8/upstream/3.1.8/src/mips/codegen-mips.h +431 -0
  288. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/constants-mips.cc +0 -0
  289. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/constants-mips.h +0 -0
  290. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/cpu-mips.cc +0 -0
  291. data/ext/v8/upstream/3.1.8/src/mips/debug-mips.cc +127 -0
  292. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/disasm-mips.cc +0 -0
  293. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/fast-codegen-mips.cc +0 -0
  294. data/ext/v8/upstream/3.1.8/src/mips/frames-mips.cc +96 -0
  295. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/frames-mips.h +0 -0
  296. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/full-codegen-mips.cc +0 -0
  297. data/ext/v8/upstream/3.1.8/src/mips/ic-mips.cc +208 -0
  298. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/jump-target-mips.cc +0 -0
  299. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/macro-assembler-mips.cc +0 -0
  300. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/macro-assembler-mips.h +0 -0
  301. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/register-allocator-mips-inl.h +0 -0
  302. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/register-allocator-mips.cc +0 -0
  303. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/register-allocator-mips.h +0 -0
  304. data/ext/v8/upstream/3.1.8/src/mips/simulator-mips.cc +1650 -0
  305. data/ext/v8/upstream/3.1.8/src/mips/simulator-mips.h +311 -0
  306. data/ext/v8/upstream/3.1.8/src/mips/stub-cache-mips.cc +418 -0
  307. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/virtual-frame-mips.cc +0 -0
  308. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mips/virtual-frame-mips.h +0 -0
  309. data/ext/v8/upstream/3.1.8/src/mirror-debugger.js +2380 -0
  310. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/mksnapshot.cc +0 -0
  311. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/natives.h +0 -0
  312. data/ext/v8/upstream/3.1.8/src/objects-debug.cc +722 -0
  313. data/ext/v8/upstream/3.1.8/src/objects-inl.h +3946 -0
  314. data/ext/v8/upstream/3.1.8/src/objects-printer.cc +801 -0
  315. data/ext/v8/upstream/3.1.8/src/objects-visiting.cc +142 -0
  316. data/ext/v8/upstream/3.1.8/src/objects-visiting.h +401 -0
  317. data/ext/v8/upstream/3.1.8/src/objects.cc +10044 -0
  318. data/ext/v8/upstream/3.1.8/src/objects.h +6571 -0
  319. data/ext/v8/upstream/3.1.8/src/parser.cc +5165 -0
  320. data/ext/v8/upstream/3.1.8/src/parser.h +802 -0
  321. data/ext/v8/upstream/3.1.8/src/platform-cygwin.cc +745 -0
  322. data/ext/v8/upstream/3.1.8/src/platform-freebsd.cc +702 -0
  323. data/ext/v8/upstream/3.1.8/src/platform-linux.cc +981 -0
  324. data/ext/v8/upstream/3.1.8/src/platform-macos.cc +732 -0
  325. data/ext/v8/upstream/3.1.8/src/platform-nullos.cc +498 -0
  326. data/ext/v8/upstream/3.1.8/src/platform-openbsd.cc +657 -0
  327. data/ext/v8/upstream/3.1.8/src/platform-posix.cc +399 -0
  328. data/ext/v8/upstream/3.1.8/src/platform-solaris.cc +714 -0
  329. data/ext/v8/upstream/3.1.8/src/platform-win32.cc +1974 -0
  330. data/ext/v8/upstream/3.1.8/src/platform.h +636 -0
  331. data/ext/v8/upstream/3.1.8/src/preparse-data.cc +183 -0
  332. data/ext/v8/upstream/3.1.8/src/preparse-data.h +249 -0
  333. data/ext/v8/upstream/3.1.8/src/preparser-api.cc +213 -0
  334. data/ext/v8/upstream/3.1.8/src/preparser.cc +1205 -0
  335. data/ext/v8/upstream/3.1.8/src/preparser.h +278 -0
  336. data/ext/v8/upstream/3.1.8/src/prettyprinter.cc +1539 -0
  337. data/ext/v8/upstream/3.1.8/src/prettyprinter.h +223 -0
  338. data/ext/v8/upstream/3.1.8/src/profile-generator-inl.h +128 -0
  339. data/ext/v8/upstream/3.1.8/src/profile-generator.cc +2899 -0
  340. data/ext/v8/upstream/3.1.8/src/profile-generator.h +1151 -0
  341. data/ext/v8/upstream/3.1.8/src/property.cc +96 -0
  342. data/ext/v8/upstream/3.1.8/src/property.h +337 -0
  343. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/regexp-macro-assembler-irregexp-inl.h +0 -0
  344. data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-irregexp.cc +470 -0
  345. data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-irregexp.h +142 -0
  346. data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-tracer.cc +373 -0
  347. data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-tracer.h +104 -0
  348. data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler.cc +257 -0
  349. data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler.h +231 -0
  350. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/regexp-stack.cc +0 -0
  351. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/regexp-stack.h +0 -0
  352. data/ext/v8/upstream/3.1.8/src/regexp.js +483 -0
  353. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/register-allocator-inl.h +0 -0
  354. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/register-allocator.cc +0 -0
  355. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/register-allocator.h +0 -0
  356. data/ext/v8/upstream/3.1.8/src/rewriter.cc +1023 -0
  357. data/ext/v8/upstream/3.1.8/src/rewriter.h +59 -0
  358. data/ext/v8/upstream/3.1.8/src/runtime-profiler.cc +443 -0
  359. data/ext/v8/upstream/3.1.8/src/runtime-profiler.h +77 -0
  360. data/ext/v8/upstream/3.1.8/src/runtime.cc +11592 -0
  361. data/ext/v8/upstream/3.1.8/src/runtime.h +582 -0
  362. data/ext/v8/upstream/3.1.8/src/runtime.js +643 -0
  363. data/ext/v8/upstream/3.1.8/src/safepoint-table.cc +253 -0
  364. data/ext/v8/upstream/3.1.8/src/safepoint-table.h +263 -0
  365. data/ext/v8/upstream/3.1.8/src/scanner-base.cc +971 -0
  366. data/ext/v8/upstream/3.1.8/src/scanner-base.h +653 -0
  367. data/ext/v8/upstream/3.1.8/src/scanner.cc +586 -0
  368. data/ext/v8/upstream/3.1.8/src/scanner.h +194 -0
  369. data/ext/v8/upstream/3.1.8/src/scopeinfo.cc +636 -0
  370. data/ext/v8/upstream/3.1.8/src/scopeinfo.h +238 -0
  371. data/ext/v8/upstream/3.1.8/src/scopes.cc +1063 -0
  372. data/ext/v8/upstream/3.1.8/src/scopes.h +494 -0
  373. data/ext/v8/upstream/3.1.8/src/serialize.cc +1535 -0
  374. data/ext/v8/upstream/3.1.8/src/serialize.h +584 -0
  375. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/shell.h +0 -0
  376. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/simulator.h +0 -0
  377. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/smart-pointer.h +0 -0
  378. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/snapshot-common.cc +0 -0
  379. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/snapshot-empty.cc +0 -0
  380. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/snapshot.h +0 -0
  381. data/ext/v8/upstream/3.1.8/src/spaces-inl.h +524 -0
  382. data/ext/v8/upstream/3.1.8/src/spaces.cc +3254 -0
  383. data/ext/v8/upstream/3.1.8/src/spaces.h +2362 -0
  384. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/splay-tree-inl.h +0 -0
  385. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/splay-tree.h +0 -0
  386. data/ext/v8/upstream/3.1.8/src/string-search.cc +40 -0
  387. data/ext/v8/upstream/3.1.8/src/string-search.h +567 -0
  388. data/ext/v8/upstream/3.1.8/src/string-stream.cc +584 -0
  389. data/ext/v8/upstream/3.1.8/src/string-stream.h +191 -0
  390. data/ext/v8/upstream/3.1.8/src/string.js +915 -0
  391. data/ext/v8/upstream/3.1.8/src/strtod.cc +440 -0
  392. data/ext/v8/upstream/3.1.8/src/strtod.h +40 -0
  393. data/ext/v8/upstream/3.1.8/src/stub-cache.cc +1878 -0
  394. data/ext/v8/upstream/3.1.8/src/stub-cache.h +849 -0
  395. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/third_party/valgrind/valgrind.h +0 -0
  396. data/ext/v8/upstream/3.1.8/src/token.cc +63 -0
  397. data/ext/v8/upstream/3.1.8/src/token.h +288 -0
  398. data/ext/v8/upstream/3.1.8/src/top.cc +1152 -0
  399. data/ext/v8/upstream/3.1.8/src/top.h +608 -0
  400. data/ext/v8/upstream/3.1.8/src/type-info.cc +406 -0
  401. data/ext/v8/upstream/3.1.8/src/type-info.h +283 -0
  402. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/unbound-queue-inl.h +0 -0
  403. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/unbound-queue.h +0 -0
  404. data/ext/v8/upstream/3.1.8/src/unicode-inl.h +238 -0
  405. data/ext/v8/upstream/3.1.8/src/unicode.cc +1624 -0
  406. data/ext/v8/upstream/3.1.8/src/unicode.h +280 -0
  407. data/ext/v8/upstream/3.1.8/src/uri.js +402 -0
  408. data/ext/v8/upstream/3.1.8/src/utils.cc +371 -0
  409. data/ext/v8/upstream/3.1.8/src/utils.h +793 -0
  410. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/v8-counters.cc +0 -0
  411. data/ext/v8/upstream/3.1.8/src/v8-counters.h +290 -0
  412. data/ext/v8/upstream/3.1.8/src/v8.cc +270 -0
  413. data/ext/v8/upstream/3.1.8/src/v8.h +127 -0
  414. data/ext/v8/upstream/3.1.8/src/v8checks.h +64 -0
  415. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/v8dll-main.cc +0 -0
  416. data/ext/v8/upstream/3.1.8/src/v8globals.h +480 -0
  417. data/ext/v8/upstream/3.1.8/src/v8natives.js +1252 -0
  418. data/ext/v8/upstream/3.1.8/src/v8preparserdll-main.cc +39 -0
  419. data/ext/v8/upstream/3.1.8/src/v8threads.cc +440 -0
  420. data/ext/v8/upstream/3.1.8/src/v8threads.h +157 -0
  421. data/ext/v8/upstream/3.1.8/src/v8utils.h +354 -0
  422. data/ext/v8/upstream/3.1.8/src/variables.cc +132 -0
  423. data/ext/v8/upstream/3.1.8/src/variables.h +212 -0
  424. data/ext/v8/upstream/3.1.8/src/version.cc +95 -0
  425. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/version.h +0 -0
  426. data/ext/v8/upstream/3.1.8/src/virtual-frame-heavy-inl.h +190 -0
  427. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame-heavy.cc +0 -0
  428. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame-inl.h +0 -0
  429. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame-light-inl.h +0 -0
  430. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame-light.cc +0 -0
  431. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/virtual-frame.cc +0 -0
  432. data/ext/v8/upstream/3.1.8/src/virtual-frame.h +59 -0
  433. data/ext/v8/upstream/3.1.8/src/vm-state-inl.h +134 -0
  434. data/ext/v8/upstream/3.1.8/src/vm-state.h +68 -0
  435. data/ext/v8/upstream/3.1.8/src/win32-headers.h +95 -0
  436. data/ext/v8/upstream/3.1.8/src/x64/assembler-x64-inl.h +455 -0
  437. data/ext/v8/upstream/3.1.8/src/x64/assembler-x64.cc +3162 -0
  438. data/ext/v8/upstream/3.1.8/src/x64/assembler-x64.h +1584 -0
  439. data/ext/v8/upstream/3.1.8/src/x64/builtins-x64.cc +1492 -0
  440. data/ext/v8/upstream/3.1.8/src/x64/code-stubs-x64.cc +5150 -0
  441. data/ext/v8/upstream/3.1.8/src/x64/code-stubs-x64.h +519 -0
  442. data/ext/v8/upstream/3.1.8/src/x64/codegen-x64-inl.h +46 -0
  443. data/ext/v8/upstream/3.1.8/src/x64/codegen-x64.cc +8835 -0
  444. data/ext/v8/upstream/3.1.8/src/x64/codegen-x64.h +750 -0
  445. data/ext/v8/upstream/3.1.8/src/x64/cpu-x64.cc +86 -0
  446. data/ext/v8/upstream/3.1.8/src/x64/debug-x64.cc +316 -0
  447. data/ext/v8/upstream/3.1.8/src/x64/deoptimizer-x64.cc +781 -0
  448. data/ext/v8/upstream/3.1.8/src/x64/disasm-x64.cc +1737 -0
  449. data/ext/v8/upstream/3.1.8/src/x64/frames-x64.cc +45 -0
  450. data/ext/v8/upstream/3.1.8/src/x64/frames-x64.h +130 -0
  451. data/ext/v8/upstream/3.1.8/src/x64/full-codegen-x64.cc +3984 -0
  452. data/ext/v8/upstream/3.1.8/src/x64/ic-x64.cc +1761 -0
  453. data/ext/v8/upstream/3.1.8/src/x64/jump-target-x64.cc +437 -0
  454. data/ext/v8/upstream/3.1.8/src/x64/lithium-codegen-x64.cc +3639 -0
  455. data/ext/v8/upstream/3.1.8/src/x64/lithium-codegen-x64.h +305 -0
  456. data/ext/v8/upstream/3.1.8/src/x64/lithium-gap-resolver-x64.cc +320 -0
  457. data/ext/v8/upstream/3.1.8/src/x64/lithium-gap-resolver-x64.h +74 -0
  458. data/ext/v8/upstream/3.1.8/src/x64/lithium-x64.cc +2044 -0
  459. data/ext/v8/upstream/3.1.8/src/x64/lithium-x64.h +2052 -0
  460. data/ext/v8/upstream/3.1.8/src/x64/macro-assembler-x64.cc +2660 -0
  461. data/ext/v8/upstream/3.1.8/src/x64/macro-assembler-x64.h +1852 -0
  462. data/ext/v8/upstream/3.1.8/src/x64/regexp-macro-assembler-x64.cc +1382 -0
  463. data/ext/v8/upstream/3.1.8/src/x64/regexp-macro-assembler-x64.h +278 -0
  464. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/x64/register-allocator-x64-inl.h +0 -0
  465. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/x64/register-allocator-x64.cc +0 -0
  466. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/x64/register-allocator-x64.h +0 -0
  467. data/ext/v8/upstream/{2.3.3 → 3.1.8}/src/x64/simulator-x64.cc +0 -0
  468. data/ext/v8/upstream/3.1.8/src/x64/simulator-x64.h +71 -0
  469. data/ext/v8/upstream/3.1.8/src/x64/stub-cache-x64.cc +3509 -0
  470. data/ext/v8/upstream/3.1.8/src/x64/virtual-frame-x64.cc +1292 -0
  471. data/ext/v8/upstream/3.1.8/src/x64/virtual-frame-x64.h +593 -0
  472. data/ext/v8/upstream/3.1.8/src/zone-inl.h +83 -0
  473. data/ext/v8/upstream/3.1.8/src/zone.cc +195 -0
  474. data/ext/v8/upstream/3.1.8/src/zone.h +233 -0
  475. data/ext/v8/upstream/3.1.8/tools/codemap.js +265 -0
  476. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/consarray.js +0 -0
  477. data/ext/v8/upstream/3.1.8/tools/csvparser.js +78 -0
  478. data/ext/v8/upstream/3.1.8/tools/disasm.py +92 -0
  479. data/ext/v8/upstream/3.1.8/tools/gc-nvp-trace-processor.py +328 -0
  480. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/generate-ten-powers.scm +0 -0
  481. data/ext/v8/upstream/3.1.8/tools/grokdump.py +840 -0
  482. data/ext/v8/upstream/3.1.8/tools/gyp/v8.gyp +869 -0
  483. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/js2c.py +0 -0
  484. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/jsmin.py +0 -0
  485. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/linux-tick-processor +0 -0
  486. data/ext/v8/upstream/3.1.8/tools/ll_prof.py +919 -0
  487. data/ext/v8/upstream/3.1.8/tools/logreader.js +185 -0
  488. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/mac-nm +0 -0
  489. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/mac-tick-processor +0 -0
  490. data/ext/v8/upstream/3.1.8/tools/oom_dump/README +31 -0
  491. data/ext/v8/upstream/3.1.8/tools/oom_dump/SConstruct +42 -0
  492. data/ext/v8/upstream/3.1.8/tools/oom_dump/oom_dump.cc +288 -0
  493. data/ext/v8/upstream/3.1.8/tools/presubmit.py +305 -0
  494. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/process-heap-prof.py +0 -0
  495. data/ext/v8/upstream/3.1.8/tools/profile.js +751 -0
  496. data/ext/v8/upstream/3.1.8/tools/profile_view.js +219 -0
  497. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/run-valgrind.py +0 -0
  498. data/ext/v8/upstream/3.1.8/tools/splaytree.js +316 -0
  499. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/stats-viewer.py +0 -0
  500. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/tickprocessor-driver.js +0 -0
  501. data/ext/v8/upstream/3.1.8/tools/tickprocessor.js +863 -0
  502. data/ext/v8/upstream/3.1.8/tools/utils.py +96 -0
  503. data/ext/v8/upstream/3.1.8/tools/visual_studio/README.txt +70 -0
  504. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/arm.vsprops +0 -0
  505. data/ext/v8/upstream/3.1.8/tools/visual_studio/common.vsprops +34 -0
  506. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/d8.vcproj +0 -0
  507. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/d8_arm.vcproj +0 -0
  508. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/d8_x64.vcproj +0 -0
  509. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/d8js2c.cmd +0 -0
  510. data/ext/v8/upstream/3.1.8/tools/visual_studio/debug.vsprops +17 -0
  511. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/ia32.vsprops +0 -0
  512. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/js2c.cmd +0 -0
  513. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/release.vsprops +0 -0
  514. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8.sln +0 -0
  515. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8.vcproj +0 -0
  516. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_arm.sln +0 -0
  517. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_arm.vcproj +0 -0
  518. data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base.vcproj +1296 -0
  519. data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base_arm.vcproj +1234 -0
  520. data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base_x64.vcproj +1296 -0
  521. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_cctest.vcproj +0 -0
  522. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_cctest_arm.vcproj +0 -0
  523. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_cctest_x64.vcproj +0 -0
  524. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_mksnapshot.vcproj +0 -0
  525. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_mksnapshot_x64.vcproj +0 -0
  526. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_process_sample.vcproj +0 -0
  527. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_process_sample_arm.vcproj +0 -0
  528. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_process_sample_x64.vcproj +0 -0
  529. data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_shell_sample.vcproj +147 -0
  530. data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_shell_sample_arm.vcproj +147 -0
  531. data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_shell_sample_x64.vcproj +163 -0
  532. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_snapshot.vcproj +0 -0
  533. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_snapshot_cc.vcproj +0 -0
  534. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_snapshot_cc_x64.vcproj +0 -0
  535. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_snapshot_x64.vcproj +0 -0
  536. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_x64.sln +0 -0
  537. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/v8_x64.vcproj +0 -0
  538. data/ext/v8/upstream/{2.3.3 → 3.1.8}/tools/visual_studio/x64.vsprops +0 -0
  539. data/ext/v8/upstream/3.1.8/tools/windows-tick-processor.bat +30 -0
  540. data/ext/v8/upstream/Makefile +2 -1
  541. data/ext/v8/v8_template.cpp +2 -2
  542. data/lib/v8/version.rb +1 -1
  543. data/spec/redjs/jsapi_spec.rb +2 -2
  544. metadata +552 -490
  545. data/ext/v8/upstream/2.3.3/.gitignore +0 -26
  546. data/ext/v8/upstream/2.3.3/AUTHORS +0 -31
  547. data/ext/v8/upstream/2.3.3/ChangeLog +0 -1916
  548. data/ext/v8/upstream/2.3.3/LICENSE +0 -55
  549. data/ext/v8/upstream/2.3.3/SConstruct +0 -1154
  550. data/ext/v8/upstream/2.3.3/include/v8-debug.h +0 -381
  551. data/ext/v8/upstream/2.3.3/include/v8-profiler.h +0 -353
  552. data/ext/v8/upstream/2.3.3/include/v8.h +0 -3616
  553. data/ext/v8/upstream/2.3.3/src/SConscript +0 -330
  554. data/ext/v8/upstream/2.3.3/src/accessors.cc +0 -661
  555. data/ext/v8/upstream/2.3.3/src/accessors.h +0 -114
  556. data/ext/v8/upstream/2.3.3/src/allocation.cc +0 -198
  557. data/ext/v8/upstream/2.3.3/src/allocation.h +0 -169
  558. data/ext/v8/upstream/2.3.3/src/api.cc +0 -4795
  559. data/ext/v8/upstream/2.3.3/src/api.h +0 -485
  560. data/ext/v8/upstream/2.3.3/src/apiutils.h +0 -69
  561. data/ext/v8/upstream/2.3.3/src/arguments.h +0 -96
  562. data/ext/v8/upstream/2.3.3/src/arm/assembler-arm-inl.h +0 -305
  563. data/ext/v8/upstream/2.3.3/src/arm/assembler-arm.cc +0 -2580
  564. data/ext/v8/upstream/2.3.3/src/arm/assembler-arm.h +0 -1275
  565. data/ext/v8/upstream/2.3.3/src/arm/builtins-arm.cc +0 -1320
  566. data/ext/v8/upstream/2.3.3/src/arm/codegen-arm-inl.h +0 -48
  567. data/ext/v8/upstream/2.3.3/src/arm/codegen-arm.cc +0 -11398
  568. data/ext/v8/upstream/2.3.3/src/arm/codegen-arm.h +0 -1102
  569. data/ext/v8/upstream/2.3.3/src/arm/constants-arm.cc +0 -154
  570. data/ext/v8/upstream/2.3.3/src/arm/constants-arm.h +0 -388
  571. data/ext/v8/upstream/2.3.3/src/arm/cpu-arm.cc +0 -142
  572. data/ext/v8/upstream/2.3.3/src/arm/debug-arm.cc +0 -309
  573. data/ext/v8/upstream/2.3.3/src/arm/disasm-arm.cc +0 -1459
  574. data/ext/v8/upstream/2.3.3/src/arm/fast-codegen-arm.cc +0 -241
  575. data/ext/v8/upstream/2.3.3/src/arm/frames-arm.cc +0 -123
  576. data/ext/v8/upstream/2.3.3/src/arm/frames-arm.h +0 -162
  577. data/ext/v8/upstream/2.3.3/src/arm/full-codegen-arm.cc +0 -3178
  578. data/ext/v8/upstream/2.3.3/src/arm/ic-arm.cc +0 -2258
  579. data/ext/v8/upstream/2.3.3/src/arm/jump-target-arm.cc +0 -164
  580. data/ext/v8/upstream/2.3.3/src/arm/macro-assembler-arm.cc +0 -1892
  581. data/ext/v8/upstream/2.3.3/src/arm/macro-assembler-arm.h +0 -727
  582. data/ext/v8/upstream/2.3.3/src/arm/regexp-macro-assembler-arm.cc +0 -1261
  583. data/ext/v8/upstream/2.3.3/src/arm/regexp-macro-assembler-arm.h +0 -266
  584. data/ext/v8/upstream/2.3.3/src/arm/simulator-arm.cc +0 -2822
  585. data/ext/v8/upstream/2.3.3/src/arm/simulator-arm.h +0 -361
  586. data/ext/v8/upstream/2.3.3/src/arm/stub-cache-arm.cc +0 -2387
  587. data/ext/v8/upstream/2.3.3/src/arm/virtual-frame-arm.cc +0 -834
  588. data/ext/v8/upstream/2.3.3/src/arm/virtual-frame-arm.h +0 -519
  589. data/ext/v8/upstream/2.3.3/src/array.js +0 -1127
  590. data/ext/v8/upstream/2.3.3/src/assembler.cc +0 -801
  591. data/ext/v8/upstream/2.3.3/src/assembler.h +0 -573
  592. data/ext/v8/upstream/2.3.3/src/ast-inl.h +0 -81
  593. data/ext/v8/upstream/2.3.3/src/ast.cc +0 -1152
  594. data/ext/v8/upstream/2.3.3/src/ast.h +0 -2106
  595. data/ext/v8/upstream/2.3.3/src/bootstrapper.cc +0 -1819
  596. data/ext/v8/upstream/2.3.3/src/builtins.cc +0 -1529
  597. data/ext/v8/upstream/2.3.3/src/builtins.h +0 -263
  598. data/ext/v8/upstream/2.3.3/src/bytecodes-irregexp.h +0 -104
  599. data/ext/v8/upstream/2.3.3/src/cached-powers.h +0 -119
  600. data/ext/v8/upstream/2.3.3/src/char-predicates-inl.h +0 -86
  601. data/ext/v8/upstream/2.3.3/src/checks.cc +0 -100
  602. data/ext/v8/upstream/2.3.3/src/checks.h +0 -310
  603. data/ext/v8/upstream/2.3.3/src/circular-queue.cc +0 -121
  604. data/ext/v8/upstream/2.3.3/src/code-stubs.cc +0 -177
  605. data/ext/v8/upstream/2.3.3/src/code-stubs.h +0 -177
  606. data/ext/v8/upstream/2.3.3/src/codegen-inl.h +0 -60
  607. data/ext/v8/upstream/2.3.3/src/codegen.cc +0 -516
  608. data/ext/v8/upstream/2.3.3/src/codegen.h +0 -897
  609. data/ext/v8/upstream/2.3.3/src/compilation-cache.cc +0 -562
  610. data/ext/v8/upstream/2.3.3/src/compilation-cache.h +0 -102
  611. data/ext/v8/upstream/2.3.3/src/compiler.cc +0 -654
  612. data/ext/v8/upstream/2.3.3/src/compiler.h +0 -299
  613. data/ext/v8/upstream/2.3.3/src/contexts.cc +0 -256
  614. data/ext/v8/upstream/2.3.3/src/contexts.h +0 -342
  615. data/ext/v8/upstream/2.3.3/src/conversions.cc +0 -1119
  616. data/ext/v8/upstream/2.3.3/src/conversions.h +0 -123
  617. data/ext/v8/upstream/2.3.3/src/counters.h +0 -239
  618. data/ext/v8/upstream/2.3.3/src/cpu-profiler-inl.h +0 -100
  619. data/ext/v8/upstream/2.3.3/src/cpu-profiler.cc +0 -538
  620. data/ext/v8/upstream/2.3.3/src/cpu-profiler.h +0 -285
  621. data/ext/v8/upstream/2.3.3/src/d8-debug.cc +0 -356
  622. data/ext/v8/upstream/2.3.3/src/d8-debug.h +0 -155
  623. data/ext/v8/upstream/2.3.3/src/d8.cc +0 -783
  624. data/ext/v8/upstream/2.3.3/src/d8.h +0 -227
  625. data/ext/v8/upstream/2.3.3/src/d8.js +0 -1683
  626. data/ext/v8/upstream/2.3.3/src/data-flow.cc +0 -758
  627. data/ext/v8/upstream/2.3.3/src/data-flow.h +0 -278
  628. data/ext/v8/upstream/2.3.3/src/date.js +0 -1059
  629. data/ext/v8/upstream/2.3.3/src/dateparser-inl.h +0 -123
  630. data/ext/v8/upstream/2.3.3/src/dateparser.h +0 -244
  631. data/ext/v8/upstream/2.3.3/src/debug-agent.cc +0 -427
  632. data/ext/v8/upstream/2.3.3/src/debug-agent.h +0 -129
  633. data/ext/v8/upstream/2.3.3/src/debug-debugger.js +0 -2227
  634. data/ext/v8/upstream/2.3.3/src/debug.cc +0 -3005
  635. data/ext/v8/upstream/2.3.3/src/debug.h +0 -993
  636. data/ext/v8/upstream/2.3.3/src/disassembler.cc +0 -312
  637. data/ext/v8/upstream/2.3.3/src/double.h +0 -169
  638. data/ext/v8/upstream/2.3.3/src/dtoa-config.c +0 -92
  639. data/ext/v8/upstream/2.3.3/src/dtoa.cc +0 -77
  640. data/ext/v8/upstream/2.3.3/src/dtoa.h +0 -81
  641. data/ext/v8/upstream/2.3.3/src/execution.cc +0 -809
  642. data/ext/v8/upstream/2.3.3/src/execution.h +0 -336
  643. data/ext/v8/upstream/2.3.3/src/factory.cc +0 -1003
  644. data/ext/v8/upstream/2.3.3/src/factory.h +0 -410
  645. data/ext/v8/upstream/2.3.3/src/fast-codegen.cc +0 -746
  646. data/ext/v8/upstream/2.3.3/src/fast-codegen.h +0 -161
  647. data/ext/v8/upstream/2.3.3/src/fast-dtoa.cc +0 -505
  648. data/ext/v8/upstream/2.3.3/src/fast-dtoa.h +0 -58
  649. data/ext/v8/upstream/2.3.3/src/flag-definitions.h +0 -455
  650. data/ext/v8/upstream/2.3.3/src/flags.cc +0 -551
  651. data/ext/v8/upstream/2.3.3/src/flags.h +0 -81
  652. data/ext/v8/upstream/2.3.3/src/flow-graph.cc +0 -763
  653. data/ext/v8/upstream/2.3.3/src/flow-graph.h +0 -180
  654. data/ext/v8/upstream/2.3.3/src/frame-element.h +0 -273
  655. data/ext/v8/upstream/2.3.3/src/frames-inl.h +0 -217
  656. data/ext/v8/upstream/2.3.3/src/frames.cc +0 -826
  657. data/ext/v8/upstream/2.3.3/src/frames.h +0 -682
  658. data/ext/v8/upstream/2.3.3/src/full-codegen.cc +0 -1443
  659. data/ext/v8/upstream/2.3.3/src/full-codegen.h +0 -548
  660. data/ext/v8/upstream/2.3.3/src/func-name-inferrer.cc +0 -76
  661. data/ext/v8/upstream/2.3.3/src/func-name-inferrer.h +0 -135
  662. data/ext/v8/upstream/2.3.3/src/global-handles.cc +0 -520
  663. data/ext/v8/upstream/2.3.3/src/global-handles.h +0 -180
  664. data/ext/v8/upstream/2.3.3/src/globals.h +0 -669
  665. data/ext/v8/upstream/2.3.3/src/handles-inl.h +0 -76
  666. data/ext/v8/upstream/2.3.3/src/handles.cc +0 -825
  667. data/ext/v8/upstream/2.3.3/src/handles.h +0 -393
  668. data/ext/v8/upstream/2.3.3/src/hashmap.cc +0 -226
  669. data/ext/v8/upstream/2.3.3/src/hashmap.h +0 -120
  670. data/ext/v8/upstream/2.3.3/src/heap-inl.h +0 -493
  671. data/ext/v8/upstream/2.3.3/src/heap-profiler.cc +0 -779
  672. data/ext/v8/upstream/2.3.3/src/heap-profiler.h +0 -323
  673. data/ext/v8/upstream/2.3.3/src/heap.cc +0 -4994
  674. data/ext/v8/upstream/2.3.3/src/heap.h +0 -1984
  675. data/ext/v8/upstream/2.3.3/src/ia32/assembler-ia32-inl.h +0 -360
  676. data/ext/v8/upstream/2.3.3/src/ia32/assembler-ia32.cc +0 -2600
  677. data/ext/v8/upstream/2.3.3/src/ia32/assembler-ia32.h +0 -969
  678. data/ext/v8/upstream/2.3.3/src/ia32/builtins-ia32.cc +0 -1261
  679. data/ext/v8/upstream/2.3.3/src/ia32/codegen-ia32.cc +0 -13968
  680. data/ext/v8/upstream/2.3.3/src/ia32/codegen-ia32.h +0 -1097
  681. data/ext/v8/upstream/2.3.3/src/ia32/cpu-ia32.cc +0 -83
  682. data/ext/v8/upstream/2.3.3/src/ia32/debug-ia32.cc +0 -309
  683. data/ext/v8/upstream/2.3.3/src/ia32/disasm-ia32.cc +0 -1471
  684. data/ext/v8/upstream/2.3.3/src/ia32/fast-codegen-ia32.cc +0 -954
  685. data/ext/v8/upstream/2.3.3/src/ia32/fast-codegen-ia32.h +0 -155
  686. data/ext/v8/upstream/2.3.3/src/ia32/frames-ia32.cc +0 -115
  687. data/ext/v8/upstream/2.3.3/src/ia32/frames-ia32.h +0 -135
  688. data/ext/v8/upstream/2.3.3/src/ia32/full-codegen-ia32.cc +0 -3281
  689. data/ext/v8/upstream/2.3.3/src/ia32/ic-ia32.cc +0 -1966
  690. data/ext/v8/upstream/2.3.3/src/ia32/macro-assembler-ia32.cc +0 -1610
  691. data/ext/v8/upstream/2.3.3/src/ia32/macro-assembler-ia32.h +0 -610
  692. data/ext/v8/upstream/2.3.3/src/ia32/regexp-macro-assembler-ia32.cc +0 -1247
  693. data/ext/v8/upstream/2.3.3/src/ia32/regexp-macro-assembler-ia32.h +0 -214
  694. data/ext/v8/upstream/2.3.3/src/ia32/simulator-ia32.h +0 -62
  695. data/ext/v8/upstream/2.3.3/src/ia32/stub-cache-ia32.cc +0 -2750
  696. data/ext/v8/upstream/2.3.3/src/ia32/virtual-frame-ia32.cc +0 -1334
  697. data/ext/v8/upstream/2.3.3/src/ia32/virtual-frame-ia32.h +0 -627
  698. data/ext/v8/upstream/2.3.3/src/ic-inl.h +0 -120
  699. data/ext/v8/upstream/2.3.3/src/ic.cc +0 -1827
  700. data/ext/v8/upstream/2.3.3/src/ic.h +0 -515
  701. data/ext/v8/upstream/2.3.3/src/interpreter-irregexp.cc +0 -646
  702. data/ext/v8/upstream/2.3.3/src/json.js +0 -268
  703. data/ext/v8/upstream/2.3.3/src/jsregexp.cc +0 -5283
  704. data/ext/v8/upstream/2.3.3/src/jsregexp.h +0 -1463
  705. data/ext/v8/upstream/2.3.3/src/jump-target-heavy.cc +0 -429
  706. data/ext/v8/upstream/2.3.3/src/jump-target-heavy.h +0 -244
  707. data/ext/v8/upstream/2.3.3/src/jump-target-light.cc +0 -110
  708. data/ext/v8/upstream/2.3.3/src/jump-target-light.h +0 -192
  709. data/ext/v8/upstream/2.3.3/src/list-inl.h +0 -166
  710. data/ext/v8/upstream/2.3.3/src/list.h +0 -159
  711. data/ext/v8/upstream/2.3.3/src/liveedit-debugger.js +0 -1057
  712. data/ext/v8/upstream/2.3.3/src/liveedit.cc +0 -1480
  713. data/ext/v8/upstream/2.3.3/src/liveedit.h +0 -170
  714. data/ext/v8/upstream/2.3.3/src/log-utils.cc +0 -497
  715. data/ext/v8/upstream/2.3.3/src/log-utils.h +0 -289
  716. data/ext/v8/upstream/2.3.3/src/log.cc +0 -1561
  717. data/ext/v8/upstream/2.3.3/src/log.h +0 -384
  718. data/ext/v8/upstream/2.3.3/src/macro-assembler.h +0 -86
  719. data/ext/v8/upstream/2.3.3/src/macros.py +0 -177
  720. data/ext/v8/upstream/2.3.3/src/mark-compact.cc +0 -2330
  721. data/ext/v8/upstream/2.3.3/src/mark-compact.h +0 -451
  722. data/ext/v8/upstream/2.3.3/src/math.js +0 -264
  723. data/ext/v8/upstream/2.3.3/src/memory.h +0 -74
  724. data/ext/v8/upstream/2.3.3/src/messages.cc +0 -183
  725. data/ext/v8/upstream/2.3.3/src/messages.h +0 -113
  726. data/ext/v8/upstream/2.3.3/src/messages.js +0 -982
  727. data/ext/v8/upstream/2.3.3/src/mips/assembler-mips.h +0 -668
  728. data/ext/v8/upstream/2.3.3/src/mips/builtins-mips.cc +0 -205
  729. data/ext/v8/upstream/2.3.3/src/mips/codegen-mips.h +0 -434
  730. data/ext/v8/upstream/2.3.3/src/mips/debug-mips.cc +0 -131
  731. data/ext/v8/upstream/2.3.3/src/mips/frames-mips.cc +0 -102
  732. data/ext/v8/upstream/2.3.3/src/mips/ic-mips.cc +0 -220
  733. data/ext/v8/upstream/2.3.3/src/mips/simulator-mips.cc +0 -1651
  734. data/ext/v8/upstream/2.3.3/src/mips/simulator-mips.h +0 -311
  735. data/ext/v8/upstream/2.3.3/src/mips/stub-cache-mips.cc +0 -403
  736. data/ext/v8/upstream/2.3.3/src/mirror-debugger.js +0 -2380
  737. data/ext/v8/upstream/2.3.3/src/objects-debug.cc +0 -1366
  738. data/ext/v8/upstream/2.3.3/src/objects-inl.h +0 -3333
  739. data/ext/v8/upstream/2.3.3/src/objects.cc +0 -8820
  740. data/ext/v8/upstream/2.3.3/src/objects.h +0 -5373
  741. data/ext/v8/upstream/2.3.3/src/oprofile-agent.cc +0 -108
  742. data/ext/v8/upstream/2.3.3/src/oprofile-agent.h +0 -77
  743. data/ext/v8/upstream/2.3.3/src/parser.cc +0 -5207
  744. data/ext/v8/upstream/2.3.3/src/parser.h +0 -197
  745. data/ext/v8/upstream/2.3.3/src/platform-freebsd.cc +0 -667
  746. data/ext/v8/upstream/2.3.3/src/platform-linux.cc +0 -862
  747. data/ext/v8/upstream/2.3.3/src/platform-macos.cc +0 -665
  748. data/ext/v8/upstream/2.3.3/src/platform-nullos.cc +0 -454
  749. data/ext/v8/upstream/2.3.3/src/platform-openbsd.cc +0 -622
  750. data/ext/v8/upstream/2.3.3/src/platform-posix.cc +0 -362
  751. data/ext/v8/upstream/2.3.3/src/platform-solaris.cc +0 -653
  752. data/ext/v8/upstream/2.3.3/src/platform-win32.cc +0 -1911
  753. data/ext/v8/upstream/2.3.3/src/platform.h +0 -577
  754. data/ext/v8/upstream/2.3.3/src/powers-ten.h +0 -2461
  755. data/ext/v8/upstream/2.3.3/src/prettyprinter.cc +0 -1531
  756. data/ext/v8/upstream/2.3.3/src/prettyprinter.h +0 -221
  757. data/ext/v8/upstream/2.3.3/src/profile-generator-inl.h +0 -148
  758. data/ext/v8/upstream/2.3.3/src/profile-generator.cc +0 -1830
  759. data/ext/v8/upstream/2.3.3/src/profile-generator.h +0 -853
  760. data/ext/v8/upstream/2.3.3/src/property.cc +0 -96
  761. data/ext/v8/upstream/2.3.3/src/property.h +0 -315
  762. data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler-irregexp.cc +0 -464
  763. data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler-irregexp.h +0 -141
  764. data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler-tracer.cc +0 -356
  765. data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler-tracer.h +0 -103
  766. data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler.cc +0 -261
  767. data/ext/v8/upstream/2.3.3/src/regexp-macro-assembler.h +0 -228
  768. data/ext/v8/upstream/2.3.3/src/regexp.js +0 -549
  769. data/ext/v8/upstream/2.3.3/src/rewriter.cc +0 -1038
  770. data/ext/v8/upstream/2.3.3/src/rewriter.h +0 -54
  771. data/ext/v8/upstream/2.3.3/src/runtime.cc +0 -10599
  772. data/ext/v8/upstream/2.3.3/src/runtime.h +0 -459
  773. data/ext/v8/upstream/2.3.3/src/runtime.js +0 -629
  774. data/ext/v8/upstream/2.3.3/src/scanner.cc +0 -1346
  775. data/ext/v8/upstream/2.3.3/src/scanner.h +0 -503
  776. data/ext/v8/upstream/2.3.3/src/scopeinfo.cc +0 -637
  777. data/ext/v8/upstream/2.3.3/src/scopeinfo.h +0 -233
  778. data/ext/v8/upstream/2.3.3/src/scopes.cc +0 -962
  779. data/ext/v8/upstream/2.3.3/src/scopes.h +0 -400
  780. data/ext/v8/upstream/2.3.3/src/serialize.cc +0 -1461
  781. data/ext/v8/upstream/2.3.3/src/serialize.h +0 -581
  782. data/ext/v8/upstream/2.3.3/src/spaces-inl.h +0 -483
  783. data/ext/v8/upstream/2.3.3/src/spaces.cc +0 -2901
  784. data/ext/v8/upstream/2.3.3/src/spaces.h +0 -2197
  785. data/ext/v8/upstream/2.3.3/src/string-stream.cc +0 -584
  786. data/ext/v8/upstream/2.3.3/src/string-stream.h +0 -189
  787. data/ext/v8/upstream/2.3.3/src/string.js +0 -1006
  788. data/ext/v8/upstream/2.3.3/src/stub-cache.cc +0 -1379
  789. data/ext/v8/upstream/2.3.3/src/stub-cache.h +0 -756
  790. data/ext/v8/upstream/2.3.3/src/third_party/dtoa/COPYING +0 -15
  791. data/ext/v8/upstream/2.3.3/src/third_party/dtoa/dtoa.c +0 -3334
  792. data/ext/v8/upstream/2.3.3/src/token.cc +0 -56
  793. data/ext/v8/upstream/2.3.3/src/token.h +0 -270
  794. data/ext/v8/upstream/2.3.3/src/top.cc +0 -1067
  795. data/ext/v8/upstream/2.3.3/src/top.h +0 -463
  796. data/ext/v8/upstream/2.3.3/src/type-info.cc +0 -53
  797. data/ext/v8/upstream/2.3.3/src/type-info.h +0 -244
  798. data/ext/v8/upstream/2.3.3/src/unicode-inl.h +0 -238
  799. data/ext/v8/upstream/2.3.3/src/unicode.cc +0 -749
  800. data/ext/v8/upstream/2.3.3/src/unicode.h +0 -279
  801. data/ext/v8/upstream/2.3.3/src/uri.js +0 -415
  802. data/ext/v8/upstream/2.3.3/src/utils.cc +0 -285
  803. data/ext/v8/upstream/2.3.3/src/utils.h +0 -745
  804. data/ext/v8/upstream/2.3.3/src/v8-counters.h +0 -250
  805. data/ext/v8/upstream/2.3.3/src/v8.cc +0 -228
  806. data/ext/v8/upstream/2.3.3/src/v8.h +0 -121
  807. data/ext/v8/upstream/2.3.3/src/v8natives.js +0 -1188
  808. data/ext/v8/upstream/2.3.3/src/v8threads.cc +0 -461
  809. data/ext/v8/upstream/2.3.3/src/v8threads.h +0 -159
  810. data/ext/v8/upstream/2.3.3/src/variables.cc +0 -119
  811. data/ext/v8/upstream/2.3.3/src/variables.h +0 -205
  812. data/ext/v8/upstream/2.3.3/src/version.cc +0 -88
  813. data/ext/v8/upstream/2.3.3/src/virtual-frame-heavy-inl.h +0 -192
  814. data/ext/v8/upstream/2.3.3/src/virtual-frame.h +0 -46
  815. data/ext/v8/upstream/2.3.3/src/vm-state-inl.h +0 -137
  816. data/ext/v8/upstream/2.3.3/src/vm-state.cc +0 -39
  817. data/ext/v8/upstream/2.3.3/src/vm-state.h +0 -77
  818. data/ext/v8/upstream/2.3.3/src/x64/assembler-x64-inl.h +0 -400
  819. data/ext/v8/upstream/2.3.3/src/x64/assembler-x64.cc +0 -2963
  820. data/ext/v8/upstream/2.3.3/src/x64/assembler-x64.h +0 -1438
  821. data/ext/v8/upstream/2.3.3/src/x64/builtins-x64.cc +0 -1296
  822. data/ext/v8/upstream/2.3.3/src/x64/codegen-x64-inl.h +0 -46
  823. data/ext/v8/upstream/2.3.3/src/x64/codegen-x64.cc +0 -12491
  824. data/ext/v8/upstream/2.3.3/src/x64/codegen-x64.h +0 -1090
  825. data/ext/v8/upstream/2.3.3/src/x64/cpu-x64.cc +0 -83
  826. data/ext/v8/upstream/2.3.3/src/x64/debug-x64.cc +0 -267
  827. data/ext/v8/upstream/2.3.3/src/x64/disasm-x64.cc +0 -1696
  828. data/ext/v8/upstream/2.3.3/src/x64/fast-codegen-x64.cc +0 -250
  829. data/ext/v8/upstream/2.3.3/src/x64/frames-x64.cc +0 -113
  830. data/ext/v8/upstream/2.3.3/src/x64/frames-x64.h +0 -125
  831. data/ext/v8/upstream/2.3.3/src/x64/full-codegen-x64.cc +0 -3270
  832. data/ext/v8/upstream/2.3.3/src/x64/ic-x64.cc +0 -1907
  833. data/ext/v8/upstream/2.3.3/src/x64/jump-target-x64.cc +0 -437
  834. data/ext/v8/upstream/2.3.3/src/x64/macro-assembler-x64.cc +0 -2793
  835. data/ext/v8/upstream/2.3.3/src/x64/macro-assembler-x64.h +0 -916
  836. data/ext/v8/upstream/2.3.3/src/x64/regexp-macro-assembler-x64.cc +0 -1374
  837. data/ext/v8/upstream/2.3.3/src/x64/regexp-macro-assembler-x64.h +0 -277
  838. data/ext/v8/upstream/2.3.3/src/x64/simulator-x64.h +0 -63
  839. data/ext/v8/upstream/2.3.3/src/x64/stub-cache-x64.cc +0 -2560
  840. data/ext/v8/upstream/2.3.3/src/x64/virtual-frame-x64.cc +0 -1264
  841. data/ext/v8/upstream/2.3.3/src/x64/virtual-frame-x64.h +0 -590
  842. data/ext/v8/upstream/2.3.3/src/zone-inl.h +0 -82
  843. data/ext/v8/upstream/2.3.3/src/zone.cc +0 -194
  844. data/ext/v8/upstream/2.3.3/src/zone.h +0 -221
  845. data/ext/v8/upstream/2.3.3/tools/codemap.js +0 -270
  846. data/ext/v8/upstream/2.3.3/tools/csvparser.js +0 -83
  847. data/ext/v8/upstream/2.3.3/tools/gc-nvp-trace-processor.py +0 -317
  848. data/ext/v8/upstream/2.3.3/tools/gyp/v8.gyp +0 -749
  849. data/ext/v8/upstream/2.3.3/tools/linux-tick-processor.py +0 -78
  850. data/ext/v8/upstream/2.3.3/tools/logreader.js +0 -338
  851. data/ext/v8/upstream/2.3.3/tools/oprofile/annotate +0 -7
  852. data/ext/v8/upstream/2.3.3/tools/oprofile/common +0 -19
  853. data/ext/v8/upstream/2.3.3/tools/oprofile/dump +0 -7
  854. data/ext/v8/upstream/2.3.3/tools/oprofile/report +0 -7
  855. data/ext/v8/upstream/2.3.3/tools/oprofile/reset +0 -7
  856. data/ext/v8/upstream/2.3.3/tools/oprofile/run +0 -14
  857. data/ext/v8/upstream/2.3.3/tools/oprofile/shutdown +0 -7
  858. data/ext/v8/upstream/2.3.3/tools/oprofile/start +0 -7
  859. data/ext/v8/upstream/2.3.3/tools/presubmit.py +0 -299
  860. data/ext/v8/upstream/2.3.3/tools/profile.js +0 -691
  861. data/ext/v8/upstream/2.3.3/tools/profile_view.js +0 -224
  862. data/ext/v8/upstream/2.3.3/tools/splaytree.js +0 -322
  863. data/ext/v8/upstream/2.3.3/tools/splaytree.py +0 -226
  864. data/ext/v8/upstream/2.3.3/tools/tickprocessor.js +0 -862
  865. data/ext/v8/upstream/2.3.3/tools/tickprocessor.py +0 -571
  866. data/ext/v8/upstream/2.3.3/tools/utils.py +0 -88
  867. data/ext/v8/upstream/2.3.3/tools/visual_studio/README.txt +0 -71
  868. data/ext/v8/upstream/2.3.3/tools/visual_studio/common.vsprops +0 -34
  869. data/ext/v8/upstream/2.3.3/tools/visual_studio/debug.vsprops +0 -17
  870. data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_base.vcproj +0 -1143
  871. data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_base_arm.vcproj +0 -1115
  872. data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_base_x64.vcproj +0 -1096
  873. data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_shell_sample.vcproj +0 -145
  874. data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_shell_sample_arm.vcproj +0 -145
  875. data/ext/v8/upstream/2.3.3/tools/visual_studio/v8_shell_sample_x64.vcproj +0 -161
  876. data/ext/v8/upstream/2.3.3/tools/windows-tick-processor.bat +0 -29
  877. data/ext/v8/upstream/2.3.3/tools/windows-tick-processor.py +0 -137
@@ -0,0 +1,1590 @@
1
+ // Copyright 2010 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 "v8.h"
29
+
30
+ #if defined(V8_TARGET_ARCH_IA32)
31
+
32
+ #include "codegen-inl.h"
33
+ #include "deoptimizer.h"
34
+ #include "full-codegen.h"
35
+
36
+ namespace v8 {
37
+ namespace internal {
38
+
39
+
40
+ #define __ ACCESS_MASM(masm)
41
+
42
+
43
+ void Builtins::Generate_Adaptor(MacroAssembler* masm,
44
+ CFunctionId id,
45
+ BuiltinExtraArguments extra_args) {
46
+ // ----------- S t a t e -------------
47
+ // -- eax : number of arguments excluding receiver
48
+ // -- edi : called function (only guaranteed when
49
+ // extra_args requires it)
50
+ // -- esi : context
51
+ // -- esp[0] : return address
52
+ // -- esp[4] : last argument
53
+ // -- ...
54
+ // -- esp[4 * argc] : first argument (argc == eax)
55
+ // -- esp[4 * (argc +1)] : receiver
56
+ // -----------------------------------
57
+
58
+ // Insert extra arguments.
59
+ int num_extra_args = 0;
60
+ if (extra_args == NEEDS_CALLED_FUNCTION) {
61
+ num_extra_args = 1;
62
+ Register scratch = ebx;
63
+ __ pop(scratch); // Save return address.
64
+ __ push(edi);
65
+ __ push(scratch); // Restore return address.
66
+ } else {
67
+ ASSERT(extra_args == NO_EXTRA_ARGUMENTS);
68
+ }
69
+
70
+ // JumpToExternalReference expects eax to contain the number of arguments
71
+ // including the receiver and the extra arguments.
72
+ __ add(Operand(eax), Immediate(num_extra_args + 1));
73
+ __ JumpToExternalReference(ExternalReference(id));
74
+ }
75
+
76
+
77
+ void Builtins::Generate_JSConstructCall(MacroAssembler* masm) {
78
+ // ----------- S t a t e -------------
79
+ // -- eax: number of arguments
80
+ // -- edi: constructor function
81
+ // -----------------------------------
82
+
83
+ Label non_function_call;
84
+ // Check that function is not a smi.
85
+ __ test(edi, Immediate(kSmiTagMask));
86
+ __ j(zero, &non_function_call);
87
+ // Check that function is a JSFunction.
88
+ __ CmpObjectType(edi, JS_FUNCTION_TYPE, ecx);
89
+ __ j(not_equal, &non_function_call);
90
+
91
+ // Jump to the function-specific construct stub.
92
+ __ mov(ebx, FieldOperand(edi, JSFunction::kSharedFunctionInfoOffset));
93
+ __ mov(ebx, FieldOperand(ebx, SharedFunctionInfo::kConstructStubOffset));
94
+ __ lea(ebx, FieldOperand(ebx, Code::kHeaderSize));
95
+ __ jmp(Operand(ebx));
96
+
97
+ // edi: called object
98
+ // eax: number of arguments
99
+ __ bind(&non_function_call);
100
+ // Set expected number of arguments to zero (not changing eax).
101
+ __ Set(ebx, Immediate(0));
102
+ __ GetBuiltinEntry(edx, Builtins::CALL_NON_FUNCTION_AS_CONSTRUCTOR);
103
+ __ jmp(Handle<Code>(builtin(ArgumentsAdaptorTrampoline)),
104
+ RelocInfo::CODE_TARGET);
105
+ }
106
+
107
+
108
+ static void Generate_JSConstructStubHelper(MacroAssembler* masm,
109
+ bool is_api_function,
110
+ bool count_constructions) {
111
+ // Should never count constructions for api objects.
112
+ ASSERT(!is_api_function || !count_constructions);
113
+
114
+ // Enter a construct frame.
115
+ __ EnterConstructFrame();
116
+
117
+ // Store a smi-tagged arguments count on the stack.
118
+ __ SmiTag(eax);
119
+ __ push(eax);
120
+
121
+ // Push the function to invoke on the stack.
122
+ __ push(edi);
123
+
124
+ // Try to allocate the object without transitioning into C code. If any of the
125
+ // preconditions is not met, the code bails out to the runtime call.
126
+ Label rt_call, allocated;
127
+ if (FLAG_inline_new) {
128
+ Label undo_allocation;
129
+ #ifdef ENABLE_DEBUGGER_SUPPORT
130
+ ExternalReference debug_step_in_fp =
131
+ ExternalReference::debug_step_in_fp_address();
132
+ __ cmp(Operand::StaticVariable(debug_step_in_fp), Immediate(0));
133
+ __ j(not_equal, &rt_call);
134
+ #endif
135
+
136
+ // Verified that the constructor is a JSFunction.
137
+ // Load the initial map and verify that it is in fact a map.
138
+ // edi: constructor
139
+ __ mov(eax, FieldOperand(edi, JSFunction::kPrototypeOrInitialMapOffset));
140
+ // Will both indicate a NULL and a Smi
141
+ __ test(eax, Immediate(kSmiTagMask));
142
+ __ j(zero, &rt_call);
143
+ // edi: constructor
144
+ // eax: initial map (if proven valid below)
145
+ __ CmpObjectType(eax, MAP_TYPE, ebx);
146
+ __ j(not_equal, &rt_call);
147
+
148
+ // Check that the constructor is not constructing a JSFunction (see comments
149
+ // in Runtime_NewObject in runtime.cc). In which case the initial map's
150
+ // instance type would be JS_FUNCTION_TYPE.
151
+ // edi: constructor
152
+ // eax: initial map
153
+ __ CmpInstanceType(eax, JS_FUNCTION_TYPE);
154
+ __ j(equal, &rt_call);
155
+
156
+ if (count_constructions) {
157
+ Label allocate;
158
+ // Decrease generous allocation count.
159
+ __ mov(ecx, FieldOperand(edi, JSFunction::kSharedFunctionInfoOffset));
160
+ __ dec_b(FieldOperand(ecx, SharedFunctionInfo::kConstructionCountOffset));
161
+ __ j(not_zero, &allocate);
162
+
163
+ __ push(eax);
164
+ __ push(edi);
165
+
166
+ __ push(edi); // constructor
167
+ // The call will replace the stub, so the countdown is only done once.
168
+ __ CallRuntime(Runtime::kFinalizeInstanceSize, 1);
169
+
170
+ __ pop(edi);
171
+ __ pop(eax);
172
+
173
+ __ bind(&allocate);
174
+ }
175
+
176
+ // Now allocate the JSObject on the heap.
177
+ // edi: constructor
178
+ // eax: initial map
179
+ __ movzx_b(edi, FieldOperand(eax, Map::kInstanceSizeOffset));
180
+ __ shl(edi, kPointerSizeLog2);
181
+ __ AllocateInNewSpace(edi, ebx, edi, no_reg, &rt_call, NO_ALLOCATION_FLAGS);
182
+ // Allocated the JSObject, now initialize the fields.
183
+ // eax: initial map
184
+ // ebx: JSObject
185
+ // edi: start of next object
186
+ __ mov(Operand(ebx, JSObject::kMapOffset), eax);
187
+ __ mov(ecx, Factory::empty_fixed_array());
188
+ __ mov(Operand(ebx, JSObject::kPropertiesOffset), ecx);
189
+ __ mov(Operand(ebx, JSObject::kElementsOffset), ecx);
190
+ // Set extra fields in the newly allocated object.
191
+ // eax: initial map
192
+ // ebx: JSObject
193
+ // edi: start of next object
194
+ { Label loop, entry;
195
+ // To allow for truncation.
196
+ if (count_constructions) {
197
+ __ mov(edx, Factory::one_pointer_filler_map());
198
+ } else {
199
+ __ mov(edx, Factory::undefined_value());
200
+ }
201
+ __ lea(ecx, Operand(ebx, JSObject::kHeaderSize));
202
+ __ jmp(&entry);
203
+ __ bind(&loop);
204
+ __ mov(Operand(ecx, 0), edx);
205
+ __ add(Operand(ecx), Immediate(kPointerSize));
206
+ __ bind(&entry);
207
+ __ cmp(ecx, Operand(edi));
208
+ __ j(less, &loop);
209
+ }
210
+
211
+ // Add the object tag to make the JSObject real, so that we can continue and
212
+ // jump into the continuation code at any time from now on. Any failures
213
+ // need to undo the allocation, so that the heap is in a consistent state
214
+ // and verifiable.
215
+ // eax: initial map
216
+ // ebx: JSObject
217
+ // edi: start of next object
218
+ __ or_(Operand(ebx), Immediate(kHeapObjectTag));
219
+
220
+ // Check if a non-empty properties array is needed.
221
+ // Allocate and initialize a FixedArray if it is.
222
+ // eax: initial map
223
+ // ebx: JSObject
224
+ // edi: start of next object
225
+ // Calculate the total number of properties described by the map.
226
+ __ movzx_b(edx, FieldOperand(eax, Map::kUnusedPropertyFieldsOffset));
227
+ __ movzx_b(ecx, FieldOperand(eax, Map::kPreAllocatedPropertyFieldsOffset));
228
+ __ add(edx, Operand(ecx));
229
+ // Calculate unused properties past the end of the in-object properties.
230
+ __ movzx_b(ecx, FieldOperand(eax, Map::kInObjectPropertiesOffset));
231
+ __ sub(edx, Operand(ecx));
232
+ // Done if no extra properties are to be allocated.
233
+ __ j(zero, &allocated);
234
+ __ Assert(positive, "Property allocation count failed.");
235
+
236
+ // Scale the number of elements by pointer size and add the header for
237
+ // FixedArrays to the start of the next object calculation from above.
238
+ // ebx: JSObject
239
+ // edi: start of next object (will be start of FixedArray)
240
+ // edx: number of elements in properties array
241
+ __ AllocateInNewSpace(FixedArray::kHeaderSize,
242
+ times_pointer_size,
243
+ edx,
244
+ edi,
245
+ ecx,
246
+ no_reg,
247
+ &undo_allocation,
248
+ RESULT_CONTAINS_TOP);
249
+
250
+ // Initialize the FixedArray.
251
+ // ebx: JSObject
252
+ // edi: FixedArray
253
+ // edx: number of elements
254
+ // ecx: start of next object
255
+ __ mov(eax, Factory::fixed_array_map());
256
+ __ mov(Operand(edi, FixedArray::kMapOffset), eax); // setup the map
257
+ __ SmiTag(edx);
258
+ __ mov(Operand(edi, FixedArray::kLengthOffset), edx); // and length
259
+
260
+ // Initialize the fields to undefined.
261
+ // ebx: JSObject
262
+ // edi: FixedArray
263
+ // ecx: start of next object
264
+ { Label loop, entry;
265
+ __ mov(edx, Factory::undefined_value());
266
+ __ lea(eax, Operand(edi, FixedArray::kHeaderSize));
267
+ __ jmp(&entry);
268
+ __ bind(&loop);
269
+ __ mov(Operand(eax, 0), edx);
270
+ __ add(Operand(eax), Immediate(kPointerSize));
271
+ __ bind(&entry);
272
+ __ cmp(eax, Operand(ecx));
273
+ __ j(below, &loop);
274
+ }
275
+
276
+ // Store the initialized FixedArray into the properties field of
277
+ // the JSObject
278
+ // ebx: JSObject
279
+ // edi: FixedArray
280
+ __ or_(Operand(edi), Immediate(kHeapObjectTag)); // add the heap tag
281
+ __ mov(FieldOperand(ebx, JSObject::kPropertiesOffset), edi);
282
+
283
+
284
+ // Continue with JSObject being successfully allocated
285
+ // ebx: JSObject
286
+ __ jmp(&allocated);
287
+
288
+ // Undo the setting of the new top so that the heap is verifiable. For
289
+ // example, the map's unused properties potentially do not match the
290
+ // allocated objects unused properties.
291
+ // ebx: JSObject (previous new top)
292
+ __ bind(&undo_allocation);
293
+ __ UndoAllocationInNewSpace(ebx);
294
+ }
295
+
296
+ // Allocate the new receiver object using the runtime call.
297
+ __ bind(&rt_call);
298
+ // Must restore edi (constructor) before calling runtime.
299
+ __ mov(edi, Operand(esp, 0));
300
+ // edi: function (constructor)
301
+ __ push(edi);
302
+ __ CallRuntime(Runtime::kNewObject, 1);
303
+ __ mov(ebx, Operand(eax)); // store result in ebx
304
+
305
+ // New object allocated.
306
+ // ebx: newly allocated object
307
+ __ bind(&allocated);
308
+ // Retrieve the function from the stack.
309
+ __ pop(edi);
310
+
311
+ // Retrieve smi-tagged arguments count from the stack.
312
+ __ mov(eax, Operand(esp, 0));
313
+ __ SmiUntag(eax);
314
+
315
+ // Push the allocated receiver to the stack. We need two copies
316
+ // because we may have to return the original one and the calling
317
+ // conventions dictate that the called function pops the receiver.
318
+ __ push(ebx);
319
+ __ push(ebx);
320
+
321
+ // Setup pointer to last argument.
322
+ __ lea(ebx, Operand(ebp, StandardFrameConstants::kCallerSPOffset));
323
+
324
+ // Copy arguments and receiver to the expression stack.
325
+ Label loop, entry;
326
+ __ mov(ecx, Operand(eax));
327
+ __ jmp(&entry);
328
+ __ bind(&loop);
329
+ __ push(Operand(ebx, ecx, times_4, 0));
330
+ __ bind(&entry);
331
+ __ dec(ecx);
332
+ __ j(greater_equal, &loop);
333
+
334
+ // Call the function.
335
+ if (is_api_function) {
336
+ __ mov(esi, FieldOperand(edi, JSFunction::kContextOffset));
337
+ Handle<Code> code = Handle<Code>(
338
+ Builtins::builtin(Builtins::HandleApiCallConstruct));
339
+ ParameterCount expected(0);
340
+ __ InvokeCode(code, expected, expected,
341
+ RelocInfo::CODE_TARGET, CALL_FUNCTION);
342
+ } else {
343
+ ParameterCount actual(eax);
344
+ __ InvokeFunction(edi, actual, CALL_FUNCTION);
345
+ }
346
+
347
+ // Restore context from the frame.
348
+ __ mov(esi, Operand(ebp, StandardFrameConstants::kContextOffset));
349
+
350
+ // If the result is an object (in the ECMA sense), we should get rid
351
+ // of the receiver and use the result; see ECMA-262 section 13.2.2-7
352
+ // on page 74.
353
+ Label use_receiver, exit;
354
+
355
+ // If the result is a smi, it is *not* an object in the ECMA sense.
356
+ __ test(eax, Immediate(kSmiTagMask));
357
+ __ j(zero, &use_receiver, not_taken);
358
+
359
+ // If the type of the result (stored in its map) is less than
360
+ // FIRST_JS_OBJECT_TYPE, it is not an object in the ECMA sense.
361
+ __ CmpObjectType(eax, FIRST_JS_OBJECT_TYPE, ecx);
362
+ __ j(above_equal, &exit, not_taken);
363
+
364
+ // Throw away the result of the constructor invocation and use the
365
+ // on-stack receiver as the result.
366
+ __ bind(&use_receiver);
367
+ __ mov(eax, Operand(esp, 0));
368
+
369
+ // Restore the arguments count and leave the construct frame.
370
+ __ bind(&exit);
371
+ __ mov(ebx, Operand(esp, kPointerSize)); // get arguments count
372
+ __ LeaveConstructFrame();
373
+
374
+ // Remove caller arguments from the stack and return.
375
+ ASSERT(kSmiTagSize == 1 && kSmiTag == 0);
376
+ __ pop(ecx);
377
+ __ lea(esp, Operand(esp, ebx, times_2, 1 * kPointerSize)); // 1 ~ receiver
378
+ __ push(ecx);
379
+ __ IncrementCounter(&Counters::constructed_objects, 1);
380
+ __ ret(0);
381
+ }
382
+
383
+
384
+ void Builtins::Generate_JSConstructStubCountdown(MacroAssembler* masm) {
385
+ Generate_JSConstructStubHelper(masm, false, true);
386
+ }
387
+
388
+
389
+ void Builtins::Generate_JSConstructStubGeneric(MacroAssembler* masm) {
390
+ Generate_JSConstructStubHelper(masm, false, false);
391
+ }
392
+
393
+
394
+ void Builtins::Generate_JSConstructStubApi(MacroAssembler* masm) {
395
+ Generate_JSConstructStubHelper(masm, true, false);
396
+ }
397
+
398
+
399
+ static void Generate_JSEntryTrampolineHelper(MacroAssembler* masm,
400
+ bool is_construct) {
401
+ // Clear the context before we push it when entering the JS frame.
402
+ __ Set(esi, Immediate(0));
403
+
404
+ // Enter an internal frame.
405
+ __ EnterInternalFrame();
406
+
407
+ // Load the previous frame pointer (ebx) to access C arguments
408
+ __ mov(ebx, Operand(ebp, 0));
409
+
410
+ // Get the function from the frame and setup the context.
411
+ __ mov(ecx, Operand(ebx, EntryFrameConstants::kFunctionArgOffset));
412
+ __ mov(esi, FieldOperand(ecx, JSFunction::kContextOffset));
413
+
414
+ // Push the function and the receiver onto the stack.
415
+ __ push(ecx);
416
+ __ push(Operand(ebx, EntryFrameConstants::kReceiverArgOffset));
417
+
418
+ // Load the number of arguments and setup pointer to the arguments.
419
+ __ mov(eax, Operand(ebx, EntryFrameConstants::kArgcOffset));
420
+ __ mov(ebx, Operand(ebx, EntryFrameConstants::kArgvOffset));
421
+
422
+ // Copy arguments to the stack in a loop.
423
+ Label loop, entry;
424
+ __ Set(ecx, Immediate(0));
425
+ __ jmp(&entry);
426
+ __ bind(&loop);
427
+ __ mov(edx, Operand(ebx, ecx, times_4, 0)); // push parameter from argv
428
+ __ push(Operand(edx, 0)); // dereference handle
429
+ __ inc(Operand(ecx));
430
+ __ bind(&entry);
431
+ __ cmp(ecx, Operand(eax));
432
+ __ j(not_equal, &loop);
433
+
434
+ // Get the function from the stack and call it.
435
+ __ mov(edi, Operand(esp, eax, times_4, +1 * kPointerSize)); // +1 ~ receiver
436
+
437
+ // Invoke the code.
438
+ if (is_construct) {
439
+ __ call(Handle<Code>(Builtins::builtin(Builtins::JSConstructCall)),
440
+ RelocInfo::CODE_TARGET);
441
+ } else {
442
+ ParameterCount actual(eax);
443
+ __ InvokeFunction(edi, actual, CALL_FUNCTION);
444
+ }
445
+
446
+ // Exit the JS frame. Notice that this also removes the empty
447
+ // context and the function left on the stack by the code
448
+ // invocation.
449
+ __ LeaveInternalFrame();
450
+ __ ret(1 * kPointerSize); // remove receiver
451
+ }
452
+
453
+
454
+ void Builtins::Generate_JSEntryTrampoline(MacroAssembler* masm) {
455
+ Generate_JSEntryTrampolineHelper(masm, false);
456
+ }
457
+
458
+
459
+ void Builtins::Generate_JSConstructEntryTrampoline(MacroAssembler* masm) {
460
+ Generate_JSEntryTrampolineHelper(masm, true);
461
+ }
462
+
463
+
464
+ void Builtins::Generate_LazyCompile(MacroAssembler* masm) {
465
+ // Enter an internal frame.
466
+ __ EnterInternalFrame();
467
+
468
+ // Push a copy of the function onto the stack.
469
+ __ push(edi);
470
+
471
+ __ push(edi); // Function is also the parameter to the runtime call.
472
+ __ CallRuntime(Runtime::kLazyCompile, 1);
473
+ __ pop(edi);
474
+
475
+ // Tear down temporary frame.
476
+ __ LeaveInternalFrame();
477
+
478
+ // Do a tail-call of the compiled function.
479
+ __ lea(ecx, FieldOperand(eax, Code::kHeaderSize));
480
+ __ jmp(Operand(ecx));
481
+ }
482
+
483
+
484
+ void Builtins::Generate_LazyRecompile(MacroAssembler* masm) {
485
+ // Enter an internal frame.
486
+ __ EnterInternalFrame();
487
+
488
+ // Push a copy of the function onto the stack.
489
+ __ push(edi);
490
+
491
+ __ push(edi); // Function is also the parameter to the runtime call.
492
+ __ CallRuntime(Runtime::kLazyRecompile, 1);
493
+
494
+ // Restore function and tear down temporary frame.
495
+ __ pop(edi);
496
+ __ LeaveInternalFrame();
497
+
498
+ // Do a tail-call of the compiled function.
499
+ __ lea(ecx, FieldOperand(eax, Code::kHeaderSize));
500
+ __ jmp(Operand(ecx));
501
+ }
502
+
503
+
504
+ static void Generate_NotifyDeoptimizedHelper(MacroAssembler* masm,
505
+ Deoptimizer::BailoutType type) {
506
+ // Enter an internal frame.
507
+ __ EnterInternalFrame();
508
+
509
+ // Pass the function and deoptimization type to the runtime system.
510
+ __ push(Immediate(Smi::FromInt(static_cast<int>(type))));
511
+ __ CallRuntime(Runtime::kNotifyDeoptimized, 1);
512
+
513
+ // Tear down temporary frame.
514
+ __ LeaveInternalFrame();
515
+
516
+ // Get the full codegen state from the stack and untag it.
517
+ __ mov(ecx, Operand(esp, 1 * kPointerSize));
518
+ __ SmiUntag(ecx);
519
+
520
+ // Switch on the state.
521
+ NearLabel not_no_registers, not_tos_eax;
522
+ __ cmp(ecx, FullCodeGenerator::NO_REGISTERS);
523
+ __ j(not_equal, &not_no_registers);
524
+ __ ret(1 * kPointerSize); // Remove state.
525
+
526
+ __ bind(&not_no_registers);
527
+ __ mov(eax, Operand(esp, 2 * kPointerSize));
528
+ __ cmp(ecx, FullCodeGenerator::TOS_REG);
529
+ __ j(not_equal, &not_tos_eax);
530
+ __ ret(2 * kPointerSize); // Remove state, eax.
531
+
532
+ __ bind(&not_tos_eax);
533
+ __ Abort("no cases left");
534
+ }
535
+
536
+
537
+ void Builtins::Generate_NotifyDeoptimized(MacroAssembler* masm) {
538
+ Generate_NotifyDeoptimizedHelper(masm, Deoptimizer::EAGER);
539
+ }
540
+
541
+
542
+ void Builtins::Generate_NotifyLazyDeoptimized(MacroAssembler* masm) {
543
+ Generate_NotifyDeoptimizedHelper(masm, Deoptimizer::LAZY);
544
+ }
545
+
546
+
547
+ void Builtins::Generate_NotifyOSR(MacroAssembler* masm) {
548
+ // TODO(kasperl): Do we need to save/restore the XMM registers too?
549
+
550
+ // For now, we are relying on the fact that Runtime::NotifyOSR
551
+ // doesn't do any garbage collection which allows us to save/restore
552
+ // the registers without worrying about which of them contain
553
+ // pointers. This seems a bit fragile.
554
+ __ pushad();
555
+ __ EnterInternalFrame();
556
+ __ CallRuntime(Runtime::kNotifyOSR, 0);
557
+ __ LeaveInternalFrame();
558
+ __ popad();
559
+ __ ret(0);
560
+ }
561
+
562
+
563
+ void Builtins::Generate_FunctionCall(MacroAssembler* masm) {
564
+ // 1. Make sure we have at least one argument.
565
+ { Label done;
566
+ __ test(eax, Operand(eax));
567
+ __ j(not_zero, &done, taken);
568
+ __ pop(ebx);
569
+ __ push(Immediate(Factory::undefined_value()));
570
+ __ push(ebx);
571
+ __ inc(eax);
572
+ __ bind(&done);
573
+ }
574
+
575
+ // 2. Get the function to call (passed as receiver) from the stack, check
576
+ // if it is a function.
577
+ Label non_function;
578
+ // 1 ~ return address.
579
+ __ mov(edi, Operand(esp, eax, times_4, 1 * kPointerSize));
580
+ __ test(edi, Immediate(kSmiTagMask));
581
+ __ j(zero, &non_function, not_taken);
582
+ __ CmpObjectType(edi, JS_FUNCTION_TYPE, ecx);
583
+ __ j(not_equal, &non_function, not_taken);
584
+
585
+
586
+ // 3a. Patch the first argument if necessary when calling a function.
587
+ Label shift_arguments;
588
+ { Label convert_to_object, use_global_receiver, patch_receiver;
589
+ // Change context eagerly in case we need the global receiver.
590
+ __ mov(esi, FieldOperand(edi, JSFunction::kContextOffset));
591
+
592
+ // Do not transform the receiver for strict mode functions.
593
+ __ mov(ebx, FieldOperand(edi, JSFunction::kSharedFunctionInfoOffset));
594
+ __ test_b(FieldOperand(ebx, SharedFunctionInfo::kStrictModeByteOffset),
595
+ 1 << SharedFunctionInfo::kStrictModeBitWithinByte);
596
+ __ j(not_equal, &shift_arguments);
597
+
598
+ // Compute the receiver in non-strict mode.
599
+ __ mov(ebx, Operand(esp, eax, times_4, 0)); // First argument.
600
+ __ test(ebx, Immediate(kSmiTagMask));
601
+ __ j(zero, &convert_to_object);
602
+
603
+ __ cmp(ebx, Factory::null_value());
604
+ __ j(equal, &use_global_receiver);
605
+ __ cmp(ebx, Factory::undefined_value());
606
+ __ j(equal, &use_global_receiver);
607
+
608
+ // We don't use IsObjectJSObjectType here because we jump on success.
609
+ __ mov(ecx, FieldOperand(ebx, HeapObject::kMapOffset));
610
+ __ movzx_b(ecx, FieldOperand(ecx, Map::kInstanceTypeOffset));
611
+ __ sub(Operand(ecx), Immediate(FIRST_JS_OBJECT_TYPE));
612
+ __ cmp(ecx, LAST_JS_OBJECT_TYPE - FIRST_JS_OBJECT_TYPE);
613
+ __ j(below_equal, &shift_arguments);
614
+
615
+ __ bind(&convert_to_object);
616
+ __ EnterInternalFrame(); // In order to preserve argument count.
617
+ __ SmiTag(eax);
618
+ __ push(eax);
619
+
620
+ __ push(ebx);
621
+ __ InvokeBuiltin(Builtins::TO_OBJECT, CALL_FUNCTION);
622
+ __ mov(ebx, eax);
623
+
624
+ __ pop(eax);
625
+ __ SmiUntag(eax);
626
+ __ LeaveInternalFrame();
627
+ // Restore the function to edi.
628
+ __ mov(edi, Operand(esp, eax, times_4, 1 * kPointerSize));
629
+ __ jmp(&patch_receiver);
630
+
631
+ // Use the global receiver object from the called function as the
632
+ // receiver.
633
+ __ bind(&use_global_receiver);
634
+ const int kGlobalIndex =
635
+ Context::kHeaderSize + Context::GLOBAL_INDEX * kPointerSize;
636
+ __ mov(ebx, FieldOperand(esi, kGlobalIndex));
637
+ __ mov(ebx, FieldOperand(ebx, GlobalObject::kGlobalContextOffset));
638
+ __ mov(ebx, FieldOperand(ebx, kGlobalIndex));
639
+ __ mov(ebx, FieldOperand(ebx, GlobalObject::kGlobalReceiverOffset));
640
+
641
+ __ bind(&patch_receiver);
642
+ __ mov(Operand(esp, eax, times_4, 0), ebx);
643
+
644
+ __ jmp(&shift_arguments);
645
+ }
646
+
647
+ // 3b. Patch the first argument when calling a non-function. The
648
+ // CALL_NON_FUNCTION builtin expects the non-function callee as
649
+ // receiver, so overwrite the first argument which will ultimately
650
+ // become the receiver.
651
+ __ bind(&non_function);
652
+ __ mov(Operand(esp, eax, times_4, 0), edi);
653
+ // Clear edi to indicate a non-function being called.
654
+ __ Set(edi, Immediate(0));
655
+
656
+ // 4. Shift arguments and return address one slot down on the stack
657
+ // (overwriting the original receiver). Adjust argument count to make
658
+ // the original first argument the new receiver.
659
+ __ bind(&shift_arguments);
660
+ { Label loop;
661
+ __ mov(ecx, eax);
662
+ __ bind(&loop);
663
+ __ mov(ebx, Operand(esp, ecx, times_4, 0));
664
+ __ mov(Operand(esp, ecx, times_4, kPointerSize), ebx);
665
+ __ dec(ecx);
666
+ __ j(not_sign, &loop); // While non-negative (to copy return address).
667
+ __ pop(ebx); // Discard copy of return address.
668
+ __ dec(eax); // One fewer argument (first argument is new receiver).
669
+ }
670
+
671
+ // 5a. Call non-function via tail call to CALL_NON_FUNCTION builtin.
672
+ { Label function;
673
+ __ test(edi, Operand(edi));
674
+ __ j(not_zero, &function, taken);
675
+ __ Set(ebx, Immediate(0));
676
+ __ GetBuiltinEntry(edx, Builtins::CALL_NON_FUNCTION);
677
+ __ jmp(Handle<Code>(builtin(ArgumentsAdaptorTrampoline)),
678
+ RelocInfo::CODE_TARGET);
679
+ __ bind(&function);
680
+ }
681
+
682
+ // 5b. Get the code to call from the function and check that the number of
683
+ // expected arguments matches what we're providing. If so, jump
684
+ // (tail-call) to the code in register edx without checking arguments.
685
+ __ mov(edx, FieldOperand(edi, JSFunction::kSharedFunctionInfoOffset));
686
+ __ mov(ebx,
687
+ FieldOperand(edx, SharedFunctionInfo::kFormalParameterCountOffset));
688
+ __ mov(edx, FieldOperand(edi, JSFunction::kCodeEntryOffset));
689
+ __ SmiUntag(ebx);
690
+ __ cmp(eax, Operand(ebx));
691
+ __ j(not_equal, Handle<Code>(builtin(ArgumentsAdaptorTrampoline)));
692
+
693
+ ParameterCount expected(0);
694
+ __ InvokeCode(Operand(edx), expected, expected, JUMP_FUNCTION);
695
+ }
696
+
697
+
698
+ void Builtins::Generate_FunctionApply(MacroAssembler* masm) {
699
+ __ EnterInternalFrame();
700
+
701
+ __ push(Operand(ebp, 4 * kPointerSize)); // push this
702
+ __ push(Operand(ebp, 2 * kPointerSize)); // push arguments
703
+ __ InvokeBuiltin(Builtins::APPLY_PREPARE, CALL_FUNCTION);
704
+
705
+ // Check the stack for overflow. We are not trying need to catch
706
+ // interruptions (e.g. debug break and preemption) here, so the "real stack
707
+ // limit" is checked.
708
+ Label okay;
709
+ ExternalReference real_stack_limit =
710
+ ExternalReference::address_of_real_stack_limit();
711
+ __ mov(edi, Operand::StaticVariable(real_stack_limit));
712
+ // Make ecx the space we have left. The stack might already be overflowed
713
+ // here which will cause ecx to become negative.
714
+ __ mov(ecx, Operand(esp));
715
+ __ sub(ecx, Operand(edi));
716
+ // Make edx the space we need for the array when it is unrolled onto the
717
+ // stack.
718
+ __ mov(edx, Operand(eax));
719
+ __ shl(edx, kPointerSizeLog2 - kSmiTagSize);
720
+ // Check if the arguments will overflow the stack.
721
+ __ cmp(ecx, Operand(edx));
722
+ __ j(greater, &okay, taken); // Signed comparison.
723
+
724
+ // Out of stack space.
725
+ __ push(Operand(ebp, 4 * kPointerSize)); // push this
726
+ __ push(eax);
727
+ __ InvokeBuiltin(Builtins::APPLY_OVERFLOW, CALL_FUNCTION);
728
+ __ bind(&okay);
729
+ // End of stack check.
730
+
731
+ // Push current index and limit.
732
+ const int kLimitOffset =
733
+ StandardFrameConstants::kExpressionsOffset - 1 * kPointerSize;
734
+ const int kIndexOffset = kLimitOffset - 1 * kPointerSize;
735
+ __ push(eax); // limit
736
+ __ push(Immediate(0)); // index
737
+
738
+ // Change context eagerly to get the right global object if
739
+ // necessary.
740
+ __ mov(edi, Operand(ebp, 4 * kPointerSize));
741
+ __ mov(esi, FieldOperand(edi, JSFunction::kContextOffset));
742
+
743
+ // Compute the receiver.
744
+ Label call_to_object, use_global_receiver, push_receiver;
745
+ __ mov(ebx, Operand(ebp, 3 * kPointerSize));
746
+
747
+ // Do not transform the receiver for strict mode functions.
748
+ __ mov(ecx, FieldOperand(edi, JSFunction::kSharedFunctionInfoOffset));
749
+ __ test_b(FieldOperand(ecx, SharedFunctionInfo::kStrictModeByteOffset),
750
+ 1 << SharedFunctionInfo::kStrictModeBitWithinByte);
751
+ __ j(not_equal, &push_receiver);
752
+
753
+ // Compute the receiver in non-strict mode.
754
+ __ test(ebx, Immediate(kSmiTagMask));
755
+ __ j(zero, &call_to_object);
756
+ __ cmp(ebx, Factory::null_value());
757
+ __ j(equal, &use_global_receiver);
758
+ __ cmp(ebx, Factory::undefined_value());
759
+ __ j(equal, &use_global_receiver);
760
+
761
+ // If given receiver is already a JavaScript object then there's no
762
+ // reason for converting it.
763
+ // We don't use IsObjectJSObjectType here because we jump on success.
764
+ __ mov(ecx, FieldOperand(ebx, HeapObject::kMapOffset));
765
+ __ movzx_b(ecx, FieldOperand(ecx, Map::kInstanceTypeOffset));
766
+ __ sub(Operand(ecx), Immediate(FIRST_JS_OBJECT_TYPE));
767
+ __ cmp(ecx, LAST_JS_OBJECT_TYPE - FIRST_JS_OBJECT_TYPE);
768
+ __ j(below_equal, &push_receiver);
769
+
770
+ // Convert the receiver to an object.
771
+ __ bind(&call_to_object);
772
+ __ push(ebx);
773
+ __ InvokeBuiltin(Builtins::TO_OBJECT, CALL_FUNCTION);
774
+ __ mov(ebx, Operand(eax));
775
+ __ jmp(&push_receiver);
776
+
777
+ // Use the current global receiver object as the receiver.
778
+ __ bind(&use_global_receiver);
779
+ const int kGlobalOffset =
780
+ Context::kHeaderSize + Context::GLOBAL_INDEX * kPointerSize;
781
+ __ mov(ebx, FieldOperand(esi, kGlobalOffset));
782
+ __ mov(ebx, FieldOperand(ebx, GlobalObject::kGlobalContextOffset));
783
+ __ mov(ebx, FieldOperand(ebx, kGlobalOffset));
784
+ __ mov(ebx, FieldOperand(ebx, GlobalObject::kGlobalReceiverOffset));
785
+
786
+ // Push the receiver.
787
+ __ bind(&push_receiver);
788
+ __ push(ebx);
789
+
790
+ // Copy all arguments from the array to the stack.
791
+ Label entry, loop;
792
+ __ mov(eax, Operand(ebp, kIndexOffset));
793
+ __ jmp(&entry);
794
+ __ bind(&loop);
795
+ __ mov(edx, Operand(ebp, 2 * kPointerSize)); // load arguments
796
+
797
+ // Use inline caching to speed up access to arguments.
798
+ Handle<Code> ic(Builtins::builtin(Builtins::KeyedLoadIC_Initialize));
799
+ __ call(ic, RelocInfo::CODE_TARGET);
800
+ // It is important that we do not have a test instruction after the
801
+ // call. A test instruction after the call is used to indicate that
802
+ // we have generated an inline version of the keyed load. In this
803
+ // case, we know that we are not generating a test instruction next.
804
+
805
+ // Push the nth argument.
806
+ __ push(eax);
807
+
808
+ // Update the index on the stack and in register eax.
809
+ __ mov(eax, Operand(ebp, kIndexOffset));
810
+ __ add(Operand(eax), Immediate(1 << kSmiTagSize));
811
+ __ mov(Operand(ebp, kIndexOffset), eax);
812
+
813
+ __ bind(&entry);
814
+ __ cmp(eax, Operand(ebp, kLimitOffset));
815
+ __ j(not_equal, &loop);
816
+
817
+ // Invoke the function.
818
+ ParameterCount actual(eax);
819
+ __ SmiUntag(eax);
820
+ __ mov(edi, Operand(ebp, 4 * kPointerSize));
821
+ __ InvokeFunction(edi, actual, CALL_FUNCTION);
822
+
823
+ __ LeaveInternalFrame();
824
+ __ ret(3 * kPointerSize); // remove this, receiver, and arguments
825
+ }
826
+
827
+
828
+ // Number of empty elements to allocate for an empty array.
829
+ static const int kPreallocatedArrayElements = 4;
830
+
831
+
832
+ // Allocate an empty JSArray. The allocated array is put into the result
833
+ // register. If the parameter initial_capacity is larger than zero an elements
834
+ // backing store is allocated with this size and filled with the hole values.
835
+ // Otherwise the elements backing store is set to the empty FixedArray.
836
+ static void AllocateEmptyJSArray(MacroAssembler* masm,
837
+ Register array_function,
838
+ Register result,
839
+ Register scratch1,
840
+ Register scratch2,
841
+ Register scratch3,
842
+ int initial_capacity,
843
+ Label* gc_required) {
844
+ ASSERT(initial_capacity >= 0);
845
+
846
+ // Load the initial map from the array function.
847
+ __ mov(scratch1, FieldOperand(array_function,
848
+ JSFunction::kPrototypeOrInitialMapOffset));
849
+
850
+ // Allocate the JSArray object together with space for a fixed array with the
851
+ // requested elements.
852
+ int size = JSArray::kSize;
853
+ if (initial_capacity > 0) {
854
+ size += FixedArray::SizeFor(initial_capacity);
855
+ }
856
+ __ AllocateInNewSpace(size,
857
+ result,
858
+ scratch2,
859
+ scratch3,
860
+ gc_required,
861
+ TAG_OBJECT);
862
+
863
+ // Allocated the JSArray. Now initialize the fields except for the elements
864
+ // array.
865
+ // result: JSObject
866
+ // scratch1: initial map
867
+ // scratch2: start of next object
868
+ __ mov(FieldOperand(result, JSObject::kMapOffset), scratch1);
869
+ __ mov(FieldOperand(result, JSArray::kPropertiesOffset),
870
+ Factory::empty_fixed_array());
871
+ // Field JSArray::kElementsOffset is initialized later.
872
+ __ mov(FieldOperand(result, JSArray::kLengthOffset), Immediate(0));
873
+
874
+ // If no storage is requested for the elements array just set the empty
875
+ // fixed array.
876
+ if (initial_capacity == 0) {
877
+ __ mov(FieldOperand(result, JSArray::kElementsOffset),
878
+ Factory::empty_fixed_array());
879
+ return;
880
+ }
881
+
882
+ // Calculate the location of the elements array and set elements array member
883
+ // of the JSArray.
884
+ // result: JSObject
885
+ // scratch2: start of next object
886
+ __ lea(scratch1, Operand(result, JSArray::kSize));
887
+ __ mov(FieldOperand(result, JSArray::kElementsOffset), scratch1);
888
+
889
+ // Initialize the FixedArray and fill it with holes. FixedArray length is
890
+ // stored as a smi.
891
+ // result: JSObject
892
+ // scratch1: elements array
893
+ // scratch2: start of next object
894
+ __ mov(FieldOperand(scratch1, FixedArray::kMapOffset),
895
+ Factory::fixed_array_map());
896
+ __ mov(FieldOperand(scratch1, FixedArray::kLengthOffset),
897
+ Immediate(Smi::FromInt(initial_capacity)));
898
+
899
+ // Fill the FixedArray with the hole value. Inline the code if short.
900
+ // Reconsider loop unfolding if kPreallocatedArrayElements gets changed.
901
+ static const int kLoopUnfoldLimit = 4;
902
+ ASSERT(kPreallocatedArrayElements <= kLoopUnfoldLimit);
903
+ if (initial_capacity <= kLoopUnfoldLimit) {
904
+ // Use a scratch register here to have only one reloc info when unfolding
905
+ // the loop.
906
+ __ mov(scratch3, Factory::the_hole_value());
907
+ for (int i = 0; i < initial_capacity; i++) {
908
+ __ mov(FieldOperand(scratch1,
909
+ FixedArray::kHeaderSize + i * kPointerSize),
910
+ scratch3);
911
+ }
912
+ } else {
913
+ Label loop, entry;
914
+ __ jmp(&entry);
915
+ __ bind(&loop);
916
+ __ mov(Operand(scratch1, 0), Factory::the_hole_value());
917
+ __ add(Operand(scratch1), Immediate(kPointerSize));
918
+ __ bind(&entry);
919
+ __ cmp(scratch1, Operand(scratch2));
920
+ __ j(below, &loop);
921
+ }
922
+ }
923
+
924
+
925
+ // Allocate a JSArray with the number of elements stored in a register. The
926
+ // register array_function holds the built-in Array function and the register
927
+ // array_size holds the size of the array as a smi. The allocated array is put
928
+ // into the result register and beginning and end of the FixedArray elements
929
+ // storage is put into registers elements_array and elements_array_end (see
930
+ // below for when that is not the case). If the parameter fill_with_holes is
931
+ // true the allocated elements backing store is filled with the hole values
932
+ // otherwise it is left uninitialized. When the backing store is filled the
933
+ // register elements_array is scratched.
934
+ static void AllocateJSArray(MacroAssembler* masm,
935
+ Register array_function, // Array function.
936
+ Register array_size, // As a smi, cannot be 0.
937
+ Register result,
938
+ Register elements_array,
939
+ Register elements_array_end,
940
+ Register scratch,
941
+ bool fill_with_hole,
942
+ Label* gc_required) {
943
+ ASSERT(scratch.is(edi)); // rep stos destination
944
+ ASSERT(!fill_with_hole || array_size.is(ecx)); // rep stos count
945
+ ASSERT(!fill_with_hole || !result.is(eax)); // result is never eax
946
+
947
+ // Load the initial map from the array function.
948
+ __ mov(elements_array,
949
+ FieldOperand(array_function,
950
+ JSFunction::kPrototypeOrInitialMapOffset));
951
+
952
+ // Allocate the JSArray object together with space for a FixedArray with the
953
+ // requested elements.
954
+ ASSERT(kSmiTagSize == 1 && kSmiTag == 0);
955
+ __ AllocateInNewSpace(JSArray::kSize + FixedArray::kHeaderSize,
956
+ times_half_pointer_size, // array_size is a smi.
957
+ array_size,
958
+ result,
959
+ elements_array_end,
960
+ scratch,
961
+ gc_required,
962
+ TAG_OBJECT);
963
+
964
+ // Allocated the JSArray. Now initialize the fields except for the elements
965
+ // array.
966
+ // result: JSObject
967
+ // elements_array: initial map
968
+ // elements_array_end: start of next object
969
+ // array_size: size of array (smi)
970
+ __ mov(FieldOperand(result, JSObject::kMapOffset), elements_array);
971
+ __ mov(elements_array, Factory::empty_fixed_array());
972
+ __ mov(FieldOperand(result, JSArray::kPropertiesOffset), elements_array);
973
+ // Field JSArray::kElementsOffset is initialized later.
974
+ __ mov(FieldOperand(result, JSArray::kLengthOffset), array_size);
975
+
976
+ // Calculate the location of the elements array and set elements array member
977
+ // of the JSArray.
978
+ // result: JSObject
979
+ // elements_array_end: start of next object
980
+ // array_size: size of array (smi)
981
+ __ lea(elements_array, Operand(result, JSArray::kSize));
982
+ __ mov(FieldOperand(result, JSArray::kElementsOffset), elements_array);
983
+
984
+ // Initialize the fixed array. FixedArray length is stored as a smi.
985
+ // result: JSObject
986
+ // elements_array: elements array
987
+ // elements_array_end: start of next object
988
+ // array_size: size of array (smi)
989
+ __ mov(FieldOperand(elements_array, FixedArray::kMapOffset),
990
+ Factory::fixed_array_map());
991
+ // For non-empty JSArrays the length of the FixedArray and the JSArray is the
992
+ // same.
993
+ __ mov(FieldOperand(elements_array, FixedArray::kLengthOffset), array_size);
994
+
995
+ // Fill the allocated FixedArray with the hole value if requested.
996
+ // result: JSObject
997
+ // elements_array: elements array
998
+ if (fill_with_hole) {
999
+ __ SmiUntag(array_size);
1000
+ __ lea(edi, Operand(elements_array,
1001
+ FixedArray::kHeaderSize - kHeapObjectTag));
1002
+ __ mov(eax, Factory::the_hole_value());
1003
+ __ cld();
1004
+ // Do not use rep stos when filling less than kRepStosThreshold
1005
+ // words.
1006
+ const int kRepStosThreshold = 16;
1007
+ Label loop, entry, done;
1008
+ __ cmp(ecx, kRepStosThreshold);
1009
+ __ j(below, &loop); // Note: ecx > 0.
1010
+ __ rep_stos();
1011
+ __ jmp(&done);
1012
+ __ bind(&loop);
1013
+ __ stos();
1014
+ __ bind(&entry);
1015
+ __ cmp(edi, Operand(elements_array_end));
1016
+ __ j(below, &loop);
1017
+ __ bind(&done);
1018
+ }
1019
+ }
1020
+
1021
+
1022
+ // Create a new array for the built-in Array function. This function allocates
1023
+ // the JSArray object and the FixedArray elements array and initializes these.
1024
+ // If the Array cannot be constructed in native code the runtime is called. This
1025
+ // function assumes the following state:
1026
+ // edi: constructor (built-in Array function)
1027
+ // eax: argc
1028
+ // esp[0]: return address
1029
+ // esp[4]: last argument
1030
+ // This function is used for both construct and normal calls of Array. Whether
1031
+ // it is a construct call or not is indicated by the construct_call parameter.
1032
+ // The only difference between handling a construct call and a normal call is
1033
+ // that for a construct call the constructor function in edi needs to be
1034
+ // preserved for entering the generic code. In both cases argc in eax needs to
1035
+ // be preserved.
1036
+ static void ArrayNativeCode(MacroAssembler* masm,
1037
+ bool construct_call,
1038
+ Label* call_generic_code) {
1039
+ Label argc_one_or_more, argc_two_or_more, prepare_generic_code_call,
1040
+ empty_array, not_empty_array;
1041
+
1042
+ // Push the constructor and argc. No need to tag argc as a smi, as there will
1043
+ // be no garbage collection with this on the stack.
1044
+ int push_count = 0;
1045
+ if (construct_call) {
1046
+ push_count++;
1047
+ __ push(edi);
1048
+ }
1049
+ push_count++;
1050
+ __ push(eax);
1051
+
1052
+ // Check for array construction with zero arguments.
1053
+ __ test(eax, Operand(eax));
1054
+ __ j(not_zero, &argc_one_or_more);
1055
+
1056
+ __ bind(&empty_array);
1057
+ // Handle construction of an empty array.
1058
+ AllocateEmptyJSArray(masm,
1059
+ edi,
1060
+ eax,
1061
+ ebx,
1062
+ ecx,
1063
+ edi,
1064
+ kPreallocatedArrayElements,
1065
+ &prepare_generic_code_call);
1066
+ __ IncrementCounter(&Counters::array_function_native, 1);
1067
+ __ pop(ebx);
1068
+ if (construct_call) {
1069
+ __ pop(edi);
1070
+ }
1071
+ __ ret(kPointerSize);
1072
+
1073
+ // Check for one argument. Bail out if argument is not smi or if it is
1074
+ // negative.
1075
+ __ bind(&argc_one_or_more);
1076
+ __ cmp(eax, 1);
1077
+ __ j(not_equal, &argc_two_or_more);
1078
+ ASSERT(kSmiTag == 0);
1079
+ __ mov(ecx, Operand(esp, (push_count + 1) * kPointerSize));
1080
+ __ test(ecx, Operand(ecx));
1081
+ __ j(not_zero, &not_empty_array);
1082
+
1083
+ // The single argument passed is zero, so we jump to the code above used to
1084
+ // handle the case of no arguments passed. To adapt the stack for that we move
1085
+ // the return address and the pushed constructor (if pushed) one stack slot up
1086
+ // thereby removing the passed argument. Argc is also on the stack - at the
1087
+ // bottom - and it needs to be changed from 1 to 0 to have the call into the
1088
+ // runtime system work in case a GC is required.
1089
+ for (int i = push_count; i > 0; i--) {
1090
+ __ mov(eax, Operand(esp, i * kPointerSize));
1091
+ __ mov(Operand(esp, (i + 1) * kPointerSize), eax);
1092
+ }
1093
+ __ add(Operand(esp), Immediate(2 * kPointerSize)); // Drop two stack slots.
1094
+ __ push(Immediate(0)); // Treat this as a call with argc of zero.
1095
+ __ jmp(&empty_array);
1096
+
1097
+ __ bind(&not_empty_array);
1098
+ __ test(ecx, Immediate(kIntptrSignBit | kSmiTagMask));
1099
+ __ j(not_zero, &prepare_generic_code_call);
1100
+
1101
+ // Handle construction of an empty array of a certain size. Get the size from
1102
+ // the stack and bail out if size is to large to actually allocate an elements
1103
+ // array.
1104
+ __ cmp(ecx, JSObject::kInitialMaxFastElementArray << kSmiTagSize);
1105
+ __ j(greater_equal, &prepare_generic_code_call);
1106
+
1107
+ // edx: array_size (smi)
1108
+ // edi: constructor
1109
+ // esp[0]: argc (cannot be 0 here)
1110
+ // esp[4]: constructor (only if construct_call)
1111
+ // esp[8]: return address
1112
+ // esp[C]: argument
1113
+ AllocateJSArray(masm,
1114
+ edi,
1115
+ ecx,
1116
+ ebx,
1117
+ eax,
1118
+ edx,
1119
+ edi,
1120
+ true,
1121
+ &prepare_generic_code_call);
1122
+ __ IncrementCounter(&Counters::array_function_native, 1);
1123
+ __ mov(eax, ebx);
1124
+ __ pop(ebx);
1125
+ if (construct_call) {
1126
+ __ pop(edi);
1127
+ }
1128
+ __ ret(2 * kPointerSize);
1129
+
1130
+ // Handle construction of an array from a list of arguments.
1131
+ __ bind(&argc_two_or_more);
1132
+ ASSERT(kSmiTag == 0);
1133
+ __ SmiTag(eax); // Convet argc to a smi.
1134
+ // eax: array_size (smi)
1135
+ // edi: constructor
1136
+ // esp[0] : argc
1137
+ // esp[4]: constructor (only if construct_call)
1138
+ // esp[8] : return address
1139
+ // esp[C] : last argument
1140
+ AllocateJSArray(masm,
1141
+ edi,
1142
+ eax,
1143
+ ebx,
1144
+ ecx,
1145
+ edx,
1146
+ edi,
1147
+ false,
1148
+ &prepare_generic_code_call);
1149
+ __ IncrementCounter(&Counters::array_function_native, 1);
1150
+ __ mov(eax, ebx);
1151
+ __ pop(ebx);
1152
+ if (construct_call) {
1153
+ __ pop(edi);
1154
+ }
1155
+ __ push(eax);
1156
+ // eax: JSArray
1157
+ // ebx: argc
1158
+ // edx: elements_array_end (untagged)
1159
+ // esp[0]: JSArray
1160
+ // esp[4]: return address
1161
+ // esp[8]: last argument
1162
+
1163
+ // Location of the last argument
1164
+ __ lea(edi, Operand(esp, 2 * kPointerSize));
1165
+
1166
+ // Location of the first array element (Parameter fill_with_holes to
1167
+ // AllocateJSArrayis false, so the FixedArray is returned in ecx).
1168
+ __ lea(edx, Operand(ecx, FixedArray::kHeaderSize - kHeapObjectTag));
1169
+
1170
+ // ebx: argc
1171
+ // edx: location of the first array element
1172
+ // edi: location of the last argument
1173
+ // esp[0]: JSArray
1174
+ // esp[4]: return address
1175
+ // esp[8]: last argument
1176
+ Label loop, entry;
1177
+ __ mov(ecx, ebx);
1178
+ __ jmp(&entry);
1179
+ __ bind(&loop);
1180
+ __ mov(eax, Operand(edi, ecx, times_pointer_size, 0));
1181
+ __ mov(Operand(edx, 0), eax);
1182
+ __ add(Operand(edx), Immediate(kPointerSize));
1183
+ __ bind(&entry);
1184
+ __ dec(ecx);
1185
+ __ j(greater_equal, &loop);
1186
+
1187
+ // Remove caller arguments from the stack and return.
1188
+ // ebx: argc
1189
+ // esp[0]: JSArray
1190
+ // esp[4]: return address
1191
+ // esp[8]: last argument
1192
+ __ pop(eax);
1193
+ __ pop(ecx);
1194
+ __ lea(esp, Operand(esp, ebx, times_pointer_size, 1 * kPointerSize));
1195
+ __ push(ecx);
1196
+ __ ret(0);
1197
+
1198
+ // Restore argc and constructor before running the generic code.
1199
+ __ bind(&prepare_generic_code_call);
1200
+ __ pop(eax);
1201
+ if (construct_call) {
1202
+ __ pop(edi);
1203
+ }
1204
+ __ jmp(call_generic_code);
1205
+ }
1206
+
1207
+
1208
+ void Builtins::Generate_ArrayCode(MacroAssembler* masm) {
1209
+ // ----------- S t a t e -------------
1210
+ // -- eax : argc
1211
+ // -- esp[0] : return address
1212
+ // -- esp[4] : last argument
1213
+ // -----------------------------------
1214
+ Label generic_array_code;
1215
+
1216
+ // Get the Array function.
1217
+ __ LoadGlobalFunction(Context::ARRAY_FUNCTION_INDEX, edi);
1218
+
1219
+ if (FLAG_debug_code) {
1220
+ // Initial map for the builtin Array function shoud be a map.
1221
+ __ mov(ebx, FieldOperand(edi, JSFunction::kPrototypeOrInitialMapOffset));
1222
+ // Will both indicate a NULL and a Smi.
1223
+ __ test(ebx, Immediate(kSmiTagMask));
1224
+ __ Assert(not_zero, "Unexpected initial map for Array function");
1225
+ __ CmpObjectType(ebx, MAP_TYPE, ecx);
1226
+ __ Assert(equal, "Unexpected initial map for Array function");
1227
+ }
1228
+
1229
+ // Run the native code for the Array function called as a normal function.
1230
+ ArrayNativeCode(masm, false, &generic_array_code);
1231
+
1232
+ // Jump to the generic array code in case the specialized code cannot handle
1233
+ // the construction.
1234
+ __ bind(&generic_array_code);
1235
+ Code* code = Builtins::builtin(Builtins::ArrayCodeGeneric);
1236
+ Handle<Code> array_code(code);
1237
+ __ jmp(array_code, RelocInfo::CODE_TARGET);
1238
+ }
1239
+
1240
+
1241
+ void Builtins::Generate_ArrayConstructCode(MacroAssembler* masm) {
1242
+ // ----------- S t a t e -------------
1243
+ // -- eax : argc
1244
+ // -- edi : constructor
1245
+ // -- esp[0] : return address
1246
+ // -- esp[4] : last argument
1247
+ // -----------------------------------
1248
+ Label generic_constructor;
1249
+
1250
+ if (FLAG_debug_code) {
1251
+ // The array construct code is only set for the builtin Array function which
1252
+ // does always have a map.
1253
+ __ LoadGlobalFunction(Context::ARRAY_FUNCTION_INDEX, ebx);
1254
+ __ cmp(edi, Operand(ebx));
1255
+ __ Assert(equal, "Unexpected Array function");
1256
+ // Initial map for the builtin Array function should be a map.
1257
+ __ mov(ebx, FieldOperand(edi, JSFunction::kPrototypeOrInitialMapOffset));
1258
+ // Will both indicate a NULL and a Smi.
1259
+ __ test(ebx, Immediate(kSmiTagMask));
1260
+ __ Assert(not_zero, "Unexpected initial map for Array function");
1261
+ __ CmpObjectType(ebx, MAP_TYPE, ecx);
1262
+ __ Assert(equal, "Unexpected initial map for Array function");
1263
+ }
1264
+
1265
+ // Run the native code for the Array function called as constructor.
1266
+ ArrayNativeCode(masm, true, &generic_constructor);
1267
+
1268
+ // Jump to the generic construct code in case the specialized code cannot
1269
+ // handle the construction.
1270
+ __ bind(&generic_constructor);
1271
+ Code* code = Builtins::builtin(Builtins::JSConstructStubGeneric);
1272
+ Handle<Code> generic_construct_stub(code);
1273
+ __ jmp(generic_construct_stub, RelocInfo::CODE_TARGET);
1274
+ }
1275
+
1276
+
1277
+ void Builtins::Generate_StringConstructCode(MacroAssembler* masm) {
1278
+ // ----------- S t a t e -------------
1279
+ // -- eax : number of arguments
1280
+ // -- edi : constructor function
1281
+ // -- esp[0] : return address
1282
+ // -- esp[(argc - n) * 4] : arg[n] (zero-based)
1283
+ // -- esp[(argc + 1) * 4] : receiver
1284
+ // -----------------------------------
1285
+ __ IncrementCounter(&Counters::string_ctor_calls, 1);
1286
+
1287
+ if (FLAG_debug_code) {
1288
+ __ LoadGlobalFunction(Context::STRING_FUNCTION_INDEX, ecx);
1289
+ __ cmp(edi, Operand(ecx));
1290
+ __ Assert(equal, "Unexpected String function");
1291
+ }
1292
+
1293
+ // Load the first argument into eax and get rid of the rest
1294
+ // (including the receiver).
1295
+ Label no_arguments;
1296
+ __ test(eax, Operand(eax));
1297
+ __ j(zero, &no_arguments);
1298
+ __ mov(ebx, Operand(esp, eax, times_pointer_size, 0));
1299
+ __ pop(ecx);
1300
+ __ lea(esp, Operand(esp, eax, times_pointer_size, kPointerSize));
1301
+ __ push(ecx);
1302
+ __ mov(eax, ebx);
1303
+
1304
+ // Lookup the argument in the number to string cache.
1305
+ Label not_cached, argument_is_string;
1306
+ NumberToStringStub::GenerateLookupNumberStringCache(
1307
+ masm,
1308
+ eax, // Input.
1309
+ ebx, // Result.
1310
+ ecx, // Scratch 1.
1311
+ edx, // Scratch 2.
1312
+ false, // Input is known to be smi?
1313
+ &not_cached);
1314
+ __ IncrementCounter(&Counters::string_ctor_cached_number, 1);
1315
+ __ bind(&argument_is_string);
1316
+ // ----------- S t a t e -------------
1317
+ // -- ebx : argument converted to string
1318
+ // -- edi : constructor function
1319
+ // -- esp[0] : return address
1320
+ // -----------------------------------
1321
+
1322
+ // Allocate a JSValue and put the tagged pointer into eax.
1323
+ Label gc_required;
1324
+ __ AllocateInNewSpace(JSValue::kSize,
1325
+ eax, // Result.
1326
+ ecx, // New allocation top (we ignore it).
1327
+ no_reg,
1328
+ &gc_required,
1329
+ TAG_OBJECT);
1330
+
1331
+ // Set the map.
1332
+ __ LoadGlobalFunctionInitialMap(edi, ecx);
1333
+ if (FLAG_debug_code) {
1334
+ __ cmpb(FieldOperand(ecx, Map::kInstanceSizeOffset),
1335
+ JSValue::kSize >> kPointerSizeLog2);
1336
+ __ Assert(equal, "Unexpected string wrapper instance size");
1337
+ __ cmpb(FieldOperand(ecx, Map::kUnusedPropertyFieldsOffset), 0);
1338
+ __ Assert(equal, "Unexpected unused properties of string wrapper");
1339
+ }
1340
+ __ mov(FieldOperand(eax, HeapObject::kMapOffset), ecx);
1341
+
1342
+ // Set properties and elements.
1343
+ __ Set(ecx, Immediate(Factory::empty_fixed_array()));
1344
+ __ mov(FieldOperand(eax, JSObject::kPropertiesOffset), ecx);
1345
+ __ mov(FieldOperand(eax, JSObject::kElementsOffset), ecx);
1346
+
1347
+ // Set the value.
1348
+ __ mov(FieldOperand(eax, JSValue::kValueOffset), ebx);
1349
+
1350
+ // Ensure the object is fully initialized.
1351
+ STATIC_ASSERT(JSValue::kSize == 4 * kPointerSize);
1352
+
1353
+ // We're done. Return.
1354
+ __ ret(0);
1355
+
1356
+ // The argument was not found in the number to string cache. Check
1357
+ // if it's a string already before calling the conversion builtin.
1358
+ Label convert_argument;
1359
+ __ bind(&not_cached);
1360
+ STATIC_ASSERT(kSmiTag == 0);
1361
+ __ test(eax, Immediate(kSmiTagMask));
1362
+ __ j(zero, &convert_argument);
1363
+ Condition is_string = masm->IsObjectStringType(eax, ebx, ecx);
1364
+ __ j(NegateCondition(is_string), &convert_argument);
1365
+ __ mov(ebx, eax);
1366
+ __ IncrementCounter(&Counters::string_ctor_string_value, 1);
1367
+ __ jmp(&argument_is_string);
1368
+
1369
+ // Invoke the conversion builtin and put the result into ebx.
1370
+ __ bind(&convert_argument);
1371
+ __ IncrementCounter(&Counters::string_ctor_conversions, 1);
1372
+ __ EnterInternalFrame();
1373
+ __ push(edi); // Preserve the function.
1374
+ __ push(eax);
1375
+ __ InvokeBuiltin(Builtins::TO_STRING, CALL_FUNCTION);
1376
+ __ pop(edi);
1377
+ __ LeaveInternalFrame();
1378
+ __ mov(ebx, eax);
1379
+ __ jmp(&argument_is_string);
1380
+
1381
+ // Load the empty string into ebx, remove the receiver from the
1382
+ // stack, and jump back to the case where the argument is a string.
1383
+ __ bind(&no_arguments);
1384
+ __ Set(ebx, Immediate(Factory::empty_string()));
1385
+ __ pop(ecx);
1386
+ __ lea(esp, Operand(esp, kPointerSize));
1387
+ __ push(ecx);
1388
+ __ jmp(&argument_is_string);
1389
+
1390
+ // At this point the argument is already a string. Call runtime to
1391
+ // create a string wrapper.
1392
+ __ bind(&gc_required);
1393
+ __ IncrementCounter(&Counters::string_ctor_gc_required, 1);
1394
+ __ EnterInternalFrame();
1395
+ __ push(ebx);
1396
+ __ CallRuntime(Runtime::kNewStringWrapper, 1);
1397
+ __ LeaveInternalFrame();
1398
+ __ ret(0);
1399
+ }
1400
+
1401
+
1402
+ static void EnterArgumentsAdaptorFrame(MacroAssembler* masm) {
1403
+ __ push(ebp);
1404
+ __ mov(ebp, Operand(esp));
1405
+
1406
+ // Store the arguments adaptor context sentinel.
1407
+ __ push(Immediate(Smi::FromInt(StackFrame::ARGUMENTS_ADAPTOR)));
1408
+
1409
+ // Push the function on the stack.
1410
+ __ push(edi);
1411
+
1412
+ // Preserve the number of arguments on the stack. Must preserve both
1413
+ // eax and ebx because these registers are used when copying the
1414
+ // arguments and the receiver.
1415
+ ASSERT(kSmiTagSize == 1);
1416
+ __ lea(ecx, Operand(eax, eax, times_1, kSmiTag));
1417
+ __ push(ecx);
1418
+ }
1419
+
1420
+
1421
+ static void LeaveArgumentsAdaptorFrame(MacroAssembler* masm) {
1422
+ // Retrieve the number of arguments from the stack.
1423
+ __ mov(ebx, Operand(ebp, ArgumentsAdaptorFrameConstants::kLengthOffset));
1424
+
1425
+ // Leave the frame.
1426
+ __ leave();
1427
+
1428
+ // Remove caller arguments from the stack.
1429
+ ASSERT(kSmiTagSize == 1 && kSmiTag == 0);
1430
+ __ pop(ecx);
1431
+ __ lea(esp, Operand(esp, ebx, times_2, 1 * kPointerSize)); // 1 ~ receiver
1432
+ __ push(ecx);
1433
+ }
1434
+
1435
+
1436
+ void Builtins::Generate_ArgumentsAdaptorTrampoline(MacroAssembler* masm) {
1437
+ // ----------- S t a t e -------------
1438
+ // -- eax : actual number of arguments
1439
+ // -- ebx : expected number of arguments
1440
+ // -- edx : code entry to call
1441
+ // -----------------------------------
1442
+
1443
+ Label invoke, dont_adapt_arguments;
1444
+ __ IncrementCounter(&Counters::arguments_adaptors, 1);
1445
+
1446
+ Label enough, too_few;
1447
+ __ cmp(eax, Operand(ebx));
1448
+ __ j(less, &too_few);
1449
+ __ cmp(ebx, SharedFunctionInfo::kDontAdaptArgumentsSentinel);
1450
+ __ j(equal, &dont_adapt_arguments);
1451
+
1452
+ { // Enough parameters: Actual >= expected.
1453
+ __ bind(&enough);
1454
+ EnterArgumentsAdaptorFrame(masm);
1455
+
1456
+ // Copy receiver and all expected arguments.
1457
+ const int offset = StandardFrameConstants::kCallerSPOffset;
1458
+ __ lea(eax, Operand(ebp, eax, times_4, offset));
1459
+ __ mov(ecx, -1); // account for receiver
1460
+
1461
+ Label copy;
1462
+ __ bind(&copy);
1463
+ __ inc(ecx);
1464
+ __ push(Operand(eax, 0));
1465
+ __ sub(Operand(eax), Immediate(kPointerSize));
1466
+ __ cmp(ecx, Operand(ebx));
1467
+ __ j(less, &copy);
1468
+ __ jmp(&invoke);
1469
+ }
1470
+
1471
+ { // Too few parameters: Actual < expected.
1472
+ __ bind(&too_few);
1473
+ EnterArgumentsAdaptorFrame(masm);
1474
+
1475
+ // Copy receiver and all actual arguments.
1476
+ const int offset = StandardFrameConstants::kCallerSPOffset;
1477
+ __ lea(edi, Operand(ebp, eax, times_4, offset));
1478
+ __ mov(ecx, -1); // account for receiver
1479
+
1480
+ Label copy;
1481
+ __ bind(&copy);
1482
+ __ inc(ecx);
1483
+ __ push(Operand(edi, 0));
1484
+ __ sub(Operand(edi), Immediate(kPointerSize));
1485
+ __ cmp(ecx, Operand(eax));
1486
+ __ j(less, &copy);
1487
+
1488
+ // Fill remaining expected arguments with undefined values.
1489
+ Label fill;
1490
+ __ bind(&fill);
1491
+ __ inc(ecx);
1492
+ __ push(Immediate(Factory::undefined_value()));
1493
+ __ cmp(ecx, Operand(ebx));
1494
+ __ j(less, &fill);
1495
+
1496
+ // Restore function pointer.
1497
+ __ mov(edi, Operand(ebp, JavaScriptFrameConstants::kFunctionOffset));
1498
+ }
1499
+
1500
+ // Call the entry point.
1501
+ __ bind(&invoke);
1502
+ __ call(Operand(edx));
1503
+
1504
+ // Leave frame and return.
1505
+ LeaveArgumentsAdaptorFrame(masm);
1506
+ __ ret(0);
1507
+
1508
+ // -------------------------------------------
1509
+ // Dont adapt arguments.
1510
+ // -------------------------------------------
1511
+ __ bind(&dont_adapt_arguments);
1512
+ __ jmp(Operand(edx));
1513
+ }
1514
+
1515
+
1516
+ void Builtins::Generate_OnStackReplacement(MacroAssembler* masm) {
1517
+ // We shouldn't be performing on-stack replacement in the first
1518
+ // place if the CPU features we need for the optimized Crankshaft
1519
+ // code aren't supported.
1520
+ CpuFeatures::Probe(false);
1521
+ if (!CpuFeatures::IsSupported(SSE2)) {
1522
+ __ Abort("Unreachable code: Cannot optimize without SSE2 support.");
1523
+ return;
1524
+ }
1525
+
1526
+ // Get the loop depth of the stack guard check. This is recorded in
1527
+ // a test(eax, depth) instruction right after the call.
1528
+ Label stack_check;
1529
+ __ mov(ebx, Operand(esp, 0)); // return address
1530
+ if (FLAG_debug_code) {
1531
+ __ cmpb(Operand(ebx, 0), Assembler::kTestAlByte);
1532
+ __ Assert(equal, "test eax instruction not found after loop stack check");
1533
+ }
1534
+ __ movzx_b(ebx, Operand(ebx, 1)); // depth
1535
+
1536
+ // Get the loop nesting level at which we allow OSR from the
1537
+ // unoptimized code and check if we want to do OSR yet. If not we
1538
+ // should perform a stack guard check so we can get interrupts while
1539
+ // waiting for on-stack replacement.
1540
+ __ mov(eax, Operand(ebp, JavaScriptFrameConstants::kFunctionOffset));
1541
+ __ mov(ecx, FieldOperand(eax, JSFunction::kSharedFunctionInfoOffset));
1542
+ __ mov(ecx, FieldOperand(ecx, SharedFunctionInfo::kCodeOffset));
1543
+ __ cmpb(ebx, FieldOperand(ecx, Code::kAllowOSRAtLoopNestingLevelOffset));
1544
+ __ j(greater, &stack_check);
1545
+
1546
+ // Pass the function to optimize as the argument to the on-stack
1547
+ // replacement runtime function.
1548
+ __ EnterInternalFrame();
1549
+ __ push(eax);
1550
+ __ CallRuntime(Runtime::kCompileForOnStackReplacement, 1);
1551
+ __ LeaveInternalFrame();
1552
+
1553
+ // If the result was -1 it means that we couldn't optimize the
1554
+ // function. Just return and continue in the unoptimized version.
1555
+ NearLabel skip;
1556
+ __ cmp(Operand(eax), Immediate(Smi::FromInt(-1)));
1557
+ __ j(not_equal, &skip);
1558
+ __ ret(0);
1559
+
1560
+ // If we decide not to perform on-stack replacement we perform a
1561
+ // stack guard check to enable interrupts.
1562
+ __ bind(&stack_check);
1563
+ NearLabel ok;
1564
+ ExternalReference stack_limit =
1565
+ ExternalReference::address_of_stack_limit();
1566
+ __ cmp(esp, Operand::StaticVariable(stack_limit));
1567
+ __ j(above_equal, &ok, taken);
1568
+ StackCheckStub stub;
1569
+ __ TailCallStub(&stub);
1570
+ __ Abort("Unreachable code: returned from tail call.");
1571
+ __ bind(&ok);
1572
+ __ ret(0);
1573
+
1574
+ __ bind(&skip);
1575
+ // Untag the AST id and push it on the stack.
1576
+ __ SmiUntag(eax);
1577
+ __ push(eax);
1578
+
1579
+ // Generate the code for doing the frame-to-frame translation using
1580
+ // the deoptimizer infrastructure.
1581
+ Deoptimizer::EntryGenerator generator(masm, Deoptimizer::OSR);
1582
+ generator.Generate();
1583
+ }
1584
+
1585
+
1586
+ #undef __
1587
+
1588
+ } } // namespace v8::internal
1589
+
1590
+ #endif // V8_TARGET_ARCH_IA32