mustang 0.0.1 → 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (560) hide show
  1. data/.rspec +1 -0
  2. data/Isolate +9 -0
  3. data/README.md +6 -12
  4. data/Rakefile +30 -4
  5. data/TODO.md +9 -0
  6. data/ext/v8/extconf.rb +56 -0
  7. data/ext/v8/v8.cpp +37 -0
  8. data/ext/v8/v8_array.cpp +161 -0
  9. data/ext/v8/v8_array.h +17 -0
  10. data/ext/v8/v8_base.cpp +147 -0
  11. data/ext/v8/v8_base.h +23 -0
  12. data/ext/v8/v8_cast.cpp +151 -0
  13. data/ext/v8/v8_cast.h +64 -0
  14. data/ext/v8/v8_context.cpp +174 -0
  15. data/ext/v8/v8_context.h +12 -0
  16. data/ext/v8/v8_date.cpp +61 -0
  17. data/ext/v8/v8_date.h +16 -0
  18. data/ext/v8/v8_errors.cpp +147 -0
  19. data/ext/v8/v8_errors.h +19 -0
  20. data/ext/v8/v8_external.cpp +66 -0
  21. data/ext/v8/v8_external.h +16 -0
  22. data/ext/v8/v8_function.cpp +182 -0
  23. data/ext/v8/v8_function.h +14 -0
  24. data/ext/v8/v8_integer.cpp +70 -0
  25. data/ext/v8/v8_integer.h +16 -0
  26. data/ext/v8/v8_macros.h +30 -0
  27. data/ext/v8/v8_main.cpp +53 -0
  28. data/ext/v8/v8_main.h +13 -0
  29. data/ext/v8/v8_number.cpp +62 -0
  30. data/ext/v8/v8_number.h +16 -0
  31. data/ext/v8/v8_object.cpp +172 -0
  32. data/ext/v8/v8_object.h +17 -0
  33. data/ext/v8/v8_ref.cpp +72 -0
  34. data/ext/v8/v8_ref.h +43 -0
  35. data/ext/v8/v8_regexp.cpp +148 -0
  36. data/ext/v8/v8_regexp.h +16 -0
  37. data/ext/v8/v8_string.cpp +78 -0
  38. data/ext/v8/v8_string.h +16 -0
  39. data/ext/v8/v8_value.cpp +370 -0
  40. data/ext/v8/v8_value.h +19 -0
  41. data/gemspec.yml +2 -1
  42. data/lib/core_ext/class.rb +14 -0
  43. data/lib/core_ext/object.rb +12 -0
  44. data/lib/core_ext/symbol.rb +23 -0
  45. data/lib/mustang.rb +44 -0
  46. data/lib/mustang/context.rb +69 -0
  47. data/lib/mustang/errors.rb +36 -0
  48. data/lib/support/delegated.rb +25 -0
  49. data/lib/v8/array.rb +21 -0
  50. data/lib/v8/context.rb +13 -0
  51. data/lib/v8/date.rb +20 -0
  52. data/lib/v8/error.rb +15 -0
  53. data/lib/v8/external.rb +16 -0
  54. data/lib/v8/function.rb +11 -0
  55. data/lib/v8/integer.rb +16 -0
  56. data/lib/v8/number.rb +16 -0
  57. data/lib/v8/object.rb +66 -0
  58. data/lib/v8/regexp.rb +23 -0
  59. data/lib/v8/string.rb +27 -0
  60. data/mustang.gemspec +3 -0
  61. data/spec/core_ext/class_spec.rb +19 -0
  62. data/spec/core_ext/object_spec.rb +19 -0
  63. data/spec/core_ext/symbol_spec.rb +27 -0
  64. data/spec/fixtures/test1.js +2 -0
  65. data/spec/fixtures/test2.js +2 -0
  66. data/spec/spec_helper.rb +20 -0
  67. data/spec/v8/array_spec.rb +88 -0
  68. data/spec/v8/cast_spec.rb +151 -0
  69. data/spec/v8/context_spec.rb +78 -0
  70. data/spec/v8/data_spec.rb +39 -0
  71. data/spec/v8/date_spec.rb +45 -0
  72. data/spec/v8/empty_spec.rb +27 -0
  73. data/spec/v8/errors_spec.rb +142 -0
  74. data/spec/v8/external_spec.rb +44 -0
  75. data/spec/v8/function_spec.rb +170 -0
  76. data/spec/v8/integer_spec.rb +41 -0
  77. data/spec/v8/main_spec.rb +18 -0
  78. data/spec/v8/null_spec.rb +27 -0
  79. data/spec/v8/number_spec.rb +40 -0
  80. data/spec/v8/object_spec.rb +79 -0
  81. data/spec/v8/primitive_spec.rb +9 -0
  82. data/spec/v8/regexp_spec.rb +65 -0
  83. data/spec/v8/string_spec.rb +48 -0
  84. data/spec/v8/undefined_spec.rb +27 -0
  85. data/spec/v8/value_spec.rb +215 -0
  86. data/vendor/v8/.gitignore +2 -0
  87. data/vendor/v8/AUTHORS +3 -1
  88. data/vendor/v8/ChangeLog +117 -0
  89. data/vendor/v8/SConstruct +334 -53
  90. data/vendor/v8/include/v8-debug.h +21 -11
  91. data/vendor/v8/include/v8-preparser.h +1 -1
  92. data/vendor/v8/include/v8-profiler.h +122 -43
  93. data/vendor/v8/include/v8-testing.h +5 -0
  94. data/vendor/v8/include/v8.h +171 -17
  95. data/vendor/v8/preparser/SConscript +38 -0
  96. data/vendor/v8/preparser/preparser-process.cc +77 -114
  97. data/vendor/v8/samples/shell.cc +232 -46
  98. data/vendor/v8/src/SConscript +29 -5
  99. data/vendor/v8/src/accessors.cc +70 -211
  100. data/vendor/v8/{test/cctest/test-mips.cc → src/allocation-inl.h} +15 -18
  101. data/vendor/v8/src/allocation.cc +0 -82
  102. data/vendor/v8/src/allocation.h +9 -42
  103. data/vendor/v8/src/api.cc +1645 -1156
  104. data/vendor/v8/src/api.h +76 -12
  105. data/vendor/v8/src/apiutils.h +0 -7
  106. data/vendor/v8/src/arguments.h +15 -4
  107. data/vendor/v8/src/arm/assembler-arm-inl.h +10 -9
  108. data/vendor/v8/src/arm/assembler-arm.cc +62 -23
  109. data/vendor/v8/src/arm/assembler-arm.h +76 -11
  110. data/vendor/v8/src/arm/builtins-arm.cc +39 -33
  111. data/vendor/v8/src/arm/code-stubs-arm.cc +1182 -402
  112. data/vendor/v8/src/arm/code-stubs-arm.h +20 -54
  113. data/vendor/v8/src/arm/codegen-arm.cc +159 -106
  114. data/vendor/v8/src/arm/codegen-arm.h +6 -6
  115. data/vendor/v8/src/arm/constants-arm.h +16 -1
  116. data/vendor/v8/src/arm/cpu-arm.cc +7 -5
  117. data/vendor/v8/src/arm/debug-arm.cc +6 -4
  118. data/vendor/v8/src/arm/deoptimizer-arm.cc +51 -14
  119. data/vendor/v8/src/arm/disasm-arm.cc +47 -15
  120. data/vendor/v8/src/arm/frames-arm.h +1 -1
  121. data/vendor/v8/src/arm/full-codegen-arm.cc +724 -408
  122. data/vendor/v8/src/arm/ic-arm.cc +90 -85
  123. data/vendor/v8/src/arm/lithium-arm.cc +140 -69
  124. data/vendor/v8/src/arm/lithium-arm.h +161 -46
  125. data/vendor/v8/src/arm/lithium-codegen-arm.cc +567 -297
  126. data/vendor/v8/src/arm/lithium-codegen-arm.h +21 -9
  127. data/vendor/v8/src/arm/lithium-gap-resolver-arm.cc +2 -0
  128. data/vendor/v8/src/arm/macro-assembler-arm.cc +457 -96
  129. data/vendor/v8/src/arm/macro-assembler-arm.h +115 -18
  130. data/vendor/v8/src/arm/regexp-macro-assembler-arm.cc +20 -13
  131. data/vendor/v8/src/arm/regexp-macro-assembler-arm.h +1 -0
  132. data/vendor/v8/src/arm/simulator-arm.cc +184 -101
  133. data/vendor/v8/src/arm/simulator-arm.h +26 -21
  134. data/vendor/v8/src/arm/stub-cache-arm.cc +450 -467
  135. data/vendor/v8/src/arm/virtual-frame-arm.cc +14 -12
  136. data/vendor/v8/src/arm/virtual-frame-arm.h +11 -8
  137. data/vendor/v8/src/array.js +35 -18
  138. data/vendor/v8/src/assembler.cc +186 -92
  139. data/vendor/v8/src/assembler.h +106 -69
  140. data/vendor/v8/src/ast-inl.h +5 -0
  141. data/vendor/v8/src/ast.cc +46 -35
  142. data/vendor/v8/src/ast.h +107 -50
  143. data/vendor/v8/src/atomicops.h +2 -0
  144. data/vendor/v8/src/atomicops_internals_mips_gcc.h +169 -0
  145. data/vendor/v8/src/bootstrapper.cc +649 -399
  146. data/vendor/v8/src/bootstrapper.h +94 -27
  147. data/vendor/v8/src/builtins.cc +359 -227
  148. data/vendor/v8/src/builtins.h +157 -123
  149. data/vendor/v8/src/checks.cc +2 -2
  150. data/vendor/v8/src/checks.h +4 -0
  151. data/vendor/v8/src/code-stubs.cc +27 -17
  152. data/vendor/v8/src/code-stubs.h +38 -17
  153. data/vendor/v8/src/codegen-inl.h +5 -1
  154. data/vendor/v8/src/codegen.cc +27 -17
  155. data/vendor/v8/src/codegen.h +9 -9
  156. data/vendor/v8/src/compilation-cache.cc +92 -206
  157. data/vendor/v8/src/compilation-cache.h +205 -30
  158. data/vendor/v8/src/compiler.cc +107 -120
  159. data/vendor/v8/src/compiler.h +17 -2
  160. data/vendor/v8/src/contexts.cc +22 -15
  161. data/vendor/v8/src/contexts.h +14 -8
  162. data/vendor/v8/src/conversions.cc +86 -30
  163. data/vendor/v8/src/counters.cc +19 -4
  164. data/vendor/v8/src/counters.h +28 -16
  165. data/vendor/v8/src/cpu-profiler-inl.h +4 -3
  166. data/vendor/v8/src/cpu-profiler.cc +123 -72
  167. data/vendor/v8/src/cpu-profiler.h +33 -19
  168. data/vendor/v8/src/cpu.h +2 -0
  169. data/vendor/v8/src/d8-debug.cc +3 -3
  170. data/vendor/v8/src/d8-debug.h +7 -6
  171. data/vendor/v8/src/d8-posix.cc +2 -0
  172. data/vendor/v8/src/d8.cc +22 -12
  173. data/vendor/v8/src/d8.gyp +3 -0
  174. data/vendor/v8/src/d8.js +618 -0
  175. data/vendor/v8/src/data-flow.h +3 -3
  176. data/vendor/v8/src/dateparser.h +4 -2
  177. data/vendor/v8/src/debug-agent.cc +10 -9
  178. data/vendor/v8/src/debug-agent.h +9 -11
  179. data/vendor/v8/src/debug-debugger.js +121 -0
  180. data/vendor/v8/src/debug.cc +331 -227
  181. data/vendor/v8/src/debug.h +248 -219
  182. data/vendor/v8/src/deoptimizer.cc +173 -62
  183. data/vendor/v8/src/deoptimizer.h +119 -19
  184. data/vendor/v8/src/disasm.h +3 -0
  185. data/vendor/v8/src/disassembler.cc +10 -9
  186. data/vendor/v8/src/execution.cc +185 -129
  187. data/vendor/v8/src/execution.h +47 -78
  188. data/vendor/v8/src/extensions/experimental/break-iterator.cc +250 -0
  189. data/vendor/v8/src/extensions/experimental/break-iterator.h +89 -0
  190. data/vendor/v8/src/extensions/experimental/experimental.gyp +2 -0
  191. data/vendor/v8/src/extensions/experimental/i18n-extension.cc +22 -2
  192. data/vendor/v8/src/extensions/externalize-string-extension.cc +2 -2
  193. data/vendor/v8/src/extensions/gc-extension.cc +1 -1
  194. data/vendor/v8/src/factory.cc +261 -154
  195. data/vendor/v8/src/factory.h +162 -158
  196. data/vendor/v8/src/flag-definitions.h +17 -11
  197. data/vendor/v8/src/frame-element.cc +0 -5
  198. data/vendor/v8/src/frame-element.h +9 -13
  199. data/vendor/v8/src/frames-inl.h +7 -0
  200. data/vendor/v8/src/frames.cc +56 -46
  201. data/vendor/v8/src/frames.h +36 -25
  202. data/vendor/v8/src/full-codegen.cc +15 -24
  203. data/vendor/v8/src/full-codegen.h +13 -41
  204. data/vendor/v8/src/func-name-inferrer.cc +7 -6
  205. data/vendor/v8/src/func-name-inferrer.h +1 -1
  206. data/vendor/v8/src/gdb-jit.cc +1 -0
  207. data/vendor/v8/src/global-handles.cc +118 -56
  208. data/vendor/v8/src/global-handles.h +98 -40
  209. data/vendor/v8/src/globals.h +2 -2
  210. data/vendor/v8/src/handles-inl.h +106 -9
  211. data/vendor/v8/src/handles.cc +220 -157
  212. data/vendor/v8/src/handles.h +38 -59
  213. data/vendor/v8/src/hashmap.h +3 -3
  214. data/vendor/v8/src/heap-inl.h +141 -25
  215. data/vendor/v8/src/heap-profiler.cc +117 -63
  216. data/vendor/v8/src/heap-profiler.h +38 -21
  217. data/vendor/v8/src/heap.cc +805 -564
  218. data/vendor/v8/src/heap.h +640 -594
  219. data/vendor/v8/src/hydrogen-instructions.cc +216 -73
  220. data/vendor/v8/src/hydrogen-instructions.h +259 -124
  221. data/vendor/v8/src/hydrogen.cc +996 -1171
  222. data/vendor/v8/src/hydrogen.h +163 -144
  223. data/vendor/v8/src/ia32/assembler-ia32-inl.h +12 -11
  224. data/vendor/v8/src/ia32/assembler-ia32.cc +85 -39
  225. data/vendor/v8/src/ia32/assembler-ia32.h +82 -16
  226. data/vendor/v8/src/ia32/builtins-ia32.cc +64 -58
  227. data/vendor/v8/src/ia32/code-stubs-ia32.cc +248 -324
  228. data/vendor/v8/src/ia32/code-stubs-ia32.h +3 -44
  229. data/vendor/v8/src/ia32/codegen-ia32.cc +217 -165
  230. data/vendor/v8/src/ia32/codegen-ia32.h +3 -0
  231. data/vendor/v8/src/ia32/cpu-ia32.cc +6 -5
  232. data/vendor/v8/src/ia32/debug-ia32.cc +8 -5
  233. data/vendor/v8/src/ia32/deoptimizer-ia32.cc +124 -14
  234. data/vendor/v8/src/ia32/disasm-ia32.cc +85 -62
  235. data/vendor/v8/src/ia32/frames-ia32.h +1 -1
  236. data/vendor/v8/src/ia32/full-codegen-ia32.cc +348 -435
  237. data/vendor/v8/src/ia32/ic-ia32.cc +91 -91
  238. data/vendor/v8/src/ia32/lithium-codegen-ia32.cc +500 -255
  239. data/vendor/v8/src/ia32/lithium-codegen-ia32.h +13 -4
  240. data/vendor/v8/src/ia32/lithium-gap-resolver-ia32.cc +6 -0
  241. data/vendor/v8/src/ia32/lithium-ia32.cc +122 -45
  242. data/vendor/v8/src/ia32/lithium-ia32.h +128 -41
  243. data/vendor/v8/src/ia32/macro-assembler-ia32.cc +109 -84
  244. data/vendor/v8/src/ia32/macro-assembler-ia32.h +18 -9
  245. data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.cc +26 -15
  246. data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.h +1 -0
  247. data/vendor/v8/src/ia32/register-allocator-ia32.cc +30 -30
  248. data/vendor/v8/src/ia32/simulator-ia32.h +4 -4
  249. data/vendor/v8/src/ia32/stub-cache-ia32.cc +383 -400
  250. data/vendor/v8/src/ia32/virtual-frame-ia32.cc +36 -13
  251. data/vendor/v8/src/ia32/virtual-frame-ia32.h +11 -5
  252. data/vendor/v8/src/ic-inl.h +12 -2
  253. data/vendor/v8/src/ic.cc +304 -221
  254. data/vendor/v8/src/ic.h +115 -58
  255. data/vendor/v8/src/interpreter-irregexp.cc +25 -21
  256. data/vendor/v8/src/interpreter-irregexp.h +2 -1
  257. data/vendor/v8/src/isolate.cc +883 -0
  258. data/vendor/v8/src/isolate.h +1304 -0
  259. data/vendor/v8/src/json.js +10 -10
  260. data/vendor/v8/src/jsregexp.cc +111 -80
  261. data/vendor/v8/src/jsregexp.h +6 -7
  262. data/vendor/v8/src/jump-target-heavy.cc +5 -8
  263. data/vendor/v8/src/jump-target-heavy.h +0 -6
  264. data/vendor/v8/src/jump-target-inl.h +1 -1
  265. data/vendor/v8/src/jump-target-light.cc +3 -3
  266. data/vendor/v8/src/lithium-allocator-inl.h +2 -0
  267. data/vendor/v8/src/lithium-allocator.cc +42 -30
  268. data/vendor/v8/src/lithium-allocator.h +8 -22
  269. data/vendor/v8/src/lithium.cc +1 -0
  270. data/vendor/v8/src/liveedit.cc +141 -99
  271. data/vendor/v8/src/liveedit.h +7 -2
  272. data/vendor/v8/src/liveobjectlist-inl.h +90 -0
  273. data/vendor/v8/src/liveobjectlist.cc +2537 -1
  274. data/vendor/v8/src/liveobjectlist.h +245 -35
  275. data/vendor/v8/src/log-utils.cc +122 -35
  276. data/vendor/v8/src/log-utils.h +33 -36
  277. data/vendor/v8/src/log.cc +299 -241
  278. data/vendor/v8/src/log.h +177 -110
  279. data/vendor/v8/src/mark-compact.cc +612 -470
  280. data/vendor/v8/src/mark-compact.h +153 -80
  281. data/vendor/v8/src/messages.cc +16 -14
  282. data/vendor/v8/src/messages.js +30 -7
  283. data/vendor/v8/src/mips/assembler-mips-inl.h +155 -35
  284. data/vendor/v8/src/mips/assembler-mips.cc +1093 -219
  285. data/vendor/v8/src/mips/assembler-mips.h +552 -153
  286. data/vendor/v8/src/mips/builtins-mips.cc +43 -100
  287. data/vendor/v8/src/mips/code-stubs-mips.cc +752 -0
  288. data/vendor/v8/src/mips/code-stubs-mips.h +511 -0
  289. data/vendor/v8/src/mips/codegen-mips-inl.h +8 -14
  290. data/vendor/v8/src/mips/codegen-mips.cc +672 -896
  291. data/vendor/v8/src/mips/codegen-mips.h +271 -69
  292. data/vendor/v8/src/mips/constants-mips.cc +44 -20
  293. data/vendor/v8/src/mips/constants-mips.h +238 -40
  294. data/vendor/v8/src/mips/cpu-mips.cc +20 -3
  295. data/vendor/v8/src/mips/debug-mips.cc +35 -7
  296. data/vendor/v8/src/mips/deoptimizer-mips.cc +91 -0
  297. data/vendor/v8/src/mips/disasm-mips.cc +329 -93
  298. data/vendor/v8/src/mips/frames-mips.cc +2 -50
  299. data/vendor/v8/src/mips/frames-mips.h +24 -9
  300. data/vendor/v8/src/mips/full-codegen-mips.cc +473 -23
  301. data/vendor/v8/src/mips/ic-mips.cc +81 -45
  302. data/vendor/v8/src/mips/jump-target-mips.cc +11 -106
  303. data/vendor/v8/src/mips/lithium-codegen-mips.h +65 -0
  304. data/vendor/v8/src/mips/lithium-mips.h +304 -0
  305. data/vendor/v8/src/mips/macro-assembler-mips.cc +2391 -390
  306. data/vendor/v8/src/mips/macro-assembler-mips.h +718 -121
  307. data/vendor/v8/src/mips/regexp-macro-assembler-mips.cc +478 -0
  308. data/vendor/v8/src/mips/regexp-macro-assembler-mips.h +250 -0
  309. data/vendor/v8/src/mips/register-allocator-mips-inl.h +0 -3
  310. data/vendor/v8/src/mips/register-allocator-mips.h +3 -2
  311. data/vendor/v8/src/mips/simulator-mips.cc +1009 -221
  312. data/vendor/v8/src/mips/simulator-mips.h +119 -36
  313. data/vendor/v8/src/mips/stub-cache-mips.cc +331 -148
  314. data/vendor/v8/src/mips/{fast-codegen-mips.cc → virtual-frame-mips-inl.h} +11 -30
  315. data/vendor/v8/src/mips/virtual-frame-mips.cc +137 -149
  316. data/vendor/v8/src/mips/virtual-frame-mips.h +294 -312
  317. data/vendor/v8/src/mirror-debugger.js +9 -8
  318. data/vendor/v8/src/mksnapshot.cc +2 -2
  319. data/vendor/v8/src/objects-debug.cc +16 -16
  320. data/vendor/v8/src/objects-inl.h +421 -195
  321. data/vendor/v8/src/objects-printer.cc +7 -7
  322. data/vendor/v8/src/objects-visiting.cc +1 -1
  323. data/vendor/v8/src/objects-visiting.h +33 -12
  324. data/vendor/v8/src/objects.cc +935 -658
  325. data/vendor/v8/src/objects.h +234 -139
  326. data/vendor/v8/src/parser.cc +484 -439
  327. data/vendor/v8/src/parser.h +35 -14
  328. data/vendor/v8/src/platform-cygwin.cc +173 -107
  329. data/vendor/v8/src/platform-freebsd.cc +224 -72
  330. data/vendor/v8/src/platform-linux.cc +234 -95
  331. data/vendor/v8/src/platform-macos.cc +215 -82
  332. data/vendor/v8/src/platform-nullos.cc +9 -3
  333. data/vendor/v8/src/platform-openbsd.cc +22 -7
  334. data/vendor/v8/src/platform-posix.cc +30 -5
  335. data/vendor/v8/src/platform-solaris.cc +120 -38
  336. data/vendor/v8/src/platform-tls-mac.h +62 -0
  337. data/vendor/v8/src/platform-tls-win32.h +62 -0
  338. data/vendor/v8/src/platform-tls.h +50 -0
  339. data/vendor/v8/src/platform-win32.cc +195 -97
  340. data/vendor/v8/src/platform.h +72 -15
  341. data/vendor/v8/src/preparse-data.cc +2 -0
  342. data/vendor/v8/src/preparser-api.cc +8 -2
  343. data/vendor/v8/src/preparser.cc +1 -1
  344. data/vendor/v8/src/prettyprinter.cc +43 -52
  345. data/vendor/v8/src/prettyprinter.h +1 -1
  346. data/vendor/v8/src/profile-generator-inl.h +0 -28
  347. data/vendor/v8/src/profile-generator.cc +942 -685
  348. data/vendor/v8/src/profile-generator.h +210 -176
  349. data/vendor/v8/src/property.cc +6 -0
  350. data/vendor/v8/src/property.h +14 -3
  351. data/vendor/v8/src/regexp-macro-assembler-irregexp.cc +1 -1
  352. data/vendor/v8/src/regexp-macro-assembler.cc +28 -19
  353. data/vendor/v8/src/regexp-macro-assembler.h +11 -6
  354. data/vendor/v8/src/regexp-stack.cc +18 -10
  355. data/vendor/v8/src/regexp-stack.h +45 -21
  356. data/vendor/v8/src/regexp.js +3 -3
  357. data/vendor/v8/src/register-allocator-inl.h +3 -3
  358. data/vendor/v8/src/register-allocator.cc +1 -7
  359. data/vendor/v8/src/register-allocator.h +5 -15
  360. data/vendor/v8/src/rewriter.cc +2 -1
  361. data/vendor/v8/src/runtime-profiler.cc +158 -128
  362. data/vendor/v8/src/runtime-profiler.h +131 -15
  363. data/vendor/v8/src/runtime.cc +2409 -1692
  364. data/vendor/v8/src/runtime.h +93 -17
  365. data/vendor/v8/src/safepoint-table.cc +3 -0
  366. data/vendor/v8/src/safepoint-table.h +9 -3
  367. data/vendor/v8/src/scanner-base.cc +21 -28
  368. data/vendor/v8/src/scanner-base.h +22 -11
  369. data/vendor/v8/src/scanner.cc +3 -5
  370. data/vendor/v8/src/scanner.h +4 -2
  371. data/vendor/v8/src/scopeinfo.cc +11 -16
  372. data/vendor/v8/src/scopeinfo.h +26 -15
  373. data/vendor/v8/src/scopes.cc +67 -37
  374. data/vendor/v8/src/scopes.h +26 -12
  375. data/vendor/v8/src/serialize.cc +193 -154
  376. data/vendor/v8/src/serialize.h +41 -36
  377. data/vendor/v8/src/small-pointer-list.h +163 -0
  378. data/vendor/v8/src/snapshot-common.cc +1 -1
  379. data/vendor/v8/src/snapshot.h +3 -1
  380. data/vendor/v8/src/spaces-inl.h +30 -25
  381. data/vendor/v8/src/spaces.cc +263 -370
  382. data/vendor/v8/src/spaces.h +178 -166
  383. data/vendor/v8/src/string-search.cc +4 -3
  384. data/vendor/v8/src/string-search.h +21 -20
  385. data/vendor/v8/src/string-stream.cc +32 -24
  386. data/vendor/v8/src/string.js +7 -7
  387. data/vendor/v8/src/stub-cache.cc +324 -248
  388. data/vendor/v8/src/stub-cache.h +181 -155
  389. data/vendor/v8/src/token.cc +3 -3
  390. data/vendor/v8/src/token.h +3 -3
  391. data/vendor/v8/src/top.cc +218 -390
  392. data/vendor/v8/src/type-info.cc +98 -32
  393. data/vendor/v8/src/type-info.h +10 -3
  394. data/vendor/v8/src/unicode.cc +1 -1
  395. data/vendor/v8/src/unicode.h +1 -1
  396. data/vendor/v8/src/utils.h +3 -0
  397. data/vendor/v8/src/v8-counters.cc +18 -11
  398. data/vendor/v8/src/v8-counters.h +34 -13
  399. data/vendor/v8/src/v8.cc +66 -121
  400. data/vendor/v8/src/v8.h +7 -4
  401. data/vendor/v8/src/v8globals.h +18 -12
  402. data/vendor/v8/src/{memory.h → v8memory.h} +0 -0
  403. data/vendor/v8/src/v8natives.js +59 -18
  404. data/vendor/v8/src/v8threads.cc +127 -114
  405. data/vendor/v8/src/v8threads.h +42 -35
  406. data/vendor/v8/src/v8utils.h +2 -39
  407. data/vendor/v8/src/variables.h +1 -1
  408. data/vendor/v8/src/version.cc +26 -5
  409. data/vendor/v8/src/version.h +4 -0
  410. data/vendor/v8/src/virtual-frame-heavy-inl.h +2 -4
  411. data/vendor/v8/src/virtual-frame-light-inl.h +5 -4
  412. data/vendor/v8/src/vm-state-inl.h +21 -17
  413. data/vendor/v8/src/vm-state.h +7 -5
  414. data/vendor/v8/src/win32-headers.h +1 -0
  415. data/vendor/v8/src/x64/assembler-x64-inl.h +12 -11
  416. data/vendor/v8/src/x64/assembler-x64.cc +80 -40
  417. data/vendor/v8/src/x64/assembler-x64.h +67 -17
  418. data/vendor/v8/src/x64/builtins-x64.cc +34 -33
  419. data/vendor/v8/src/x64/code-stubs-x64.cc +636 -377
  420. data/vendor/v8/src/x64/code-stubs-x64.h +14 -48
  421. data/vendor/v8/src/x64/codegen-x64-inl.h +1 -1
  422. data/vendor/v8/src/x64/codegen-x64.cc +158 -136
  423. data/vendor/v8/src/x64/codegen-x64.h +4 -1
  424. data/vendor/v8/src/x64/cpu-x64.cc +7 -5
  425. data/vendor/v8/src/x64/debug-x64.cc +8 -6
  426. data/vendor/v8/src/x64/deoptimizer-x64.cc +195 -20
  427. data/vendor/v8/src/x64/disasm-x64.cc +42 -23
  428. data/vendor/v8/src/x64/frames-x64.cc +1 -1
  429. data/vendor/v8/src/x64/frames-x64.h +2 -2
  430. data/vendor/v8/src/x64/full-codegen-x64.cc +780 -218
  431. data/vendor/v8/src/x64/ic-x64.cc +77 -79
  432. data/vendor/v8/src/x64/jump-target-x64.cc +1 -1
  433. data/vendor/v8/src/x64/lithium-codegen-x64.cc +698 -181
  434. data/vendor/v8/src/x64/lithium-codegen-x64.h +31 -6
  435. data/vendor/v8/src/x64/lithium-x64.cc +136 -54
  436. data/vendor/v8/src/x64/lithium-x64.h +142 -51
  437. data/vendor/v8/src/x64/macro-assembler-x64.cc +456 -187
  438. data/vendor/v8/src/x64/macro-assembler-x64.h +166 -34
  439. data/vendor/v8/src/x64/regexp-macro-assembler-x64.cc +44 -28
  440. data/vendor/v8/src/x64/regexp-macro-assembler-x64.h +8 -4
  441. data/vendor/v8/src/x64/register-allocator-x64-inl.h +3 -3
  442. data/vendor/v8/src/x64/register-allocator-x64.cc +12 -8
  443. data/vendor/v8/src/x64/simulator-x64.h +5 -5
  444. data/vendor/v8/src/x64/stub-cache-x64.cc +299 -344
  445. data/vendor/v8/src/x64/virtual-frame-x64.cc +37 -13
  446. data/vendor/v8/src/x64/virtual-frame-x64.h +13 -7
  447. data/vendor/v8/src/zone-inl.h +49 -3
  448. data/vendor/v8/src/zone.cc +42 -41
  449. data/vendor/v8/src/zone.h +37 -34
  450. data/vendor/v8/test/benchmarks/testcfg.py +100 -0
  451. data/vendor/v8/test/cctest/SConscript +5 -4
  452. data/vendor/v8/test/cctest/cctest.h +3 -2
  453. data/vendor/v8/test/cctest/cctest.status +6 -11
  454. data/vendor/v8/test/cctest/test-accessors.cc +3 -3
  455. data/vendor/v8/test/cctest/test-alloc.cc +39 -33
  456. data/vendor/v8/test/cctest/test-api.cc +1092 -205
  457. data/vendor/v8/test/cctest/test-assembler-arm.cc +39 -25
  458. data/vendor/v8/test/cctest/test-assembler-ia32.cc +36 -37
  459. data/vendor/v8/test/cctest/test-assembler-mips.cc +1098 -40
  460. data/vendor/v8/test/cctest/test-assembler-x64.cc +32 -25
  461. data/vendor/v8/test/cctest/test-ast.cc +1 -0
  462. data/vendor/v8/test/cctest/test-circular-queue.cc +8 -5
  463. data/vendor/v8/test/cctest/test-compiler.cc +24 -24
  464. data/vendor/v8/test/cctest/test-cpu-profiler.cc +140 -5
  465. data/vendor/v8/test/cctest/test-dataflow.cc +1 -0
  466. data/vendor/v8/test/cctest/test-debug.cc +136 -77
  467. data/vendor/v8/test/cctest/test-decls.cc +1 -1
  468. data/vendor/v8/test/cctest/test-deoptimization.cc +25 -24
  469. data/vendor/v8/test/cctest/test-disasm-arm.cc +9 -4
  470. data/vendor/v8/test/cctest/test-disasm-ia32.cc +10 -8
  471. data/vendor/v8/test/cctest/test-func-name-inference.cc +10 -4
  472. data/vendor/v8/test/cctest/test-heap-profiler.cc +226 -164
  473. data/vendor/v8/test/cctest/test-heap.cc +240 -217
  474. data/vendor/v8/test/cctest/test-liveedit.cc +1 -0
  475. data/vendor/v8/test/cctest/test-log-stack-tracer.cc +18 -20
  476. data/vendor/v8/test/cctest/test-log.cc +114 -108
  477. data/vendor/v8/test/cctest/test-macro-assembler-x64.cc +247 -177
  478. data/vendor/v8/test/cctest/test-mark-compact.cc +129 -90
  479. data/vendor/v8/test/cctest/test-parsing.cc +15 -14
  480. data/vendor/v8/test/cctest/test-platform-linux.cc +1 -0
  481. data/vendor/v8/test/cctest/test-platform-tls.cc +66 -0
  482. data/vendor/v8/test/cctest/test-platform-win32.cc +1 -0
  483. data/vendor/v8/test/cctest/test-profile-generator.cc +1 -1
  484. data/vendor/v8/test/cctest/test-regexp.cc +53 -41
  485. data/vendor/v8/test/cctest/test-reloc-info.cc +18 -11
  486. data/vendor/v8/test/cctest/test-serialize.cc +44 -43
  487. data/vendor/v8/test/cctest/test-sockets.cc +8 -3
  488. data/vendor/v8/test/cctest/test-spaces.cc +47 -29
  489. data/vendor/v8/test/cctest/test-strings.cc +20 -20
  490. data/vendor/v8/test/cctest/test-thread-termination.cc +8 -3
  491. data/vendor/v8/test/cctest/test-threads.cc +5 -3
  492. data/vendor/v8/test/cctest/test-utils.cc +5 -4
  493. data/vendor/v8/test/cctest/testcfg.py +7 -3
  494. data/vendor/v8/test/es5conform/es5conform.status +2 -77
  495. data/vendor/v8/test/es5conform/testcfg.py +1 -1
  496. data/vendor/v8/test/message/testcfg.py +1 -1
  497. data/vendor/v8/test/mjsunit/accessors-on-global-object.js +3 -3
  498. data/vendor/v8/test/mjsunit/array-concat.js +43 -1
  499. data/vendor/v8/test/mjsunit/array-join.js +25 -0
  500. data/vendor/v8/test/mjsunit/bitops-info.js +7 -1
  501. data/vendor/v8/test/mjsunit/compiler/array-length.js +2 -2
  502. data/vendor/v8/test/mjsunit/compiler/global-accessors.js +47 -0
  503. data/vendor/v8/test/mjsunit/compiler/pic.js +1 -1
  504. data/vendor/v8/test/mjsunit/compiler/regress-loadfield.js +65 -0
  505. data/vendor/v8/test/mjsunit/math-sqrt.js +5 -1
  506. data/vendor/v8/test/mjsunit/mjsunit.js +59 -8
  507. data/vendor/v8/test/mjsunit/mjsunit.status +0 -12
  508. data/vendor/v8/test/mjsunit/mul-exhaustive.js +129 -11
  509. data/vendor/v8/test/mjsunit/negate-zero.js +1 -1
  510. data/vendor/v8/test/mjsunit/object-freeze.js +5 -13
  511. data/vendor/v8/test/mjsunit/object-prevent-extensions.js +9 -50
  512. data/vendor/v8/test/mjsunit/object-seal.js +4 -13
  513. data/vendor/v8/test/mjsunit/override-eval-with-non-function.js +36 -0
  514. data/vendor/v8/test/mjsunit/regress/regress-1145.js +54 -0
  515. data/vendor/v8/test/mjsunit/regress/regress-1172-bis.js +37 -0
  516. data/vendor/v8/test/mjsunit/regress/regress-1181.js +54 -0
  517. data/vendor/v8/test/mjsunit/regress/regress-1207.js +35 -0
  518. data/vendor/v8/test/mjsunit/regress/regress-1209.js +34 -0
  519. data/vendor/v8/test/mjsunit/regress/regress-1210.js +48 -0
  520. data/vendor/v8/test/mjsunit/regress/regress-1213.js +43 -0
  521. data/vendor/v8/test/mjsunit/regress/regress-1218.js +29 -0
  522. data/vendor/v8/test/mjsunit/regress/regress-1229.js +79 -0
  523. data/vendor/v8/test/mjsunit/regress/regress-1233.js +47 -0
  524. data/vendor/v8/test/mjsunit/regress/regress-1236.js +34 -0
  525. data/vendor/v8/test/mjsunit/regress/regress-1237.js +36 -0
  526. data/vendor/v8/test/mjsunit/regress/regress-1240.js +39 -0
  527. data/vendor/v8/test/mjsunit/regress/regress-1257.js +58 -0
  528. data/vendor/v8/test/mjsunit/regress/regress-1278.js +69 -0
  529. data/vendor/v8/test/mjsunit/regress/regress-create-exception.js +1 -0
  530. data/vendor/v8/test/mjsunit/regress/regress-lazy-deopt-reloc.js +52 -0
  531. data/vendor/v8/test/mjsunit/sin-cos.js +15 -10
  532. data/vendor/v8/test/mjsunit/smi-negative-zero.js +2 -2
  533. data/vendor/v8/test/mjsunit/str-to-num.js +1 -1
  534. data/vendor/v8/test/mjsunit/strict-mode.js +435 -0
  535. data/vendor/v8/test/mjsunit/testcfg.py +23 -6
  536. data/vendor/v8/test/mozilla/mozilla.status +0 -2
  537. data/vendor/v8/test/mozilla/testcfg.py +1 -1
  538. data/vendor/v8/test/preparser/empty.js +28 -0
  539. data/vendor/v8/test/preparser/functions-only.js +38 -0
  540. data/vendor/v8/test/preparser/non-alphanum.js +34 -0
  541. data/vendor/v8/test/preparser/symbols-only.js +49 -0
  542. data/vendor/v8/test/preparser/testcfg.py +90 -0
  543. data/vendor/v8/test/sputnik/testcfg.py +1 -1
  544. data/vendor/v8/test/test262/README +16 -0
  545. data/vendor/v8/test/test262/harness-adapt.js +80 -0
  546. data/vendor/v8/test/test262/test262.status +1506 -0
  547. data/vendor/v8/test/test262/testcfg.py +123 -0
  548. data/vendor/v8/tools/freebsd-tick-processor +10 -0
  549. data/vendor/v8/tools/gyp/v8.gyp +8 -33
  550. data/vendor/v8/tools/linux-tick-processor +5 -3
  551. data/vendor/v8/tools/test.py +37 -14
  552. data/vendor/v8/tools/tickprocessor.js +22 -8
  553. data/vendor/v8/tools/visual_studio/v8_base.vcproj +13 -1
  554. data/vendor/v8/tools/visual_studio/v8_base_arm.vcproj +5 -1
  555. data/vendor/v8/tools/visual_studio/v8_base_x64.vcproj +5 -1
  556. data/vendor/v8/tools/visual_studio/x64.vsprops +1 -0
  557. metadata +1495 -1341
  558. data/ext/extconf.rb +0 -22
  559. data/ext/mustang.cpp +0 -58
  560. data/vendor/v8/src/top.h +0 -608
@@ -41,18 +41,21 @@ namespace internal {
41
41
  // -------------------------------------------------------------------------
42
42
  // MacroAssembler implementation.
43
43
 
44
- MacroAssembler::MacroAssembler(void* buffer, int size)
45
- : Assembler(buffer, size),
44
+ MacroAssembler::MacroAssembler(Isolate* arg_isolate, void* buffer, int size)
45
+ : Assembler(arg_isolate, buffer, size),
46
46
  generating_stub_(false),
47
- allow_stub_calls_(true),
48
- code_object_(Heap::undefined_value()) {
47
+ allow_stub_calls_(true) {
48
+ if (isolate() != NULL) {
49
+ code_object_ = Handle<Object>(isolate()->heap()->undefined_value(),
50
+ isolate());
51
+ }
49
52
  }
50
53
 
51
54
 
52
55
  void MacroAssembler::RecordWriteHelper(Register object,
53
56
  Register addr,
54
57
  Register scratch) {
55
- if (FLAG_debug_code) {
58
+ if (emit_debug_code()) {
56
59
  // Check that the object is not in new space.
57
60
  Label not_in_new_space;
58
61
  InNewSpace(object, scratch, not_equal, &not_in_new_space);
@@ -113,7 +116,7 @@ void MacroAssembler::RecordWrite(Register object,
113
116
 
114
117
  // Clobber all input registers when running with the debug-code flag
115
118
  // turned on to provoke errors.
116
- if (FLAG_debug_code) {
119
+ if (emit_debug_code()) {
117
120
  mov(object, Immediate(BitCast<int32_t>(kZapValue)));
118
121
  mov(value, Immediate(BitCast<int32_t>(kZapValue)));
119
122
  mov(scratch, Immediate(BitCast<int32_t>(kZapValue)));
@@ -141,7 +144,7 @@ void MacroAssembler::RecordWrite(Register object,
141
144
 
142
145
  // Clobber all input registers when running with the debug-code flag
143
146
  // turned on to provoke errors.
144
- if (FLAG_debug_code) {
147
+ if (emit_debug_code()) {
145
148
  mov(object, Immediate(BitCast<int32_t>(kZapValue)));
146
149
  mov(address, Immediate(BitCast<int32_t>(kZapValue)));
147
150
  mov(value, Immediate(BitCast<int32_t>(kZapValue)));
@@ -152,7 +155,7 @@ void MacroAssembler::RecordWrite(Register object,
152
155
  #ifdef ENABLE_DEBUGGER_SUPPORT
153
156
  void MacroAssembler::DebugBreak() {
154
157
  Set(eax, Immediate(0));
155
- mov(ebx, Immediate(ExternalReference(Runtime::kDebugBreak)));
158
+ mov(ebx, Immediate(ExternalReference(Runtime::kDebugBreak, isolate())));
156
159
  CEntryStub ces(1);
157
160
  call(ces.GetCode(), RelocInfo::DEBUG_BREAK);
158
161
  }
@@ -250,7 +253,7 @@ void MacroAssembler::AbortIfNotNumber(Register object) {
250
253
  test(object, Immediate(kSmiTagMask));
251
254
  j(zero, &ok);
252
255
  cmp(FieldOperand(object, HeapObject::kMapOffset),
253
- Factory::heap_number_map());
256
+ isolate()->factory()->heap_number_map());
254
257
  Assert(equal, "Operand not a number");
255
258
  bind(&ok);
256
259
  }
@@ -285,15 +288,15 @@ void MacroAssembler::EnterFrame(StackFrame::Type type) {
285
288
  push(esi);
286
289
  push(Immediate(Smi::FromInt(type)));
287
290
  push(Immediate(CodeObject()));
288
- if (FLAG_debug_code) {
289
- cmp(Operand(esp, 0), Immediate(Factory::undefined_value()));
291
+ if (emit_debug_code()) {
292
+ cmp(Operand(esp, 0), Immediate(isolate()->factory()->undefined_value()));
290
293
  Check(not_equal, "code object not properly patched");
291
294
  }
292
295
  }
293
296
 
294
297
 
295
298
  void MacroAssembler::LeaveFrame(StackFrame::Type type) {
296
- if (FLAG_debug_code) {
299
+ if (emit_debug_code()) {
297
300
  cmp(Operand(ebp, StandardFrameConstants::kMarkerOffset),
298
301
  Immediate(Smi::FromInt(type)));
299
302
  Check(equal, "stack frame types must match");
@@ -316,8 +319,10 @@ void MacroAssembler::EnterExitFramePrologue() {
316
319
  push(Immediate(CodeObject())); // Accessed from ExitFrame::code_slot.
317
320
 
318
321
  // Save the frame pointer and the context in top.
319
- ExternalReference c_entry_fp_address(Top::k_c_entry_fp_address);
320
- ExternalReference context_address(Top::k_context_address);
322
+ ExternalReference c_entry_fp_address(Isolate::k_c_entry_fp_address,
323
+ isolate());
324
+ ExternalReference context_address(Isolate::k_context_address,
325
+ isolate());
321
326
  mov(Operand::StaticVariable(c_entry_fp_address), ebp);
322
327
  mov(Operand::StaticVariable(context_address), esi);
323
328
  }
@@ -339,7 +344,7 @@ void MacroAssembler::EnterExitFrameEpilogue(int argc, bool save_doubles) {
339
344
  }
340
345
 
341
346
  // Get the required frame alignment for the OS.
342
- static const int kFrameAlignment = OS::ActivationFrameAlignment();
347
+ const int kFrameAlignment = OS::ActivationFrameAlignment();
343
348
  if (kFrameAlignment > 0) {
344
349
  ASSERT(IsPowerOf2(kFrameAlignment));
345
350
  and_(esp, -kFrameAlignment);
@@ -358,7 +363,8 @@ void MacroAssembler::EnterExitFrame(bool save_doubles) {
358
363
  mov(edi, Operand(eax));
359
364
  lea(esi, Operand(ebp, eax, times_4, offset));
360
365
 
361
- EnterExitFrameEpilogue(2, save_doubles);
366
+ // Reserve space for argc, argv and isolate.
367
+ EnterExitFrameEpilogue(3, save_doubles);
362
368
  }
363
369
 
364
370
 
@@ -394,14 +400,15 @@ void MacroAssembler::LeaveExitFrame(bool save_doubles) {
394
400
 
395
401
  void MacroAssembler::LeaveExitFrameEpilogue() {
396
402
  // Restore current context from top and clear it in debug mode.
397
- ExternalReference context_address(Top::k_context_address);
403
+ ExternalReference context_address(Isolate::k_context_address, isolate());
398
404
  mov(esi, Operand::StaticVariable(context_address));
399
405
  #ifdef DEBUG
400
406
  mov(Operand::StaticVariable(context_address), Immediate(0));
401
407
  #endif
402
408
 
403
409
  // Clear the top frame.
404
- ExternalReference c_entry_fp_address(Top::k_c_entry_fp_address);
410
+ ExternalReference c_entry_fp_address(Isolate::k_c_entry_fp_address,
411
+ isolate());
405
412
  mov(Operand::StaticVariable(c_entry_fp_address), Immediate(0));
406
413
  }
407
414
 
@@ -435,15 +442,19 @@ void MacroAssembler::PushTryHandler(CodeLocation try_location,
435
442
  push(Immediate(0)); // NULL frame pointer.
436
443
  }
437
444
  // Save the current handler as the next handler.
438
- push(Operand::StaticVariable(ExternalReference(Top::k_handler_address)));
445
+ push(Operand::StaticVariable(ExternalReference(Isolate::k_handler_address,
446
+ isolate())));
439
447
  // Link this handler as the new current one.
440
- mov(Operand::StaticVariable(ExternalReference(Top::k_handler_address)), esp);
448
+ mov(Operand::StaticVariable(ExternalReference(Isolate::k_handler_address,
449
+ isolate())),
450
+ esp);
441
451
  }
442
452
 
443
453
 
444
454
  void MacroAssembler::PopTryHandler() {
445
455
  ASSERT_EQ(0, StackHandlerConstants::kNextOffset);
446
- pop(Operand::StaticVariable(ExternalReference(Top::k_handler_address)));
456
+ pop(Operand::StaticVariable(ExternalReference(Isolate::k_handler_address,
457
+ isolate())));
447
458
  add(Operand(esp), Immediate(StackHandlerConstants::kSize - kPointerSize));
448
459
  }
449
460
 
@@ -458,7 +469,8 @@ void MacroAssembler::Throw(Register value) {
458
469
  }
459
470
 
460
471
  // Drop the sp to the top of the handler.
461
- ExternalReference handler_address(Top::k_handler_address);
472
+ ExternalReference handler_address(Isolate::k_handler_address,
473
+ isolate());
462
474
  mov(esp, Operand::StaticVariable(handler_address));
463
475
 
464
476
  // Restore next handler and frame pointer, discard handler state.
@@ -494,7 +506,8 @@ void MacroAssembler::ThrowUncatchable(UncatchableExceptionType type,
494
506
  }
495
507
 
496
508
  // Drop sp to the top stack handler.
497
- ExternalReference handler_address(Top::k_handler_address);
509
+ ExternalReference handler_address(Isolate::k_handler_address,
510
+ isolate());
498
511
  mov(esp, Operand::StaticVariable(handler_address));
499
512
 
500
513
  // Unwind the handlers until the ENTRY handler is found.
@@ -516,12 +529,15 @@ void MacroAssembler::ThrowUncatchable(UncatchableExceptionType type,
516
529
 
517
530
  if (type == OUT_OF_MEMORY) {
518
531
  // Set external caught exception to false.
519
- ExternalReference external_caught(Top::k_external_caught_exception_address);
532
+ ExternalReference external_caught(
533
+ Isolate::k_external_caught_exception_address,
534
+ isolate());
520
535
  mov(eax, false);
521
536
  mov(Operand::StaticVariable(external_caught), eax);
522
537
 
523
538
  // Set pending exception and eax to out of memory exception.
524
- ExternalReference pending_exception(Top::k_pending_exception_address);
539
+ ExternalReference pending_exception(Isolate::k_pending_exception_address,
540
+ isolate());
525
541
  mov(eax, reinterpret_cast<int32_t>(Failure::OutOfMemoryException()));
526
542
  mov(Operand::StaticVariable(pending_exception), eax);
527
543
  }
@@ -550,7 +566,7 @@ void MacroAssembler::CheckAccessGlobalProxy(Register holder_reg,
550
566
  mov(scratch, Operand(ebp, StandardFrameConstants::kContextOffset));
551
567
 
552
568
  // When generating debug code, make sure the lexical context is set.
553
- if (FLAG_debug_code) {
569
+ if (emit_debug_code()) {
554
570
  cmp(Operand(scratch), Immediate(0));
555
571
  Check(not_equal, "we should not have an empty lexical context");
556
572
  }
@@ -560,11 +576,11 @@ void MacroAssembler::CheckAccessGlobalProxy(Register holder_reg,
560
576
  mov(scratch, FieldOperand(scratch, GlobalObject::kGlobalContextOffset));
561
577
 
562
578
  // Check the context is a global context.
563
- if (FLAG_debug_code) {
579
+ if (emit_debug_code()) {
564
580
  push(scratch);
565
581
  // Read the first word and compare to global_context_map.
566
582
  mov(scratch, FieldOperand(scratch, HeapObject::kMapOffset));
567
- cmp(scratch, Factory::global_context_map());
583
+ cmp(scratch, isolate()->factory()->global_context_map());
568
584
  Check(equal, "JSGlobalObject::global_context should be a global context.");
569
585
  pop(scratch);
570
586
  }
@@ -584,14 +600,14 @@ void MacroAssembler::CheckAccessGlobalProxy(Register holder_reg,
584
600
  mov(holder_reg, FieldOperand(holder_reg, JSGlobalProxy::kContextOffset));
585
601
 
586
602
  // Check the context is a global context.
587
- if (FLAG_debug_code) {
588
- cmp(holder_reg, Factory::null_value());
603
+ if (emit_debug_code()) {
604
+ cmp(holder_reg, isolate()->factory()->null_value());
589
605
  Check(not_equal, "JSGlobalProxy::context() should not be null.");
590
606
 
591
607
  push(holder_reg);
592
608
  // Read the first word and compare to global_context_map(),
593
609
  mov(holder_reg, FieldOperand(holder_reg, HeapObject::kMapOffset));
594
- cmp(holder_reg, Factory::global_context_map());
610
+ cmp(holder_reg, isolate()->factory()->global_context_map());
595
611
  Check(equal, "JSGlobalObject::global_context should be a global context.");
596
612
  pop(holder_reg);
597
613
  }
@@ -611,7 +627,7 @@ void MacroAssembler::LoadAllocationTopHelper(Register result,
611
627
  Register scratch,
612
628
  AllocationFlags flags) {
613
629
  ExternalReference new_space_allocation_top =
614
- ExternalReference::new_space_allocation_top_address();
630
+ ExternalReference::new_space_allocation_top_address(isolate());
615
631
 
616
632
  // Just return if allocation top is already known.
617
633
  if ((flags & RESULT_CONTAINS_TOP) != 0) {
@@ -637,13 +653,13 @@ void MacroAssembler::LoadAllocationTopHelper(Register result,
637
653
 
638
654
  void MacroAssembler::UpdateAllocationTopHelper(Register result_end,
639
655
  Register scratch) {
640
- if (FLAG_debug_code) {
656
+ if (emit_debug_code()) {
641
657
  test(result_end, Immediate(kObjectAlignmentMask));
642
658
  Check(zero, "Unaligned allocation in new space");
643
659
  }
644
660
 
645
661
  ExternalReference new_space_allocation_top =
646
- ExternalReference::new_space_allocation_top_address();
662
+ ExternalReference::new_space_allocation_top_address(isolate());
647
663
 
648
664
  // Update new top. Use scratch if available.
649
665
  if (scratch.is(no_reg)) {
@@ -661,7 +677,7 @@ void MacroAssembler::AllocateInNewSpace(int object_size,
661
677
  Label* gc_required,
662
678
  AllocationFlags flags) {
663
679
  if (!FLAG_inline_new) {
664
- if (FLAG_debug_code) {
680
+ if (emit_debug_code()) {
665
681
  // Trash the registers to simulate an allocation failure.
666
682
  mov(result, Immediate(0x7091));
667
683
  if (result_end.is_valid()) {
@@ -683,7 +699,7 @@ void MacroAssembler::AllocateInNewSpace(int object_size,
683
699
 
684
700
  // Calculate new top and bail out if new space is exhausted.
685
701
  ExternalReference new_space_allocation_limit =
686
- ExternalReference::new_space_allocation_limit_address();
702
+ ExternalReference::new_space_allocation_limit_address(isolate());
687
703
 
688
704
  if (!top_reg.is(result)) {
689
705
  mov(top_reg, result);
@@ -718,7 +734,7 @@ void MacroAssembler::AllocateInNewSpace(int header_size,
718
734
  Label* gc_required,
719
735
  AllocationFlags flags) {
720
736
  if (!FLAG_inline_new) {
721
- if (FLAG_debug_code) {
737
+ if (emit_debug_code()) {
722
738
  // Trash the registers to simulate an allocation failure.
723
739
  mov(result, Immediate(0x7091));
724
740
  mov(result_end, Immediate(0x7191));
@@ -737,7 +753,7 @@ void MacroAssembler::AllocateInNewSpace(int header_size,
737
753
 
738
754
  // Calculate new top and bail out if new space is exhausted.
739
755
  ExternalReference new_space_allocation_limit =
740
- ExternalReference::new_space_allocation_limit_address();
756
+ ExternalReference::new_space_allocation_limit_address(isolate());
741
757
 
742
758
  // We assume that element_count*element_size + header_size does not
743
759
  // overflow.
@@ -764,7 +780,7 @@ void MacroAssembler::AllocateInNewSpace(Register object_size,
764
780
  Label* gc_required,
765
781
  AllocationFlags flags) {
766
782
  if (!FLAG_inline_new) {
767
- if (FLAG_debug_code) {
783
+ if (emit_debug_code()) {
768
784
  // Trash the registers to simulate an allocation failure.
769
785
  mov(result, Immediate(0x7091));
770
786
  mov(result_end, Immediate(0x7191));
@@ -783,7 +799,7 @@ void MacroAssembler::AllocateInNewSpace(Register object_size,
783
799
 
784
800
  // Calculate new top and bail out if new space is exhausted.
785
801
  ExternalReference new_space_allocation_limit =
786
- ExternalReference::new_space_allocation_limit_address();
802
+ ExternalReference::new_space_allocation_limit_address(isolate());
787
803
  if (!object_size.is(result_end)) {
788
804
  mov(result_end, object_size);
789
805
  }
@@ -804,7 +820,7 @@ void MacroAssembler::AllocateInNewSpace(Register object_size,
804
820
 
805
821
  void MacroAssembler::UndoAllocationInNewSpace(Register object) {
806
822
  ExternalReference new_space_allocation_top =
807
- ExternalReference::new_space_allocation_top_address();
823
+ ExternalReference::new_space_allocation_top_address(isolate());
808
824
 
809
825
  // Make sure the object has no tag before resetting top.
810
826
  and_(Operand(object), Immediate(~kHeapObjectTagMask));
@@ -830,7 +846,7 @@ void MacroAssembler::AllocateHeapNumber(Register result,
830
846
 
831
847
  // Set the map.
832
848
  mov(FieldOperand(result, HeapObject::kMapOffset),
833
- Immediate(Factory::heap_number_map()));
849
+ Immediate(isolate()->factory()->heap_number_map()));
834
850
  }
835
851
 
836
852
 
@@ -860,7 +876,7 @@ void MacroAssembler::AllocateTwoByteString(Register result,
860
876
 
861
877
  // Set the map, length and hash field.
862
878
  mov(FieldOperand(result, HeapObject::kMapOffset),
863
- Immediate(Factory::string_map()));
879
+ Immediate(isolate()->factory()->string_map()));
864
880
  mov(scratch1, length);
865
881
  SmiTag(scratch1);
866
882
  mov(FieldOperand(result, String::kLengthOffset), scratch1);
@@ -895,7 +911,7 @@ void MacroAssembler::AllocateAsciiString(Register result,
895
911
 
896
912
  // Set the map, length and hash field.
897
913
  mov(FieldOperand(result, HeapObject::kMapOffset),
898
- Immediate(Factory::ascii_string_map()));
914
+ Immediate(isolate()->factory()->ascii_string_map()));
899
915
  mov(scratch1, length);
900
916
  SmiTag(scratch1);
901
917
  mov(FieldOperand(result, String::kLengthOffset), scratch1);
@@ -921,7 +937,7 @@ void MacroAssembler::AllocateAsciiString(Register result,
921
937
 
922
938
  // Set the map, length and hash field.
923
939
  mov(FieldOperand(result, HeapObject::kMapOffset),
924
- Immediate(Factory::ascii_string_map()));
940
+ Immediate(isolate()->factory()->ascii_string_map()));
925
941
  mov(FieldOperand(result, String::kLengthOffset),
926
942
  Immediate(Smi::FromInt(length)));
927
943
  mov(FieldOperand(result, String::kHashFieldOffset),
@@ -943,7 +959,7 @@ void MacroAssembler::AllocateConsString(Register result,
943
959
 
944
960
  // Set the map. The other fields are left uninitialized.
945
961
  mov(FieldOperand(result, HeapObject::kMapOffset),
946
- Immediate(Factory::cons_string_map()));
962
+ Immediate(isolate()->factory()->cons_string_map()));
947
963
  }
948
964
 
949
965
 
@@ -961,7 +977,7 @@ void MacroAssembler::AllocateAsciiConsString(Register result,
961
977
 
962
978
  // Set the map. The other fields are left uninitialized.
963
979
  mov(FieldOperand(result, HeapObject::kMapOffset),
964
- Immediate(Factory::cons_ascii_string_map()));
980
+ Immediate(isolate()->factory()->cons_ascii_string_map()));
965
981
  }
966
982
 
967
983
 
@@ -1079,7 +1095,7 @@ void MacroAssembler::TryGetFunctionPrototype(Register function,
1079
1095
  // If the prototype or initial map is the hole, don't return it and
1080
1096
  // simply miss the cache instead. This will allow us to allocate a
1081
1097
  // prototype object on-demand in the runtime system.
1082
- cmp(Operand(result), Immediate(Factory::the_hole_value()));
1098
+ cmp(Operand(result), Immediate(isolate()->factory()->the_hole_value()));
1083
1099
  j(equal, miss, not_taken);
1084
1100
 
1085
1101
  // If the function does not have an initial map, we're done.
@@ -1145,7 +1161,7 @@ void MacroAssembler::IllegalOperation(int num_arguments) {
1145
1161
  if (num_arguments > 0) {
1146
1162
  add(Operand(esp), Immediate(num_arguments * kPointerSize));
1147
1163
  }
1148
- mov(eax, Immediate(Factory::undefined_value()));
1164
+ mov(eax, Immediate(isolate()->factory()->undefined_value()));
1149
1165
  }
1150
1166
 
1151
1167
 
@@ -1174,9 +1190,9 @@ void MacroAssembler::CallRuntime(Runtime::FunctionId id, int num_arguments) {
1174
1190
 
1175
1191
 
1176
1192
  void MacroAssembler::CallRuntimeSaveDoubles(Runtime::FunctionId id) {
1177
- Runtime::Function* function = Runtime::FunctionForId(id);
1193
+ const Runtime::Function* function = Runtime::FunctionForId(id);
1178
1194
  Set(eax, Immediate(function->nargs));
1179
- mov(ebx, Immediate(ExternalReference(function)));
1195
+ mov(ebx, Immediate(ExternalReference(function, isolate())));
1180
1196
  CEntryStub ces(1);
1181
1197
  ces.SaveDoubles();
1182
1198
  CallStub(&ces);
@@ -1189,7 +1205,8 @@ MaybeObject* MacroAssembler::TryCallRuntime(Runtime::FunctionId id,
1189
1205
  }
1190
1206
 
1191
1207
 
1192
- void MacroAssembler::CallRuntime(Runtime::Function* f, int num_arguments) {
1208
+ void MacroAssembler::CallRuntime(const Runtime::Function* f,
1209
+ int num_arguments) {
1193
1210
  // If the expected number of arguments of the runtime function is
1194
1211
  // constant, we check that the actual number of arguments match the
1195
1212
  // expectation.
@@ -1203,19 +1220,19 @@ void MacroAssembler::CallRuntime(Runtime::Function* f, int num_arguments) {
1203
1220
  // should remove this need and make the runtime routine entry code
1204
1221
  // smarter.
1205
1222
  Set(eax, Immediate(num_arguments));
1206
- mov(ebx, Immediate(ExternalReference(f)));
1223
+ mov(ebx, Immediate(ExternalReference(f, isolate())));
1207
1224
  CEntryStub ces(1);
1208
1225
  CallStub(&ces);
1209
1226
  }
1210
1227
 
1211
1228
 
1212
- MaybeObject* MacroAssembler::TryCallRuntime(Runtime::Function* f,
1229
+ MaybeObject* MacroAssembler::TryCallRuntime(const Runtime::Function* f,
1213
1230
  int num_arguments) {
1214
1231
  if (f->nargs >= 0 && f->nargs != num_arguments) {
1215
1232
  IllegalOperation(num_arguments);
1216
1233
  // Since we did not call the stub, there was no allocation failure.
1217
1234
  // Return some non-failure object.
1218
- return Heap::undefined_value();
1235
+ return isolate()->heap()->undefined_value();
1219
1236
  }
1220
1237
 
1221
1238
  // TODO(1236192): Most runtime routines don't need the number of
@@ -1223,7 +1240,7 @@ MaybeObject* MacroAssembler::TryCallRuntime(Runtime::Function* f,
1223
1240
  // should remove this need and make the runtime routine entry code
1224
1241
  // smarter.
1225
1242
  Set(eax, Immediate(num_arguments));
1226
- mov(ebx, Immediate(ExternalReference(f)));
1243
+ mov(ebx, Immediate(ExternalReference(f, isolate())));
1227
1244
  CEntryStub ces(1);
1228
1245
  return TryCallStub(&ces);
1229
1246
  }
@@ -1265,7 +1282,9 @@ MaybeObject* MacroAssembler::TryTailCallExternalReference(
1265
1282
  void MacroAssembler::TailCallRuntime(Runtime::FunctionId fid,
1266
1283
  int num_arguments,
1267
1284
  int result_size) {
1268
- TailCallExternalReference(ExternalReference(fid), num_arguments, result_size);
1285
+ TailCallExternalReference(ExternalReference(fid, isolate()),
1286
+ num_arguments,
1287
+ result_size);
1269
1288
  }
1270
1289
 
1271
1290
 
@@ -1273,7 +1292,7 @@ MaybeObject* MacroAssembler::TryTailCallRuntime(Runtime::FunctionId fid,
1273
1292
  int num_arguments,
1274
1293
  int result_size) {
1275
1294
  return TryTailCallExternalReference(
1276
- ExternalReference(fid), num_arguments, result_size);
1295
+ ExternalReference(fid, isolate()), num_arguments, result_size);
1277
1296
  }
1278
1297
 
1279
1298
 
@@ -1320,7 +1339,7 @@ void MacroAssembler::PrepareCallApiFunction(int argc, Register scratch) {
1320
1339
  // pointer to out cell.
1321
1340
  lea(scratch, Operand(esp, (argc + 1) * kPointerSize));
1322
1341
  mov(Operand(esp, 0 * kPointerSize), scratch); // output.
1323
- if (FLAG_debug_code) {
1342
+ if (emit_debug_code()) {
1324
1343
  mov(Operand(esp, (argc + 1) * kPointerSize), Immediate(0)); // out cell.
1325
1344
  }
1326
1345
  }
@@ -1373,9 +1392,9 @@ MaybeObject* MacroAssembler::TryCallApiFunctionAndReturn(ApiFunction* function,
1373
1392
 
1374
1393
  // Check if the function scheduled an exception.
1375
1394
  ExternalReference scheduled_exception_address =
1376
- ExternalReference::scheduled_exception_address();
1395
+ ExternalReference::scheduled_exception_address(isolate());
1377
1396
  cmp(Operand::StaticVariable(scheduled_exception_address),
1378
- Immediate(Factory::the_hole_value()));
1397
+ Immediate(isolate()->factory()->the_hole_value()));
1379
1398
  j(not_equal, &promote_scheduled_exception, not_taken);
1380
1399
  LeaveApiExitFrame();
1381
1400
  ret(stack_space * kPointerSize);
@@ -1387,14 +1406,17 @@ MaybeObject* MacroAssembler::TryCallApiFunctionAndReturn(ApiFunction* function,
1387
1406
  }
1388
1407
  bind(&empty_handle);
1389
1408
  // It was zero; the result is undefined.
1390
- mov(eax, Factory::undefined_value());
1409
+ mov(eax, isolate()->factory()->undefined_value());
1391
1410
  jmp(&prologue);
1392
1411
 
1393
1412
  // HandleScope limit has changed. Delete allocated extensions.
1413
+ ExternalReference delete_extensions =
1414
+ ExternalReference::delete_handle_scope_extensions(isolate());
1394
1415
  bind(&delete_allocated_handles);
1395
1416
  mov(Operand::StaticVariable(limit_address), edi);
1396
1417
  mov(edi, eax);
1397
- mov(eax, Immediate(ExternalReference::delete_handle_scope_extensions()));
1418
+ mov(Operand(esp, 0), Immediate(ExternalReference::isolate_address()));
1419
+ mov(eax, Immediate(delete_extensions));
1398
1420
  call(Operand(eax));
1399
1421
  mov(eax, edi);
1400
1422
  jmp(&leave_exit_frame);
@@ -1424,7 +1446,7 @@ void MacroAssembler::InvokePrologue(const ParameterCount& expected,
1424
1446
  const ParameterCount& actual,
1425
1447
  Handle<Code> code_constant,
1426
1448
  const Operand& code_operand,
1427
- Label* done,
1449
+ NearLabel* done,
1428
1450
  InvokeFlag flag,
1429
1451
  PostCallGenerator* post_call_generator) {
1430
1452
  bool definitely_matches = false;
@@ -1467,7 +1489,7 @@ void MacroAssembler::InvokePrologue(const ParameterCount& expected,
1467
1489
 
1468
1490
  if (!definitely_matches) {
1469
1491
  Handle<Code> adaptor =
1470
- Handle<Code>(Builtins::builtin(Builtins::ArgumentsAdaptorTrampoline));
1492
+ isolate()->builtins()->ArgumentsAdaptorTrampoline();
1471
1493
  if (!code_constant.is_null()) {
1472
1494
  mov(edx, Immediate(code_constant));
1473
1495
  add(Operand(edx), Immediate(Code::kHeaderSize - kHeapObjectTag));
@@ -1492,7 +1514,7 @@ void MacroAssembler::InvokeCode(const Operand& code,
1492
1514
  const ParameterCount& actual,
1493
1515
  InvokeFlag flag,
1494
1516
  PostCallGenerator* post_call_generator) {
1495
- Label done;
1517
+ NearLabel done;
1496
1518
  InvokePrologue(expected, actual, Handle<Code>::null(), code,
1497
1519
  &done, flag, post_call_generator);
1498
1520
  if (flag == CALL_FUNCTION) {
@@ -1512,7 +1534,7 @@ void MacroAssembler::InvokeCode(Handle<Code> code,
1512
1534
  RelocInfo::Mode rmode,
1513
1535
  InvokeFlag flag,
1514
1536
  PostCallGenerator* post_call_generator) {
1515
- Label done;
1537
+ NearLabel done;
1516
1538
  Operand dummy(eax);
1517
1539
  InvokePrologue(expected, actual, code, dummy, &done,
1518
1540
  flag, post_call_generator);
@@ -1621,7 +1643,7 @@ void MacroAssembler::LoadContext(Register dst, int context_chain_length) {
1621
1643
  // (i.e., the static scope chain and runtime context chain do not agree).
1622
1644
  // A variable occurring in such a scope should have slot type LOOKUP and
1623
1645
  // not CONTEXT.
1624
- if (FLAG_debug_code) {
1646
+ if (emit_debug_code()) {
1625
1647
  cmp(dst, Operand(dst, Context::SlotOffset(Context::FCONTEXT_INDEX)));
1626
1648
  Check(equal, "Yo dawg, I heard you liked function contexts "
1627
1649
  "so I put function contexts in all your contexts");
@@ -1643,9 +1665,9 @@ void MacroAssembler::LoadGlobalFunctionInitialMap(Register function,
1643
1665
  Register map) {
1644
1666
  // Load the initial map. The global functions all have initial maps.
1645
1667
  mov(map, FieldOperand(function, JSFunction::kPrototypeOrInitialMapOffset));
1646
- if (FLAG_debug_code) {
1668
+ if (emit_debug_code()) {
1647
1669
  Label ok, fail;
1648
- CheckMap(map, Factory::meta_map(), &fail, false);
1670
+ CheckMap(map, isolate()->factory()->meta_map(), &fail, false);
1649
1671
  jmp(&ok);
1650
1672
  bind(&fail);
1651
1673
  Abort("Global functions must have initial map");
@@ -1787,18 +1809,19 @@ void MacroAssembler::DecrementCounter(Condition cc,
1787
1809
 
1788
1810
 
1789
1811
  void MacroAssembler::Assert(Condition cc, const char* msg) {
1790
- if (FLAG_debug_code) Check(cc, msg);
1812
+ if (emit_debug_code()) Check(cc, msg);
1791
1813
  }
1792
1814
 
1793
1815
 
1794
1816
  void MacroAssembler::AssertFastElements(Register elements) {
1795
- if (FLAG_debug_code) {
1817
+ if (emit_debug_code()) {
1818
+ Factory* factory = isolate()->factory();
1796
1819
  Label ok;
1797
1820
  cmp(FieldOperand(elements, HeapObject::kMapOffset),
1798
- Immediate(Factory::fixed_array_map()));
1821
+ Immediate(factory->fixed_array_map()));
1799
1822
  j(equal, &ok);
1800
1823
  cmp(FieldOperand(elements, HeapObject::kMapOffset),
1801
- Immediate(Factory::fixed_cow_array_map()));
1824
+ Immediate(factory->fixed_cow_array_map()));
1802
1825
  j(equal, &ok);
1803
1826
  Abort("JSObject with fast elements map has slow elements");
1804
1827
  bind(&ok);
@@ -1860,10 +1883,10 @@ void MacroAssembler::Abort(const char* msg) {
1860
1883
  void MacroAssembler::JumpIfNotNumber(Register reg,
1861
1884
  TypeInfo info,
1862
1885
  Label* on_not_number) {
1863
- if (FLAG_debug_code) AbortIfSmi(reg);
1886
+ if (emit_debug_code()) AbortIfSmi(reg);
1864
1887
  if (!info.IsNumber()) {
1865
1888
  cmp(FieldOperand(reg, HeapObject::kMapOffset),
1866
- Factory::heap_number_map());
1889
+ isolate()->factory()->heap_number_map());
1867
1890
  j(not_equal, on_not_number);
1868
1891
  }
1869
1892
  }
@@ -1874,7 +1897,7 @@ void MacroAssembler::ConvertToInt32(Register dst,
1874
1897
  Register scratch,
1875
1898
  TypeInfo info,
1876
1899
  Label* on_not_int32) {
1877
- if (FLAG_debug_code) {
1900
+ if (emit_debug_code()) {
1878
1901
  AbortIfSmi(source);
1879
1902
  AbortIfNotNumber(source);
1880
1903
  }
@@ -1968,14 +1991,14 @@ void MacroAssembler::JumpIfNotBothSequentialAsciiStrings(Register object1,
1968
1991
 
1969
1992
 
1970
1993
  void MacroAssembler::PrepareCallCFunction(int num_arguments, Register scratch) {
1971
- int frameAlignment = OS::ActivationFrameAlignment();
1972
- if (frameAlignment != 0) {
1994
+ int frame_alignment = OS::ActivationFrameAlignment();
1995
+ if (frame_alignment != 0) {
1973
1996
  // Make stack end at alignment and make room for num_arguments words
1974
1997
  // and the original value of esp.
1975
1998
  mov(scratch, esp);
1976
1999
  sub(Operand(esp), Immediate((num_arguments + 1) * kPointerSize));
1977
- ASSERT(IsPowerOf2(frameAlignment));
1978
- and_(esp, -frameAlignment);
2000
+ ASSERT(IsPowerOf2(frame_alignment));
2001
+ and_(esp, -frame_alignment);
1979
2002
  mov(Operand(esp, num_arguments * kPointerSize), scratch);
1980
2003
  } else {
1981
2004
  sub(Operand(esp), Immediate(num_arguments * kPointerSize));
@@ -1994,7 +2017,7 @@ void MacroAssembler::CallCFunction(ExternalReference function,
1994
2017
  void MacroAssembler::CallCFunction(Register function,
1995
2018
  int num_arguments) {
1996
2019
  // Check stack alignment.
1997
- if (FLAG_debug_code) {
2020
+ if (emit_debug_code()) {
1998
2021
  CheckStackAlignment();
1999
2022
  }
2000
2023
 
@@ -2002,13 +2025,15 @@ void MacroAssembler::CallCFunction(Register function,
2002
2025
  if (OS::ActivationFrameAlignment() != 0) {
2003
2026
  mov(esp, Operand(esp, num_arguments * kPointerSize));
2004
2027
  } else {
2005
- add(Operand(esp), Immediate(num_arguments * sizeof(int32_t)));
2028
+ add(Operand(esp), Immediate(num_arguments * kPointerSize));
2006
2029
  }
2007
2030
  }
2008
2031
 
2009
2032
 
2010
2033
  CodePatcher::CodePatcher(byte* address, int size)
2011
- : address_(address), size_(size), masm_(address, size + Assembler::kGap) {
2034
+ : address_(address),
2035
+ size_(size),
2036
+ masm_(Isolate::Current(), address, size + Assembler::kGap) {
2012
2037
  // Create a new macro assembler pointing to the address of the code to patch.
2013
2038
  // The size is adjusted with kGap on order for the assembler to generate size
2014
2039
  // bytes of instructions without failing with buffer size constraints.