libv8 3.11.8.17 → 3.16.14.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (754) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +1 -2
  3. data/Gemfile +1 -1
  4. data/Rakefile +6 -7
  5. data/lib/libv8/version.rb +1 -1
  6. data/vendor/v8/.gitignore +24 -3
  7. data/vendor/v8/AUTHORS +7 -0
  8. data/vendor/v8/ChangeLog +839 -0
  9. data/vendor/v8/DEPS +1 -1
  10. data/vendor/v8/Makefile.android +92 -0
  11. data/vendor/v8/OWNERS +11 -0
  12. data/vendor/v8/PRESUBMIT.py +71 -0
  13. data/vendor/v8/SConstruct +34 -39
  14. data/vendor/v8/build/android.gypi +56 -37
  15. data/vendor/v8/build/common.gypi +112 -30
  16. data/vendor/v8/build/gyp_v8 +1 -1
  17. data/vendor/v8/build/standalone.gypi +15 -11
  18. data/vendor/v8/include/v8-debug.h +9 -1
  19. data/vendor/v8/include/v8-preparser.h +4 -3
  20. data/vendor/v8/include/v8-profiler.h +25 -25
  21. data/vendor/v8/include/v8-testing.h +4 -3
  22. data/vendor/v8/include/v8.h +994 -540
  23. data/vendor/v8/preparser/preparser-process.cc +3 -3
  24. data/vendor/v8/samples/lineprocessor.cc +20 -27
  25. data/vendor/v8/samples/process.cc +18 -14
  26. data/vendor/v8/samples/shell.cc +16 -15
  27. data/vendor/v8/src/SConscript +15 -14
  28. data/vendor/v8/src/accessors.cc +169 -77
  29. data/vendor/v8/src/accessors.h +4 -0
  30. data/vendor/v8/src/allocation-inl.h +2 -2
  31. data/vendor/v8/src/allocation.h +7 -7
  32. data/vendor/v8/src/api.cc +810 -497
  33. data/vendor/v8/src/api.h +85 -60
  34. data/vendor/v8/src/arm/assembler-arm-inl.h +179 -22
  35. data/vendor/v8/src/arm/assembler-arm.cc +633 -264
  36. data/vendor/v8/src/arm/assembler-arm.h +264 -197
  37. data/vendor/v8/src/arm/builtins-arm.cc +117 -27
  38. data/vendor/v8/src/arm/code-stubs-arm.cc +1241 -700
  39. data/vendor/v8/src/arm/code-stubs-arm.h +35 -138
  40. data/vendor/v8/src/arm/codegen-arm.cc +285 -16
  41. data/vendor/v8/src/arm/codegen-arm.h +22 -0
  42. data/vendor/v8/src/arm/constants-arm.cc +5 -3
  43. data/vendor/v8/src/arm/constants-arm.h +24 -11
  44. data/vendor/v8/src/arm/debug-arm.cc +3 -3
  45. data/vendor/v8/src/arm/deoptimizer-arm.cc +382 -92
  46. data/vendor/v8/src/arm/disasm-arm.cc +61 -12
  47. data/vendor/v8/src/arm/frames-arm.h +0 -14
  48. data/vendor/v8/src/arm/full-codegen-arm.cc +332 -304
  49. data/vendor/v8/src/arm/ic-arm.cc +180 -259
  50. data/vendor/v8/src/arm/lithium-arm.cc +364 -316
  51. data/vendor/v8/src/arm/lithium-arm.h +512 -275
  52. data/vendor/v8/src/arm/lithium-codegen-arm.cc +1768 -809
  53. data/vendor/v8/src/arm/lithium-codegen-arm.h +97 -35
  54. data/vendor/v8/src/arm/lithium-gap-resolver-arm.cc +12 -5
  55. data/vendor/v8/src/arm/macro-assembler-arm.cc +439 -228
  56. data/vendor/v8/src/arm/macro-assembler-arm.h +116 -70
  57. data/vendor/v8/src/arm/regexp-macro-assembler-arm.cc +54 -44
  58. data/vendor/v8/src/arm/regexp-macro-assembler-arm.h +3 -10
  59. data/vendor/v8/src/arm/simulator-arm.cc +272 -238
  60. data/vendor/v8/src/arm/simulator-arm.h +38 -8
  61. data/vendor/v8/src/arm/stub-cache-arm.cc +522 -895
  62. data/vendor/v8/src/array.js +101 -70
  63. data/vendor/v8/src/assembler.cc +270 -19
  64. data/vendor/v8/src/assembler.h +110 -15
  65. data/vendor/v8/src/ast.cc +79 -69
  66. data/vendor/v8/src/ast.h +255 -301
  67. data/vendor/v8/src/atomicops.h +7 -1
  68. data/vendor/v8/src/atomicops_internals_tsan.h +335 -0
  69. data/vendor/v8/src/bootstrapper.cc +481 -418
  70. data/vendor/v8/src/bootstrapper.h +4 -4
  71. data/vendor/v8/src/builtins.cc +498 -311
  72. data/vendor/v8/src/builtins.h +75 -47
  73. data/vendor/v8/src/checks.cc +2 -1
  74. data/vendor/v8/src/checks.h +8 -0
  75. data/vendor/v8/src/code-stubs-hydrogen.cc +253 -0
  76. data/vendor/v8/src/code-stubs.cc +249 -84
  77. data/vendor/v8/src/code-stubs.h +501 -169
  78. data/vendor/v8/src/codegen.cc +36 -18
  79. data/vendor/v8/src/codegen.h +25 -3
  80. data/vendor/v8/src/collection.js +54 -17
  81. data/vendor/v8/src/compilation-cache.cc +24 -16
  82. data/vendor/v8/src/compilation-cache.h +15 -6
  83. data/vendor/v8/src/compiler.cc +497 -195
  84. data/vendor/v8/src/compiler.h +246 -38
  85. data/vendor/v8/src/contexts.cc +64 -24
  86. data/vendor/v8/src/contexts.h +60 -29
  87. data/vendor/v8/src/conversions-inl.h +24 -14
  88. data/vendor/v8/src/conversions.h +7 -4
  89. data/vendor/v8/src/counters.cc +21 -12
  90. data/vendor/v8/src/counters.h +44 -16
  91. data/vendor/v8/src/cpu-profiler.h +1 -1
  92. data/vendor/v8/src/d8-debug.cc +2 -2
  93. data/vendor/v8/src/d8-readline.cc +13 -2
  94. data/vendor/v8/src/d8.cc +681 -273
  95. data/vendor/v8/src/d8.gyp +4 -4
  96. data/vendor/v8/src/d8.h +38 -18
  97. data/vendor/v8/src/d8.js +0 -617
  98. data/vendor/v8/src/data-flow.h +55 -0
  99. data/vendor/v8/src/date.js +1 -42
  100. data/vendor/v8/src/dateparser-inl.h +5 -1
  101. data/vendor/v8/src/debug-agent.cc +10 -15
  102. data/vendor/v8/src/debug-debugger.js +147 -149
  103. data/vendor/v8/src/debug.cc +323 -164
  104. data/vendor/v8/src/debug.h +26 -14
  105. data/vendor/v8/src/deoptimizer.cc +765 -290
  106. data/vendor/v8/src/deoptimizer.h +130 -28
  107. data/vendor/v8/src/disassembler.cc +10 -4
  108. data/vendor/v8/src/elements-kind.cc +7 -2
  109. data/vendor/v8/src/elements-kind.h +19 -0
  110. data/vendor/v8/src/elements.cc +607 -285
  111. data/vendor/v8/src/elements.h +36 -13
  112. data/vendor/v8/src/execution.cc +52 -31
  113. data/vendor/v8/src/execution.h +4 -4
  114. data/vendor/v8/src/extensions/externalize-string-extension.cc +5 -4
  115. data/vendor/v8/src/extensions/gc-extension.cc +5 -1
  116. data/vendor/v8/src/extensions/statistics-extension.cc +153 -0
  117. data/vendor/v8/src/{inspector.h → extensions/statistics-extension.h} +12 -23
  118. data/vendor/v8/src/factory.cc +101 -134
  119. data/vendor/v8/src/factory.h +36 -31
  120. data/vendor/v8/src/flag-definitions.h +102 -25
  121. data/vendor/v8/src/flags.cc +9 -5
  122. data/vendor/v8/src/frames-inl.h +10 -0
  123. data/vendor/v8/src/frames.cc +116 -26
  124. data/vendor/v8/src/frames.h +96 -12
  125. data/vendor/v8/src/full-codegen.cc +219 -74
  126. data/vendor/v8/src/full-codegen.h +63 -21
  127. data/vendor/v8/src/func-name-inferrer.cc +8 -7
  128. data/vendor/v8/src/func-name-inferrer.h +5 -3
  129. data/vendor/v8/src/gdb-jit.cc +71 -57
  130. data/vendor/v8/src/global-handles.cc +230 -101
  131. data/vendor/v8/src/global-handles.h +26 -27
  132. data/vendor/v8/src/globals.h +17 -19
  133. data/vendor/v8/src/handles-inl.h +59 -12
  134. data/vendor/v8/src/handles.cc +180 -200
  135. data/vendor/v8/src/handles.h +80 -11
  136. data/vendor/v8/src/hashmap.h +60 -40
  137. data/vendor/v8/src/heap-inl.h +107 -45
  138. data/vendor/v8/src/heap-profiler.cc +38 -19
  139. data/vendor/v8/src/heap-profiler.h +24 -14
  140. data/vendor/v8/src/heap.cc +1123 -738
  141. data/vendor/v8/src/heap.h +385 -146
  142. data/vendor/v8/src/hydrogen-instructions.cc +700 -217
  143. data/vendor/v8/src/hydrogen-instructions.h +1158 -472
  144. data/vendor/v8/src/hydrogen.cc +3319 -1662
  145. data/vendor/v8/src/hydrogen.h +411 -170
  146. data/vendor/v8/src/ia32/assembler-ia32-inl.h +46 -16
  147. data/vendor/v8/src/ia32/assembler-ia32.cc +131 -61
  148. data/vendor/v8/src/ia32/assembler-ia32.h +115 -57
  149. data/vendor/v8/src/ia32/builtins-ia32.cc +99 -5
  150. data/vendor/v8/src/ia32/code-stubs-ia32.cc +787 -495
  151. data/vendor/v8/src/ia32/code-stubs-ia32.h +10 -100
  152. data/vendor/v8/src/ia32/codegen-ia32.cc +227 -23
  153. data/vendor/v8/src/ia32/codegen-ia32.h +14 -0
  154. data/vendor/v8/src/ia32/deoptimizer-ia32.cc +428 -87
  155. data/vendor/v8/src/ia32/disasm-ia32.cc +28 -1
  156. data/vendor/v8/src/ia32/frames-ia32.h +6 -16
  157. data/vendor/v8/src/ia32/full-codegen-ia32.cc +280 -272
  158. data/vendor/v8/src/ia32/ic-ia32.cc +150 -250
  159. data/vendor/v8/src/ia32/lithium-codegen-ia32.cc +1600 -517
  160. data/vendor/v8/src/ia32/lithium-codegen-ia32.h +90 -24
  161. data/vendor/v8/src/ia32/lithium-gap-resolver-ia32.cc +10 -6
  162. data/vendor/v8/src/ia32/lithium-gap-resolver-ia32.h +2 -2
  163. data/vendor/v8/src/ia32/lithium-ia32.cc +405 -302
  164. data/vendor/v8/src/ia32/lithium-ia32.h +526 -271
  165. data/vendor/v8/src/ia32/macro-assembler-ia32.cc +378 -119
  166. data/vendor/v8/src/ia32/macro-assembler-ia32.h +62 -28
  167. data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.cc +43 -30
  168. data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.h +2 -10
  169. data/vendor/v8/src/ia32/stub-cache-ia32.cc +492 -678
  170. data/vendor/v8/src/ic-inl.h +9 -4
  171. data/vendor/v8/src/ic.cc +836 -923
  172. data/vendor/v8/src/ic.h +228 -247
  173. data/vendor/v8/src/incremental-marking-inl.h +26 -30
  174. data/vendor/v8/src/incremental-marking.cc +276 -248
  175. data/vendor/v8/src/incremental-marking.h +29 -37
  176. data/vendor/v8/src/interface.cc +34 -25
  177. data/vendor/v8/src/interface.h +69 -25
  178. data/vendor/v8/src/interpreter-irregexp.cc +2 -2
  179. data/vendor/v8/src/isolate.cc +382 -76
  180. data/vendor/v8/src/isolate.h +109 -56
  181. data/vendor/v8/src/json-parser.h +217 -104
  182. data/vendor/v8/src/json-stringifier.h +745 -0
  183. data/vendor/v8/src/json.js +10 -132
  184. data/vendor/v8/src/jsregexp-inl.h +106 -0
  185. data/vendor/v8/src/jsregexp.cc +517 -285
  186. data/vendor/v8/src/jsregexp.h +145 -117
  187. data/vendor/v8/src/list-inl.h +35 -22
  188. data/vendor/v8/src/list.h +46 -19
  189. data/vendor/v8/src/lithium-allocator-inl.h +22 -2
  190. data/vendor/v8/src/lithium-allocator.cc +85 -70
  191. data/vendor/v8/src/lithium-allocator.h +21 -39
  192. data/vendor/v8/src/lithium.cc +259 -5
  193. data/vendor/v8/src/lithium.h +131 -32
  194. data/vendor/v8/src/liveedit-debugger.js +52 -3
  195. data/vendor/v8/src/liveedit.cc +393 -113
  196. data/vendor/v8/src/liveedit.h +7 -3
  197. data/vendor/v8/src/log-utils.cc +4 -2
  198. data/vendor/v8/src/log.cc +170 -140
  199. data/vendor/v8/src/log.h +62 -11
  200. data/vendor/v8/src/macro-assembler.h +17 -0
  201. data/vendor/v8/src/macros.py +2 -0
  202. data/vendor/v8/src/mark-compact-inl.h +3 -23
  203. data/vendor/v8/src/mark-compact.cc +801 -830
  204. data/vendor/v8/src/mark-compact.h +154 -47
  205. data/vendor/v8/src/marking-thread.cc +85 -0
  206. data/vendor/v8/src/{inspector.cc → marking-thread.h} +32 -24
  207. data/vendor/v8/src/math.js +12 -18
  208. data/vendor/v8/src/messages.cc +18 -8
  209. data/vendor/v8/src/messages.js +314 -261
  210. data/vendor/v8/src/mips/assembler-mips-inl.h +58 -6
  211. data/vendor/v8/src/mips/assembler-mips.cc +92 -75
  212. data/vendor/v8/src/mips/assembler-mips.h +54 -60
  213. data/vendor/v8/src/mips/builtins-mips.cc +116 -17
  214. data/vendor/v8/src/mips/code-stubs-mips.cc +919 -556
  215. data/vendor/v8/src/mips/code-stubs-mips.h +22 -131
  216. data/vendor/v8/src/mips/codegen-mips.cc +281 -6
  217. data/vendor/v8/src/mips/codegen-mips.h +22 -0
  218. data/vendor/v8/src/mips/constants-mips.cc +2 -0
  219. data/vendor/v8/src/mips/constants-mips.h +12 -2
  220. data/vendor/v8/src/mips/deoptimizer-mips.cc +286 -50
  221. data/vendor/v8/src/mips/disasm-mips.cc +13 -0
  222. data/vendor/v8/src/mips/full-codegen-mips.cc +297 -284
  223. data/vendor/v8/src/mips/ic-mips.cc +182 -263
  224. data/vendor/v8/src/mips/lithium-codegen-mips.cc +1208 -556
  225. data/vendor/v8/src/mips/lithium-codegen-mips.h +72 -19
  226. data/vendor/v8/src/mips/lithium-gap-resolver-mips.cc +9 -2
  227. data/vendor/v8/src/mips/lithium-mips.cc +290 -302
  228. data/vendor/v8/src/mips/lithium-mips.h +463 -266
  229. data/vendor/v8/src/mips/macro-assembler-mips.cc +208 -115
  230. data/vendor/v8/src/mips/macro-assembler-mips.h +67 -24
  231. data/vendor/v8/src/mips/regexp-macro-assembler-mips.cc +40 -25
  232. data/vendor/v8/src/mips/regexp-macro-assembler-mips.h +3 -9
  233. data/vendor/v8/src/mips/simulator-mips.cc +112 -40
  234. data/vendor/v8/src/mips/simulator-mips.h +5 -0
  235. data/vendor/v8/src/mips/stub-cache-mips.cc +502 -884
  236. data/vendor/v8/src/mirror-debugger.js +157 -30
  237. data/vendor/v8/src/mksnapshot.cc +88 -14
  238. data/vendor/v8/src/object-observe.js +235 -0
  239. data/vendor/v8/src/objects-debug.cc +178 -176
  240. data/vendor/v8/src/objects-inl.h +1333 -486
  241. data/vendor/v8/src/objects-printer.cc +125 -43
  242. data/vendor/v8/src/objects-visiting-inl.h +578 -6
  243. data/vendor/v8/src/objects-visiting.cc +2 -2
  244. data/vendor/v8/src/objects-visiting.h +172 -79
  245. data/vendor/v8/src/objects.cc +3533 -2885
  246. data/vendor/v8/src/objects.h +1352 -1131
  247. data/vendor/v8/src/optimizing-compiler-thread.cc +152 -0
  248. data/vendor/v8/src/optimizing-compiler-thread.h +111 -0
  249. data/vendor/v8/src/parser.cc +390 -500
  250. data/vendor/v8/src/parser.h +45 -33
  251. data/vendor/v8/src/platform-cygwin.cc +10 -21
  252. data/vendor/v8/src/platform-freebsd.cc +36 -41
  253. data/vendor/v8/src/platform-linux.cc +160 -124
  254. data/vendor/v8/src/platform-macos.cc +30 -27
  255. data/vendor/v8/src/platform-nullos.cc +17 -1
  256. data/vendor/v8/src/platform-openbsd.cc +19 -50
  257. data/vendor/v8/src/platform-posix.cc +14 -0
  258. data/vendor/v8/src/platform-solaris.cc +20 -53
  259. data/vendor/v8/src/platform-win32.cc +49 -26
  260. data/vendor/v8/src/platform.h +40 -1
  261. data/vendor/v8/src/preparser.cc +8 -5
  262. data/vendor/v8/src/preparser.h +2 -2
  263. data/vendor/v8/src/prettyprinter.cc +16 -0
  264. data/vendor/v8/src/prettyprinter.h +2 -0
  265. data/vendor/v8/src/profile-generator-inl.h +1 -0
  266. data/vendor/v8/src/profile-generator.cc +209 -147
  267. data/vendor/v8/src/profile-generator.h +15 -12
  268. data/vendor/v8/src/property-details.h +46 -31
  269. data/vendor/v8/src/property.cc +27 -46
  270. data/vendor/v8/src/property.h +163 -83
  271. data/vendor/v8/src/proxy.js +7 -2
  272. data/vendor/v8/src/regexp-macro-assembler-irregexp.cc +4 -13
  273. data/vendor/v8/src/regexp-macro-assembler-irregexp.h +1 -2
  274. data/vendor/v8/src/regexp-macro-assembler-tracer.cc +1 -11
  275. data/vendor/v8/src/regexp-macro-assembler-tracer.h +0 -1
  276. data/vendor/v8/src/regexp-macro-assembler.cc +31 -14
  277. data/vendor/v8/src/regexp-macro-assembler.h +14 -11
  278. data/vendor/v8/src/regexp-stack.cc +1 -0
  279. data/vendor/v8/src/regexp.js +9 -8
  280. data/vendor/v8/src/rewriter.cc +18 -7
  281. data/vendor/v8/src/runtime-profiler.cc +52 -43
  282. data/vendor/v8/src/runtime-profiler.h +0 -25
  283. data/vendor/v8/src/runtime.cc +2006 -2023
  284. data/vendor/v8/src/runtime.h +56 -49
  285. data/vendor/v8/src/safepoint-table.cc +12 -18
  286. data/vendor/v8/src/safepoint-table.h +11 -8
  287. data/vendor/v8/src/scanner.cc +1 -0
  288. data/vendor/v8/src/scanner.h +4 -10
  289. data/vendor/v8/src/scopeinfo.cc +35 -9
  290. data/vendor/v8/src/scopeinfo.h +64 -3
  291. data/vendor/v8/src/scopes.cc +251 -156
  292. data/vendor/v8/src/scopes.h +61 -27
  293. data/vendor/v8/src/serialize.cc +348 -396
  294. data/vendor/v8/src/serialize.h +125 -114
  295. data/vendor/v8/src/small-pointer-list.h +11 -11
  296. data/vendor/v8/src/{smart-array-pointer.h → smart-pointers.h} +64 -15
  297. data/vendor/v8/src/snapshot-common.cc +64 -15
  298. data/vendor/v8/src/snapshot-empty.cc +7 -1
  299. data/vendor/v8/src/snapshot.h +9 -2
  300. data/vendor/v8/src/spaces-inl.h +17 -0
  301. data/vendor/v8/src/spaces.cc +477 -183
  302. data/vendor/v8/src/spaces.h +238 -58
  303. data/vendor/v8/src/splay-tree-inl.h +8 -7
  304. data/vendor/v8/src/splay-tree.h +24 -10
  305. data/vendor/v8/src/store-buffer.cc +12 -5
  306. data/vendor/v8/src/store-buffer.h +2 -4
  307. data/vendor/v8/src/string-search.h +22 -6
  308. data/vendor/v8/src/string-stream.cc +11 -8
  309. data/vendor/v8/src/string.js +47 -15
  310. data/vendor/v8/src/stub-cache.cc +461 -224
  311. data/vendor/v8/src/stub-cache.h +164 -102
  312. data/vendor/v8/src/sweeper-thread.cc +105 -0
  313. data/vendor/v8/src/sweeper-thread.h +81 -0
  314. data/vendor/v8/src/token.h +1 -0
  315. data/vendor/v8/src/transitions-inl.h +220 -0
  316. data/vendor/v8/src/transitions.cc +160 -0
  317. data/vendor/v8/src/transitions.h +207 -0
  318. data/vendor/v8/src/type-info.cc +182 -181
  319. data/vendor/v8/src/type-info.h +31 -19
  320. data/vendor/v8/src/unicode-inl.h +62 -106
  321. data/vendor/v8/src/unicode.cc +57 -67
  322. data/vendor/v8/src/unicode.h +45 -91
  323. data/vendor/v8/src/uri.js +57 -29
  324. data/vendor/v8/src/utils.h +105 -5
  325. data/vendor/v8/src/v8-counters.cc +54 -11
  326. data/vendor/v8/src/v8-counters.h +134 -19
  327. data/vendor/v8/src/v8.cc +29 -29
  328. data/vendor/v8/src/v8.h +1 -0
  329. data/vendor/v8/src/v8conversions.cc +26 -22
  330. data/vendor/v8/src/v8globals.h +56 -43
  331. data/vendor/v8/src/v8natives.js +83 -30
  332. data/vendor/v8/src/v8threads.cc +42 -21
  333. data/vendor/v8/src/v8threads.h +4 -1
  334. data/vendor/v8/src/v8utils.cc +9 -93
  335. data/vendor/v8/src/v8utils.h +37 -33
  336. data/vendor/v8/src/variables.cc +6 -3
  337. data/vendor/v8/src/variables.h +6 -13
  338. data/vendor/v8/src/version.cc +2 -2
  339. data/vendor/v8/src/vm-state-inl.h +11 -0
  340. data/vendor/v8/src/x64/assembler-x64-inl.h +39 -8
  341. data/vendor/v8/src/x64/assembler-x64.cc +78 -64
  342. data/vendor/v8/src/x64/assembler-x64.h +38 -33
  343. data/vendor/v8/src/x64/builtins-x64.cc +105 -7
  344. data/vendor/v8/src/x64/code-stubs-x64.cc +790 -413
  345. data/vendor/v8/src/x64/code-stubs-x64.h +10 -106
  346. data/vendor/v8/src/x64/codegen-x64.cc +210 -8
  347. data/vendor/v8/src/x64/codegen-x64.h +20 -1
  348. data/vendor/v8/src/x64/deoptimizer-x64.cc +336 -75
  349. data/vendor/v8/src/x64/disasm-x64.cc +15 -0
  350. data/vendor/v8/src/x64/frames-x64.h +0 -14
  351. data/vendor/v8/src/x64/full-codegen-x64.cc +293 -270
  352. data/vendor/v8/src/x64/ic-x64.cc +153 -251
  353. data/vendor/v8/src/x64/lithium-codegen-x64.cc +1379 -531
  354. data/vendor/v8/src/x64/lithium-codegen-x64.h +67 -23
  355. data/vendor/v8/src/x64/lithium-gap-resolver-x64.cc +2 -2
  356. data/vendor/v8/src/x64/lithium-x64.cc +349 -289
  357. data/vendor/v8/src/x64/lithium-x64.h +460 -250
  358. data/vendor/v8/src/x64/macro-assembler-x64.cc +350 -177
  359. data/vendor/v8/src/x64/macro-assembler-x64.h +67 -49
  360. data/vendor/v8/src/x64/regexp-macro-assembler-x64.cc +46 -33
  361. data/vendor/v8/src/x64/regexp-macro-assembler-x64.h +2 -3
  362. data/vendor/v8/src/x64/stub-cache-x64.cc +484 -653
  363. data/vendor/v8/src/zone-inl.h +9 -27
  364. data/vendor/v8/src/zone.cc +5 -5
  365. data/vendor/v8/src/zone.h +53 -27
  366. data/vendor/v8/test/benchmarks/testcfg.py +5 -0
  367. data/vendor/v8/test/cctest/cctest.cc +4 -0
  368. data/vendor/v8/test/cctest/cctest.gyp +3 -1
  369. data/vendor/v8/test/cctest/cctest.h +57 -9
  370. data/vendor/v8/test/cctest/cctest.status +15 -15
  371. data/vendor/v8/test/cctest/test-accessors.cc +26 -0
  372. data/vendor/v8/test/cctest/test-alloc.cc +22 -30
  373. data/vendor/v8/test/cctest/test-api.cc +1943 -314
  374. data/vendor/v8/test/cctest/test-assembler-arm.cc +133 -13
  375. data/vendor/v8/test/cctest/test-assembler-ia32.cc +1 -1
  376. data/vendor/v8/test/cctest/test-assembler-mips.cc +12 -0
  377. data/vendor/v8/test/cctest/test-ast.cc +4 -2
  378. data/vendor/v8/test/cctest/test-compiler.cc +61 -29
  379. data/vendor/v8/test/cctest/test-dataflow.cc +2 -2
  380. data/vendor/v8/test/cctest/test-debug.cc +212 -33
  381. data/vendor/v8/test/cctest/test-decls.cc +257 -11
  382. data/vendor/v8/test/cctest/test-dictionary.cc +24 -10
  383. data/vendor/v8/test/cctest/test-disasm-arm.cc +118 -1
  384. data/vendor/v8/test/cctest/test-disasm-ia32.cc +3 -2
  385. data/vendor/v8/test/cctest/test-flags.cc +14 -1
  386. data/vendor/v8/test/cctest/test-func-name-inference.cc +7 -4
  387. data/vendor/v8/test/cctest/test-global-object.cc +51 -0
  388. data/vendor/v8/test/cctest/test-hashing.cc +32 -23
  389. data/vendor/v8/test/cctest/test-heap-profiler.cc +131 -77
  390. data/vendor/v8/test/cctest/test-heap.cc +1084 -143
  391. data/vendor/v8/test/cctest/test-list.cc +1 -1
  392. data/vendor/v8/test/cctest/test-liveedit.cc +3 -2
  393. data/vendor/v8/test/cctest/test-lockers.cc +12 -13
  394. data/vendor/v8/test/cctest/test-log.cc +10 -8
  395. data/vendor/v8/test/cctest/test-macro-assembler-x64.cc +2 -2
  396. data/vendor/v8/test/cctest/test-mark-compact.cc +44 -22
  397. data/vendor/v8/test/cctest/test-object-observe.cc +434 -0
  398. data/vendor/v8/test/cctest/test-parsing.cc +86 -39
  399. data/vendor/v8/test/cctest/test-platform-linux.cc +6 -0
  400. data/vendor/v8/test/cctest/test-platform-win32.cc +7 -0
  401. data/vendor/v8/test/cctest/test-random.cc +5 -4
  402. data/vendor/v8/test/cctest/test-regexp.cc +137 -101
  403. data/vendor/v8/test/cctest/test-serialize.cc +150 -230
  404. data/vendor/v8/test/cctest/test-sockets.cc +1 -1
  405. data/vendor/v8/test/cctest/test-spaces.cc +139 -0
  406. data/vendor/v8/test/cctest/test-strings.cc +736 -74
  407. data/vendor/v8/test/cctest/test-thread-termination.cc +10 -11
  408. data/vendor/v8/test/cctest/test-threads.cc +4 -4
  409. data/vendor/v8/test/cctest/test-utils.cc +16 -0
  410. data/vendor/v8/test/cctest/test-weakmaps.cc +7 -3
  411. data/vendor/v8/test/cctest/testcfg.py +64 -5
  412. data/vendor/v8/test/es5conform/testcfg.py +5 -0
  413. data/vendor/v8/test/message/message.status +1 -1
  414. data/vendor/v8/test/message/overwritten-builtins.out +3 -0
  415. data/vendor/v8/test/message/testcfg.py +89 -8
  416. data/vendor/v8/test/message/try-catch-finally-no-message.out +26 -26
  417. data/vendor/v8/test/mjsunit/accessor-map-sharing.js +18 -2
  418. data/vendor/v8/test/mjsunit/allocation-site-info.js +126 -0
  419. data/vendor/v8/test/mjsunit/array-bounds-check-removal.js +62 -1
  420. data/vendor/v8/test/mjsunit/array-iteration.js +1 -1
  421. data/vendor/v8/test/mjsunit/array-literal-transitions.js +2 -0
  422. data/vendor/v8/test/mjsunit/array-natives-elements.js +317 -0
  423. data/vendor/v8/test/mjsunit/array-reduce.js +8 -8
  424. data/vendor/v8/test/mjsunit/array-slice.js +12 -0
  425. data/vendor/v8/test/mjsunit/array-store-and-grow.js +4 -1
  426. data/vendor/v8/test/mjsunit/assert-opt-and-deopt.js +1 -1
  427. data/vendor/v8/test/mjsunit/bugs/bug-2337.js +53 -0
  428. data/vendor/v8/test/mjsunit/compare-known-objects-slow.js +69 -0
  429. data/vendor/v8/test/mjsunit/compiler/alloc-object-huge.js +3 -1
  430. data/vendor/v8/test/mjsunit/compiler/inline-accessors.js +368 -0
  431. data/vendor/v8/test/mjsunit/compiler/inline-arguments.js +87 -1
  432. data/vendor/v8/test/mjsunit/compiler/inline-closures.js +49 -0
  433. data/vendor/v8/test/mjsunit/compiler/inline-construct.js +55 -43
  434. data/vendor/v8/test/mjsunit/compiler/inline-literals.js +39 -0
  435. data/vendor/v8/test/mjsunit/compiler/multiply-add.js +69 -0
  436. data/vendor/v8/test/mjsunit/compiler/optimized-closures.js +57 -0
  437. data/vendor/v8/test/mjsunit/compiler/parallel-proto-change.js +44 -0
  438. data/vendor/v8/test/mjsunit/compiler/property-static.js +69 -0
  439. data/vendor/v8/test/mjsunit/compiler/proto-chain-constant.js +55 -0
  440. data/vendor/v8/test/mjsunit/compiler/proto-chain-load.js +44 -0
  441. data/vendor/v8/test/mjsunit/compiler/regress-gvn.js +3 -2
  442. data/vendor/v8/test/mjsunit/compiler/regress-or.js +6 -2
  443. data/vendor/v8/test/mjsunit/compiler/rotate.js +224 -0
  444. data/vendor/v8/test/mjsunit/compiler/uint32.js +173 -0
  445. data/vendor/v8/test/mjsunit/count-based-osr.js +2 -1
  446. data/vendor/v8/test/mjsunit/d8-os.js +3 -3
  447. data/vendor/v8/test/mjsunit/date-parse.js +3 -0
  448. data/vendor/v8/test/mjsunit/date.js +22 -0
  449. data/vendor/v8/test/mjsunit/debug-break-inline.js +1 -0
  450. data/vendor/v8/test/mjsunit/debug-evaluate-locals-optimized-double.js +22 -12
  451. data/vendor/v8/test/mjsunit/debug-evaluate-locals-optimized.js +21 -10
  452. data/vendor/v8/test/mjsunit/debug-liveedit-compile-error.js +60 -0
  453. data/vendor/v8/test/mjsunit/debug-liveedit-double-call.js +142 -0
  454. data/vendor/v8/test/mjsunit/debug-liveedit-literals.js +94 -0
  455. data/vendor/v8/test/mjsunit/debug-liveedit-restart-frame.js +153 -0
  456. data/vendor/v8/test/mjsunit/debug-multiple-breakpoints.js +1 -1
  457. data/vendor/v8/test/mjsunit/debug-script-breakpoints-closure.js +67 -0
  458. data/vendor/v8/test/mjsunit/debug-script-breakpoints-nested.js +82 -0
  459. data/vendor/v8/test/mjsunit/debug-script.js +4 -2
  460. data/vendor/v8/test/mjsunit/debug-set-variable-value.js +308 -0
  461. data/vendor/v8/test/mjsunit/debug-stepout-scope-part1.js +190 -0
  462. data/vendor/v8/test/mjsunit/debug-stepout-scope-part2.js +83 -0
  463. data/vendor/v8/test/mjsunit/debug-stepout-scope-part3.js +80 -0
  464. data/vendor/v8/test/mjsunit/debug-stepout-scope-part4.js +80 -0
  465. data/vendor/v8/test/mjsunit/debug-stepout-scope-part5.js +77 -0
  466. data/vendor/v8/test/mjsunit/debug-stepout-scope-part6.js +79 -0
  467. data/vendor/v8/test/mjsunit/debug-stepout-scope-part7.js +79 -0
  468. data/vendor/v8/test/mjsunit/{debug-stepout-scope.js → debug-stepout-scope-part8.js} +0 -189
  469. data/vendor/v8/test/mjsunit/delete-non-configurable.js +74 -0
  470. data/vendor/v8/test/mjsunit/deopt-minus-zero.js +56 -0
  471. data/vendor/v8/test/mjsunit/elements-kind.js +6 -4
  472. data/vendor/v8/test/mjsunit/elements-length-no-holey.js +33 -0
  473. data/vendor/v8/test/mjsunit/elements-transition-hoisting.js +46 -19
  474. data/vendor/v8/test/mjsunit/error-accessors.js +54 -0
  475. data/vendor/v8/test/mjsunit/error-constructors.js +1 -14
  476. data/vendor/v8/test/mjsunit/error-tostring.js +8 -0
  477. data/vendor/v8/test/mjsunit/eval-stack-trace.js +204 -0
  478. data/vendor/v8/test/mjsunit/external-array.js +364 -1
  479. data/vendor/v8/test/mjsunit/fast-array-length.js +37 -0
  480. data/vendor/v8/test/mjsunit/fast-non-keyed.js +113 -0
  481. data/vendor/v8/test/mjsunit/fast-prototype.js +117 -0
  482. data/vendor/v8/test/mjsunit/function-call.js +14 -18
  483. data/vendor/v8/test/mjsunit/fuzz-natives-part1.js +230 -0
  484. data/vendor/v8/test/mjsunit/fuzz-natives-part2.js +229 -0
  485. data/vendor/v8/test/mjsunit/fuzz-natives-part3.js +229 -0
  486. data/vendor/v8/test/mjsunit/{fuzz-natives.js → fuzz-natives-part4.js} +12 -2
  487. data/vendor/v8/test/mjsunit/generated-transition-stub.js +218 -0
  488. data/vendor/v8/test/mjsunit/greedy.js +1 -1
  489. data/vendor/v8/test/mjsunit/harmony/block-conflicts.js +2 -1
  490. data/vendor/v8/test/mjsunit/harmony/block-let-crankshaft.js +1 -1
  491. data/vendor/v8/test/mjsunit/harmony/collections.js +69 -11
  492. data/vendor/v8/test/mjsunit/harmony/debug-blockscopes.js +2 -2
  493. data/vendor/v8/test/mjsunit/harmony/module-linking.js +180 -3
  494. data/vendor/v8/test/mjsunit/harmony/module-parsing.js +31 -0
  495. data/vendor/v8/test/mjsunit/harmony/module-recompile.js +87 -0
  496. data/vendor/v8/test/mjsunit/harmony/module-resolution.js +15 -2
  497. data/vendor/v8/test/mjsunit/harmony/object-observe.js +1056 -0
  498. data/vendor/v8/test/mjsunit/harmony/proxies-json.js +178 -0
  499. data/vendor/v8/test/mjsunit/harmony/proxies.js +25 -10
  500. data/vendor/v8/test/mjsunit/json-parser-recursive.js +33 -0
  501. data/vendor/v8/test/mjsunit/json-stringify-recursive.js +52 -0
  502. data/vendor/v8/test/mjsunit/json.js +38 -2
  503. data/vendor/v8/test/mjsunit/json2.js +153 -0
  504. data/vendor/v8/test/mjsunit/limit-locals.js +5 -4
  505. data/vendor/v8/test/mjsunit/manual-parallel-recompile.js +79 -0
  506. data/vendor/v8/test/mjsunit/math-exp-precision.js +64 -0
  507. data/vendor/v8/test/mjsunit/math-floor-negative.js +59 -0
  508. data/vendor/v8/test/mjsunit/math-floor-of-div-minus-zero.js +41 -0
  509. data/vendor/v8/test/mjsunit/math-floor-of-div-nosudiv.js +288 -0
  510. data/vendor/v8/test/mjsunit/math-floor-of-div.js +81 -9
  511. data/vendor/v8/test/mjsunit/{math-floor.js → math-floor-part1.js} +1 -72
  512. data/vendor/v8/test/mjsunit/math-floor-part2.js +76 -0
  513. data/vendor/v8/test/mjsunit/math-floor-part3.js +78 -0
  514. data/vendor/v8/test/mjsunit/math-floor-part4.js +76 -0
  515. data/vendor/v8/test/mjsunit/mirror-object.js +43 -9
  516. data/vendor/v8/test/mjsunit/mjsunit.js +1 -1
  517. data/vendor/v8/test/mjsunit/mjsunit.status +52 -27
  518. data/vendor/v8/test/mjsunit/mul-exhaustive-part1.js +491 -0
  519. data/vendor/v8/test/mjsunit/mul-exhaustive-part10.js +470 -0
  520. data/vendor/v8/test/mjsunit/mul-exhaustive-part2.js +525 -0
  521. data/vendor/v8/test/mjsunit/mul-exhaustive-part3.js +532 -0
  522. data/vendor/v8/test/mjsunit/mul-exhaustive-part4.js +509 -0
  523. data/vendor/v8/test/mjsunit/mul-exhaustive-part5.js +505 -0
  524. data/vendor/v8/test/mjsunit/mul-exhaustive-part6.js +554 -0
  525. data/vendor/v8/test/mjsunit/mul-exhaustive-part7.js +497 -0
  526. data/vendor/v8/test/mjsunit/mul-exhaustive-part8.js +526 -0
  527. data/vendor/v8/test/mjsunit/mul-exhaustive-part9.js +533 -0
  528. data/vendor/v8/test/mjsunit/new-function.js +34 -0
  529. data/vendor/v8/test/mjsunit/numops-fuzz-part1.js +1172 -0
  530. data/vendor/v8/test/mjsunit/numops-fuzz-part2.js +1178 -0
  531. data/vendor/v8/test/mjsunit/numops-fuzz-part3.js +1178 -0
  532. data/vendor/v8/test/mjsunit/numops-fuzz-part4.js +1177 -0
  533. data/vendor/v8/test/mjsunit/object-define-property.js +107 -2
  534. data/vendor/v8/test/mjsunit/override-read-only-property.js +6 -4
  535. data/vendor/v8/test/mjsunit/packed-elements.js +2 -2
  536. data/vendor/v8/test/mjsunit/parse-int-float.js +4 -4
  537. data/vendor/v8/test/mjsunit/pixel-array-rounding.js +1 -1
  538. data/vendor/v8/test/mjsunit/readonly.js +228 -0
  539. data/vendor/v8/test/mjsunit/regexp-capture-3.js +16 -18
  540. data/vendor/v8/test/mjsunit/regexp-capture.js +2 -0
  541. data/vendor/v8/test/mjsunit/regexp-global.js +122 -0
  542. data/vendor/v8/test/mjsunit/regexp-results-cache.js +78 -0
  543. data/vendor/v8/test/mjsunit/regress/regress-1117.js +12 -3
  544. data/vendor/v8/test/mjsunit/regress/regress-1118.js +1 -1
  545. data/vendor/v8/test/mjsunit/regress/regress-115100.js +36 -0
  546. data/vendor/v8/test/mjsunit/regress/regress-1199637.js +1 -3
  547. data/vendor/v8/test/mjsunit/regress/regress-121407.js +1 -1
  548. data/vendor/v8/test/mjsunit/regress/regress-131923.js +30 -0
  549. data/vendor/v8/test/mjsunit/regress/regress-131994.js +70 -0
  550. data/vendor/v8/test/mjsunit/regress/regress-133211.js +35 -0
  551. data/vendor/v8/test/mjsunit/regress/regress-133211b.js +39 -0
  552. data/vendor/v8/test/mjsunit/regress/regress-136048.js +34 -0
  553. data/vendor/v8/test/mjsunit/regress/regress-137768.js +73 -0
  554. data/vendor/v8/test/mjsunit/regress/regress-143967.js +34 -0
  555. data/vendor/v8/test/mjsunit/regress/regress-145201.js +107 -0
  556. data/vendor/v8/test/mjsunit/regress/regress-147497.js +45 -0
  557. data/vendor/v8/test/mjsunit/regress/regress-148378.js +38 -0
  558. data/vendor/v8/test/mjsunit/regress/regress-1563.js +1 -1
  559. data/vendor/v8/test/mjsunit/regress/regress-1591.js +48 -0
  560. data/vendor/v8/test/mjsunit/regress/regress-164442.js +45 -0
  561. data/vendor/v8/test/mjsunit/regress/regress-165637.js +61 -0
  562. data/vendor/v8/test/mjsunit/regress/regress-166379.js +39 -0
  563. data/vendor/v8/test/mjsunit/regress/regress-166553.js +33 -0
  564. data/vendor/v8/test/mjsunit/regress/regress-1692.js +1 -1
  565. data/vendor/v8/test/mjsunit/regress/regress-171641.js +40 -0
  566. data/vendor/v8/test/mjsunit/regress/regress-1980.js +1 -1
  567. data/vendor/v8/test/mjsunit/regress/regress-2073.js +99 -0
  568. data/vendor/v8/test/mjsunit/regress/regress-2119.js +36 -0
  569. data/vendor/v8/test/mjsunit/regress/regress-2156.js +39 -0
  570. data/vendor/v8/test/mjsunit/regress/regress-2163.js +70 -0
  571. data/vendor/v8/test/mjsunit/regress/regress-2170.js +58 -0
  572. data/vendor/v8/test/mjsunit/regress/regress-2172.js +35 -0
  573. data/vendor/v8/test/mjsunit/regress/regress-2185-2.js +145 -0
  574. data/vendor/v8/test/mjsunit/regress/regress-2185.js +38 -0
  575. data/vendor/v8/test/mjsunit/regress/regress-2186.js +49 -0
  576. data/vendor/v8/test/mjsunit/regress/regress-2193.js +58 -0
  577. data/vendor/v8/test/mjsunit/regress/regress-2219.js +32 -0
  578. data/vendor/v8/test/mjsunit/regress/regress-2225.js +65 -0
  579. data/vendor/v8/test/mjsunit/regress/regress-2226.js +36 -0
  580. data/vendor/v8/test/mjsunit/regress/regress-2234.js +41 -0
  581. data/vendor/v8/test/mjsunit/regress/regress-2243.js +31 -0
  582. data/vendor/v8/test/mjsunit/regress/regress-2249.js +33 -0
  583. data/vendor/v8/test/mjsunit/regress/regress-2250.js +68 -0
  584. data/vendor/v8/test/mjsunit/regress/regress-2261.js +113 -0
  585. data/vendor/v8/test/mjsunit/regress/regress-2263.js +30 -0
  586. data/vendor/v8/test/mjsunit/regress/regress-2284.js +32 -0
  587. data/vendor/v8/test/mjsunit/regress/regress-2285.js +32 -0
  588. data/vendor/v8/test/mjsunit/regress/regress-2286.js +32 -0
  589. data/vendor/v8/test/mjsunit/regress/regress-2289.js +34 -0
  590. data/vendor/v8/test/mjsunit/regress/regress-2291.js +36 -0
  591. data/vendor/v8/test/mjsunit/regress/regress-2294.js +70 -0
  592. data/vendor/v8/test/mjsunit/regress/regress-2296.js +40 -0
  593. data/vendor/v8/test/mjsunit/regress/regress-2315.js +40 -0
  594. data/vendor/v8/test/mjsunit/regress/regress-2318.js +66 -0
  595. data/vendor/v8/test/mjsunit/regress/regress-2322.js +36 -0
  596. data/vendor/v8/test/mjsunit/regress/regress-2326.js +54 -0
  597. data/vendor/v8/test/mjsunit/regress/regress-2336.js +53 -0
  598. data/vendor/v8/test/mjsunit/regress/regress-2339.js +59 -0
  599. data/vendor/v8/test/mjsunit/regress/regress-2346.js +123 -0
  600. data/vendor/v8/test/mjsunit/regress/regress-2373.js +29 -0
  601. data/vendor/v8/test/mjsunit/regress/regress-2374.js +33 -0
  602. data/vendor/v8/test/mjsunit/regress/regress-2398.js +41 -0
  603. data/vendor/v8/test/mjsunit/regress/regress-2410.js +36 -0
  604. data/vendor/v8/test/mjsunit/regress/regress-2416.js +75 -0
  605. data/vendor/v8/test/mjsunit/regress/regress-2419.js +37 -0
  606. data/vendor/v8/test/mjsunit/regress/regress-2433.js +36 -0
  607. data/vendor/v8/test/mjsunit/regress/regress-2437.js +156 -0
  608. data/vendor/v8/test/mjsunit/regress/regress-2438.js +52 -0
  609. data/vendor/v8/test/mjsunit/regress/regress-2443.js +129 -0
  610. data/vendor/v8/test/mjsunit/regress/regress-2444.js +120 -0
  611. data/vendor/v8/test/mjsunit/regress/regress-2489.js +50 -0
  612. data/vendor/v8/test/mjsunit/regress/regress-2499.js +40 -0
  613. data/vendor/v8/test/mjsunit/regress/regress-334.js +1 -1
  614. data/vendor/v8/test/mjsunit/regress/regress-492.js +39 -1
  615. data/vendor/v8/test/mjsunit/regress/regress-builtin-array-op.js +38 -0
  616. data/vendor/v8/test/mjsunit/regress/regress-cnlt-elements.js +43 -0
  617. data/vendor/v8/test/mjsunit/regress/regress-cnlt-enum-indices.js +45 -0
  618. data/vendor/v8/test/mjsunit/regress/regress-cntl-descriptors-enum.js +46 -0
  619. data/vendor/v8/test/mjsunit/regress/regress-convert-enum.js +60 -0
  620. data/vendor/v8/test/mjsunit/regress/regress-convert-enum2.js +46 -0
  621. data/vendor/v8/test/mjsunit/regress/regress-convert-transition.js +40 -0
  622. data/vendor/v8/test/mjsunit/regress/regress-crbug-119926.js +3 -1
  623. data/vendor/v8/test/mjsunit/regress/regress-crbug-125148.js +90 -0
  624. data/vendor/v8/test/mjsunit/regress/regress-crbug-134055.js +63 -0
  625. data/vendor/v8/test/mjsunit/regress/regress-crbug-134609.js +59 -0
  626. data/vendor/v8/test/mjsunit/regress/regress-crbug-135008.js +45 -0
  627. data/vendor/v8/test/mjsunit/regress/regress-crbug-135066.js +55 -0
  628. data/vendor/v8/test/mjsunit/regress/regress-crbug-137689.js +47 -0
  629. data/vendor/v8/test/mjsunit/regress/regress-crbug-138887.js +48 -0
  630. data/vendor/v8/test/mjsunit/regress/regress-crbug-140083.js +44 -0
  631. data/vendor/v8/test/mjsunit/regress/regress-crbug-142087.js +38 -0
  632. data/vendor/v8/test/mjsunit/regress/regress-crbug-142218.js +44 -0
  633. data/vendor/v8/test/mjsunit/regress/regress-crbug-145961.js +39 -0
  634. data/vendor/v8/test/mjsunit/regress/regress-crbug-146910.js +33 -0
  635. data/vendor/v8/test/mjsunit/regress/regress-crbug-147475.js +48 -0
  636. data/vendor/v8/test/mjsunit/regress/regress-crbug-148376.js +35 -0
  637. data/vendor/v8/test/mjsunit/regress/regress-crbug-150545.js +53 -0
  638. data/vendor/v8/test/mjsunit/regress/regress-crbug-150729.js +39 -0
  639. data/vendor/v8/test/mjsunit/regress/regress-crbug-157019.js +54 -0
  640. data/vendor/v8/test/mjsunit/regress/regress-crbug-157520.js +38 -0
  641. data/vendor/v8/test/mjsunit/regress/regress-crbug-158185.js +39 -0
  642. data/vendor/v8/test/mjsunit/regress/regress-crbug-160010.js +35 -0
  643. data/vendor/v8/test/mjsunit/regress/regress-crbug-162085.js +71 -0
  644. data/vendor/v8/test/mjsunit/regress/regress-crbug-168545.js +34 -0
  645. data/vendor/v8/test/mjsunit/regress/regress-crbug-170856.js +33 -0
  646. data/vendor/v8/test/mjsunit/regress/regress-crbug-172345.js +34 -0
  647. data/vendor/v8/test/mjsunit/regress/regress-crbug-173974.js +36 -0
  648. data/vendor/v8/test/mjsunit/regress/regress-crbug-18639.js +9 -5
  649. data/vendor/v8/test/mjsunit/regress/regress-debug-code-recompilation.js +2 -1
  650. data/vendor/v8/test/mjsunit/regress/regress-deep-proto.js +45 -0
  651. data/vendor/v8/test/mjsunit/regress/regress-delete-empty-double.js +40 -0
  652. data/vendor/v8/test/mjsunit/regress/regress-iteration-order.js +42 -0
  653. data/vendor/v8/test/mjsunit/regress/regress-json-stringify-gc.js +41 -0
  654. data/vendor/v8/test/mjsunit/regress/regress-latin-1.js +78 -0
  655. data/vendor/v8/test/mjsunit/regress/regress-load-elements.js +49 -0
  656. data/vendor/v8/test/mjsunit/regress/regress-observe-empty-double-array.js +38 -0
  657. data/vendor/v8/test/mjsunit/regress/regress-undefined-store-keyed-fast-element.js +37 -0
  658. data/vendor/v8/test/mjsunit/shift-for-integer-div.js +59 -0
  659. data/vendor/v8/test/mjsunit/stack-traces-gc.js +119 -0
  660. data/vendor/v8/test/mjsunit/stack-traces-overflow.js +122 -0
  661. data/vendor/v8/test/mjsunit/stack-traces.js +39 -1
  662. data/vendor/v8/test/mjsunit/str-to-num.js +7 -2
  663. data/vendor/v8/test/mjsunit/strict-mode.js +36 -11
  664. data/vendor/v8/test/mjsunit/string-charcodeat.js +3 -0
  665. data/vendor/v8/test/mjsunit/string-natives.js +72 -0
  666. data/vendor/v8/test/mjsunit/string-split.js +17 -0
  667. data/vendor/v8/test/mjsunit/testcfg.py +76 -6
  668. data/vendor/v8/test/mjsunit/tools/tickprocessor.js +4 -1
  669. data/vendor/v8/test/mjsunit/try-finally-continue.js +72 -0
  670. data/vendor/v8/test/mjsunit/typed-array-slice.js +61 -0
  671. data/vendor/v8/test/mjsunit/unbox-double-arrays.js +2 -0
  672. data/vendor/v8/test/mjsunit/uri.js +12 -0
  673. data/vendor/v8/test/mjsunit/with-readonly.js +4 -2
  674. data/vendor/v8/test/mozilla/mozilla.status +19 -113
  675. data/vendor/v8/test/mozilla/testcfg.py +122 -3
  676. data/vendor/v8/test/preparser/preparser.status +5 -0
  677. data/vendor/v8/test/preparser/strict-identifiers.pyt +1 -1
  678. data/vendor/v8/test/preparser/testcfg.py +101 -5
  679. data/vendor/v8/test/sputnik/sputnik.status +1 -1
  680. data/vendor/v8/test/sputnik/testcfg.py +5 -0
  681. data/vendor/v8/test/test262/README +2 -2
  682. data/vendor/v8/test/test262/test262.status +13 -36
  683. data/vendor/v8/test/test262/testcfg.py +102 -8
  684. data/vendor/v8/tools/android-build.sh +0 -0
  685. data/vendor/v8/tools/android-ll-prof.sh +69 -0
  686. data/vendor/v8/tools/android-run.py +109 -0
  687. data/vendor/v8/tools/android-sync.sh +105 -0
  688. data/vendor/v8/tools/bash-completion.sh +0 -0
  689. data/vendor/v8/tools/check-static-initializers.sh +0 -0
  690. data/vendor/v8/tools/common-includes.sh +15 -22
  691. data/vendor/v8/tools/disasm.py +4 -4
  692. data/vendor/v8/tools/fuzz-harness.sh +0 -0
  693. data/vendor/v8/tools/gen-postmortem-metadata.py +6 -8
  694. data/vendor/v8/tools/grokdump.py +404 -129
  695. data/vendor/v8/tools/gyp/v8.gyp +105 -43
  696. data/vendor/v8/tools/linux-tick-processor +5 -5
  697. data/vendor/v8/tools/ll_prof.py +75 -15
  698. data/vendor/v8/tools/merge-to-branch.sh +2 -2
  699. data/vendor/v8/tools/plot-timer-events +70 -0
  700. data/vendor/v8/tools/plot-timer-events.js +510 -0
  701. data/vendor/v8/tools/presubmit.py +1 -0
  702. data/vendor/v8/tools/push-to-trunk.sh +14 -4
  703. data/vendor/v8/tools/run-llprof.sh +69 -0
  704. data/vendor/v8/tools/run-tests.py +372 -0
  705. data/vendor/v8/tools/run-valgrind.py +1 -1
  706. data/vendor/v8/tools/status-file-converter.py +39 -0
  707. data/vendor/v8/tools/test-server.py +224 -0
  708. data/vendor/v8/tools/test-wrapper-gypbuild.py +13 -16
  709. data/vendor/v8/tools/test.py +10 -19
  710. data/vendor/v8/tools/testrunner/README +174 -0
  711. data/vendor/v8/tools/testrunner/__init__.py +26 -0
  712. data/vendor/v8/tools/testrunner/local/__init__.py +26 -0
  713. data/vendor/v8/tools/testrunner/local/commands.py +153 -0
  714. data/vendor/v8/tools/testrunner/local/execution.py +182 -0
  715. data/vendor/v8/tools/testrunner/local/old_statusfile.py +460 -0
  716. data/vendor/v8/tools/testrunner/local/progress.py +238 -0
  717. data/vendor/v8/tools/testrunner/local/statusfile.py +145 -0
  718. data/vendor/v8/tools/testrunner/local/testsuite.py +187 -0
  719. data/vendor/v8/tools/testrunner/local/utils.py +108 -0
  720. data/vendor/v8/tools/testrunner/local/verbose.py +99 -0
  721. data/vendor/v8/tools/testrunner/network/__init__.py +26 -0
  722. data/vendor/v8/tools/testrunner/network/distro.py +90 -0
  723. data/vendor/v8/tools/testrunner/network/endpoint.py +124 -0
  724. data/vendor/v8/tools/testrunner/network/network_execution.py +253 -0
  725. data/vendor/v8/tools/testrunner/network/perfdata.py +120 -0
  726. data/vendor/v8/tools/testrunner/objects/__init__.py +26 -0
  727. data/vendor/v8/tools/testrunner/objects/context.py +50 -0
  728. data/vendor/v8/tools/testrunner/objects/output.py +60 -0
  729. data/vendor/v8/tools/testrunner/objects/peer.py +80 -0
  730. data/vendor/v8/tools/testrunner/objects/testcase.py +83 -0
  731. data/vendor/v8/tools/testrunner/objects/workpacket.py +90 -0
  732. data/vendor/v8/tools/testrunner/server/__init__.py +26 -0
  733. data/vendor/v8/tools/testrunner/server/compression.py +111 -0
  734. data/vendor/v8/tools/testrunner/server/constants.py +51 -0
  735. data/vendor/v8/tools/testrunner/server/daemon.py +147 -0
  736. data/vendor/v8/tools/testrunner/server/local_handler.py +119 -0
  737. data/vendor/v8/tools/testrunner/server/main.py +245 -0
  738. data/vendor/v8/tools/testrunner/server/presence_handler.py +120 -0
  739. data/vendor/v8/tools/testrunner/server/signatures.py +63 -0
  740. data/vendor/v8/tools/testrunner/server/status_handler.py +112 -0
  741. data/vendor/v8/tools/testrunner/server/work_handler.py +150 -0
  742. data/vendor/v8/tools/tick-processor.html +168 -0
  743. data/vendor/v8/tools/tickprocessor-driver.js +5 -3
  744. data/vendor/v8/tools/tickprocessor.js +58 -15
  745. metadata +534 -30
  746. data/patches/add-freebsd9-and-freebsd10-to-gyp-GetFlavor.patch +0 -11
  747. data/patches/do-not-imply-vfp3-and-armv7.patch +0 -44
  748. data/patches/fPIC-on-x64.patch +0 -14
  749. data/vendor/v8/src/liveobjectlist-inl.h +0 -126
  750. data/vendor/v8/src/liveobjectlist.cc +0 -2631
  751. data/vendor/v8/src/liveobjectlist.h +0 -319
  752. data/vendor/v8/test/mjsunit/mul-exhaustive.js +0 -4629
  753. data/vendor/v8/test/mjsunit/numops-fuzz.js +0 -4609
  754. data/vendor/v8/test/mjsunit/regress/regress-1969.js +0 -5045
@@ -53,9 +53,17 @@ MacroAssembler::MacroAssembler(Isolate* arg_isolate, void* buffer, int size)
53
53
  }
54
54
 
55
55
 
56
- static intptr_t RootRegisterDelta(ExternalReference other, Isolate* isolate) {
56
+ static const int kInvalidRootRegisterDelta = -1;
57
+
58
+
59
+ intptr_t MacroAssembler::RootRegisterDelta(ExternalReference other) {
60
+ if (predictable_code_size() &&
61
+ (other.address() < reinterpret_cast<Address>(isolate()) ||
62
+ other.address() >= reinterpret_cast<Address>(isolate() + 1))) {
63
+ return kInvalidRootRegisterDelta;
64
+ }
57
65
  Address roots_register_value = kRootRegisterBias +
58
- reinterpret_cast<Address>(isolate->heap()->roots_array_start());
66
+ reinterpret_cast<Address>(isolate()->heap()->roots_array_start());
59
67
  intptr_t delta = other.address() - roots_register_value;
60
68
  return delta;
61
69
  }
@@ -64,8 +72,8 @@ static intptr_t RootRegisterDelta(ExternalReference other, Isolate* isolate) {
64
72
  Operand MacroAssembler::ExternalOperand(ExternalReference target,
65
73
  Register scratch) {
66
74
  if (root_array_available_ && !Serializer::enabled()) {
67
- intptr_t delta = RootRegisterDelta(target, isolate());
68
- if (is_int32(delta)) {
75
+ intptr_t delta = RootRegisterDelta(target);
76
+ if (delta != kInvalidRootRegisterDelta && is_int32(delta)) {
69
77
  Serializer::TooLateToEnableNow();
70
78
  return Operand(kRootRegister, static_cast<int32_t>(delta));
71
79
  }
@@ -77,8 +85,8 @@ Operand MacroAssembler::ExternalOperand(ExternalReference target,
77
85
 
78
86
  void MacroAssembler::Load(Register destination, ExternalReference source) {
79
87
  if (root_array_available_ && !Serializer::enabled()) {
80
- intptr_t delta = RootRegisterDelta(source, isolate());
81
- if (is_int32(delta)) {
88
+ intptr_t delta = RootRegisterDelta(source);
89
+ if (delta != kInvalidRootRegisterDelta && is_int32(delta)) {
82
90
  Serializer::TooLateToEnableNow();
83
91
  movq(destination, Operand(kRootRegister, static_cast<int32_t>(delta)));
84
92
  return;
@@ -96,8 +104,8 @@ void MacroAssembler::Load(Register destination, ExternalReference source) {
96
104
 
97
105
  void MacroAssembler::Store(ExternalReference destination, Register source) {
98
106
  if (root_array_available_ && !Serializer::enabled()) {
99
- intptr_t delta = RootRegisterDelta(destination, isolate());
100
- if (is_int32(delta)) {
107
+ intptr_t delta = RootRegisterDelta(destination);
108
+ if (delta != kInvalidRootRegisterDelta && is_int32(delta)) {
101
109
  Serializer::TooLateToEnableNow();
102
110
  movq(Operand(kRootRegister, static_cast<int32_t>(delta)), source);
103
111
  return;
@@ -116,8 +124,8 @@ void MacroAssembler::Store(ExternalReference destination, Register source) {
116
124
  void MacroAssembler::LoadAddress(Register destination,
117
125
  ExternalReference source) {
118
126
  if (root_array_available_ && !Serializer::enabled()) {
119
- intptr_t delta = RootRegisterDelta(source, isolate());
120
- if (is_int32(delta)) {
127
+ intptr_t delta = RootRegisterDelta(source);
128
+ if (delta != kInvalidRootRegisterDelta && is_int32(delta)) {
121
129
  Serializer::TooLateToEnableNow();
122
130
  lea(destination, Operand(kRootRegister, static_cast<int32_t>(delta)));
123
131
  return;
@@ -133,8 +141,8 @@ int MacroAssembler::LoadAddressSize(ExternalReference source) {
133
141
  // This calculation depends on the internals of LoadAddress.
134
142
  // It's correctness is ensured by the asserts in the Call
135
143
  // instruction below.
136
- intptr_t delta = RootRegisterDelta(source, isolate());
137
- if (is_int32(delta)) {
144
+ intptr_t delta = RootRegisterDelta(source);
145
+ if (delta != kInvalidRootRegisterDelta && is_int32(delta)) {
138
146
  Serializer::TooLateToEnableNow();
139
147
  // Operand is lea(scratch, Operand(kRootRegister, delta));
140
148
  // Opcodes : REX.W 8D ModRM Disp8/Disp32 - 4 or 7.
@@ -154,7 +162,7 @@ void MacroAssembler::PushAddress(ExternalReference source) {
154
162
  int64_t address = reinterpret_cast<int64_t>(source.address());
155
163
  if (is_int32(address) && !Serializer::enabled()) {
156
164
  if (emit_debug_code()) {
157
- movq(kScratchRegister, BitCast<int64_t>(kZapValue), RelocInfo::NONE);
165
+ movq(kScratchRegister, BitCast<int64_t>(kZapValue), RelocInfo::NONE64);
158
166
  }
159
167
  push(Immediate(static_cast<int32_t>(address)));
160
168
  return;
@@ -216,7 +224,7 @@ void MacroAssembler::RememberedSetHelper(Register object, // For debug tests.
216
224
  Register scratch,
217
225
  SaveFPRegsMode save_fp,
218
226
  RememberedSetFinalAction and_then) {
219
- if (FLAG_debug_code) {
227
+ if (emit_debug_code()) {
220
228
  Label ok;
221
229
  JumpIfNotInNewSpace(object, scratch, &ok, Label::kNear);
222
230
  int3();
@@ -279,7 +287,7 @@ void MacroAssembler::InNewSpace(Register object,
279
287
  ASSERT(is_int32(static_cast<int64_t>(HEAP->NewSpaceMask())));
280
288
  intptr_t new_space_start =
281
289
  reinterpret_cast<intptr_t>(HEAP->NewSpaceStart());
282
- movq(kScratchRegister, -new_space_start, RelocInfo::NONE);
290
+ movq(kScratchRegister, -new_space_start, RelocInfo::NONE64);
283
291
  if (scratch.is(object)) {
284
292
  addq(scratch, kScratchRegister);
285
293
  } else {
@@ -334,8 +342,8 @@ void MacroAssembler::RecordWriteField(
334
342
  // Clobber clobbered input registers when running with the debug-code flag
335
343
  // turned on to provoke errors.
336
344
  if (emit_debug_code()) {
337
- movq(value, BitCast<int64_t>(kZapValue), RelocInfo::NONE);
338
- movq(dst, BitCast<int64_t>(kZapValue), RelocInfo::NONE);
345
+ movq(value, BitCast<int64_t>(kZapValue), RelocInfo::NONE64);
346
+ movq(dst, BitCast<int64_t>(kZapValue), RelocInfo::NONE64);
339
347
  }
340
348
  }
341
349
 
@@ -368,8 +376,8 @@ void MacroAssembler::RecordWriteArray(Register object,
368
376
  // Clobber clobbered input registers when running with the debug-code flag
369
377
  // turned on to provoke errors.
370
378
  if (emit_debug_code()) {
371
- movq(value, BitCast<int64_t>(kZapValue), RelocInfo::NONE);
372
- movq(index, BitCast<int64_t>(kZapValue), RelocInfo::NONE);
379
+ movq(value, BitCast<int64_t>(kZapValue), RelocInfo::NONE64);
380
+ movq(index, BitCast<int64_t>(kZapValue), RelocInfo::NONE64);
373
381
  }
374
382
  }
375
383
 
@@ -388,16 +396,14 @@ void MacroAssembler::RecordWrite(Register object,
388
396
  ASSERT(!object.is(value));
389
397
  ASSERT(!object.is(address));
390
398
  ASSERT(!value.is(address));
391
- if (emit_debug_code()) {
392
- AbortIfSmi(object);
393
- }
399
+ AssertNotSmi(object);
394
400
 
395
401
  if (remembered_set_action == OMIT_REMEMBERED_SET &&
396
402
  !FLAG_incremental_marking) {
397
403
  return;
398
404
  }
399
405
 
400
- if (FLAG_debug_code) {
406
+ if (emit_debug_code()) {
401
407
  Label ok;
402
408
  cmpq(value, Operand(address, 0));
403
409
  j(equal, &ok, Label::kNear);
@@ -436,8 +442,8 @@ void MacroAssembler::RecordWrite(Register object,
436
442
  // Clobber clobbered registers when running with the debug-code flag
437
443
  // turned on to provoke errors.
438
444
  if (emit_debug_code()) {
439
- movq(address, BitCast<int64_t>(kZapValue), RelocInfo::NONE);
440
- movq(value, BitCast<int64_t>(kZapValue), RelocInfo::NONE);
445
+ movq(address, BitCast<int64_t>(kZapValue), RelocInfo::NONE64);
446
+ movq(value, BitCast<int64_t>(kZapValue), RelocInfo::NONE64);
441
447
  }
442
448
  }
443
449
 
@@ -518,11 +524,11 @@ void MacroAssembler::Abort(const char* msg) {
518
524
  }
519
525
  #endif
520
526
  push(rax);
521
- movq(kScratchRegister, p0, RelocInfo::NONE);
527
+ movq(kScratchRegister, p0, RelocInfo::NONE64);
522
528
  push(kScratchRegister);
523
529
  movq(kScratchRegister,
524
530
  reinterpret_cast<intptr_t>(Smi::FromInt(static_cast<int>(p1 - p0))),
525
- RelocInfo::NONE);
531
+ RelocInfo::NONE64);
526
532
  push(kScratchRegister);
527
533
 
528
534
  if (!has_frame_) {
@@ -538,7 +544,7 @@ void MacroAssembler::Abort(const char* msg) {
538
544
  }
539
545
 
540
546
 
541
- void MacroAssembler::CallStub(CodeStub* stub, unsigned ast_id) {
547
+ void MacroAssembler::CallStub(CodeStub* stub, TypeFeedbackId ast_id) {
542
548
  ASSERT(AllowThisStubCall(stub)); // Calls are not allowed in some stubs
543
549
  Call(stub->GetCode(), RelocInfo::CODE_TARGET, ast_id);
544
550
  }
@@ -714,11 +720,28 @@ void MacroAssembler::CallApiFunctionAndReturn(Address function_address,
714
720
  movq(prev_next_address_reg, Operand(base_reg, kNextOffset));
715
721
  movq(prev_limit_reg, Operand(base_reg, kLimitOffset));
716
722
  addl(Operand(base_reg, kLevelOffset), Immediate(1));
723
+
724
+ if (FLAG_log_timer_events) {
725
+ FrameScope frame(this, StackFrame::MANUAL);
726
+ PushSafepointRegisters();
727
+ PrepareCallCFunction(0);
728
+ CallCFunction(ExternalReference::log_enter_external_function(isolate()), 0);
729
+ PopSafepointRegisters();
730
+ }
731
+
717
732
  // Call the api function!
718
733
  movq(rax, reinterpret_cast<int64_t>(function_address),
719
- RelocInfo::RUNTIME_ENTRY);
734
+ RelocInfo::EXTERNAL_REFERENCE);
720
735
  call(rax);
721
736
 
737
+ if (FLAG_log_timer_events) {
738
+ FrameScope frame(this, StackFrame::MANUAL);
739
+ PushSafepointRegisters();
740
+ PrepareCallCFunction(0);
741
+ CallCFunction(ExternalReference::log_leave_external_function(isolate()), 0);
742
+ PopSafepointRegisters();
743
+ }
744
+
722
745
  #if defined(_WIN64) && !defined(__MINGW64__)
723
746
  // rax keeps a pointer to v8::Handle, unpack it.
724
747
  movq(rax, Operand(rax, 0));
@@ -743,17 +766,52 @@ void MacroAssembler::CallApiFunctionAndReturn(Address function_address,
743
766
  Cmp(Operand(rsi, 0), factory->the_hole_value());
744
767
  j(not_equal, &promote_scheduled_exception);
745
768
 
769
+ #if ENABLE_EXTRA_CHECKS
770
+ // Check if the function returned a valid JavaScript value.
771
+ Label ok;
772
+ Register return_value = rax;
773
+ Register map = rcx;
774
+
775
+ JumpIfSmi(return_value, &ok, Label::kNear);
776
+ movq(map, FieldOperand(return_value, HeapObject::kMapOffset));
777
+
778
+ CmpInstanceType(map, FIRST_NONSTRING_TYPE);
779
+ j(below, &ok, Label::kNear);
780
+
781
+ CmpInstanceType(map, FIRST_SPEC_OBJECT_TYPE);
782
+ j(above_equal, &ok, Label::kNear);
783
+
784
+ CompareRoot(map, Heap::kHeapNumberMapRootIndex);
785
+ j(equal, &ok, Label::kNear);
786
+
787
+ CompareRoot(return_value, Heap::kUndefinedValueRootIndex);
788
+ j(equal, &ok, Label::kNear);
789
+
790
+ CompareRoot(return_value, Heap::kTrueValueRootIndex);
791
+ j(equal, &ok, Label::kNear);
792
+
793
+ CompareRoot(return_value, Heap::kFalseValueRootIndex);
794
+ j(equal, &ok, Label::kNear);
795
+
796
+ CompareRoot(return_value, Heap::kNullValueRootIndex);
797
+ j(equal, &ok, Label::kNear);
798
+
799
+ Abort("API call returned invalid object");
800
+
801
+ bind(&ok);
802
+ #endif
803
+
746
804
  LeaveApiExitFrame();
747
805
  ret(stack_space * kPointerSize);
748
806
 
749
- bind(&promote_scheduled_exception);
750
- TailCallRuntime(Runtime::kPromoteScheduledException, 0, 1);
751
-
752
807
  bind(&empty_result);
753
808
  // It was zero; the result is undefined.
754
- Move(rax, factory->undefined_value());
809
+ LoadRoot(rax, Heap::kUndefinedValueRootIndex);
755
810
  jmp(&prologue);
756
811
 
812
+ bind(&promote_scheduled_exception);
813
+ TailCallRuntime(Runtime::kPromoteScheduledException, 0, 1);
814
+
757
815
  // HandleScope limit has changed. Delete allocated extensions.
758
816
  bind(&delete_allocated_handles);
759
817
  movq(Operand(base_reg, kLimitOffset), prev_limit_reg);
@@ -798,7 +856,7 @@ void MacroAssembler::InvokeBuiltin(Builtins::JavaScript id,
798
856
  void MacroAssembler::GetBuiltinFunction(Register target,
799
857
  Builtins::JavaScript id) {
800
858
  // Load the builtins object into target register.
801
- movq(target, Operand(rsi, Context::SlotOffset(Context::GLOBAL_INDEX)));
859
+ movq(target, Operand(rsi, Context::SlotOffset(Context::GLOBAL_OBJECT_INDEX)));
802
860
  movq(target, FieldOperand(target, GlobalObject::kBuiltinsOffset));
803
861
  movq(target, FieldOperand(target,
804
862
  JSBuiltinsObject::OffsetOfFunctionWithId(id)));
@@ -841,8 +899,8 @@ void MacroAssembler::PushCallerSaved(SaveFPRegsMode fp_mode,
841
899
  // R12 to r15 are callee save on all platforms.
842
900
  if (fp_mode == kSaveFPRegs) {
843
901
  CpuFeatures::Scope scope(SSE2);
844
- subq(rsp, Immediate(kDoubleSize * XMMRegister::kNumRegisters));
845
- for (int i = 0; i < XMMRegister::kNumRegisters; i++) {
902
+ subq(rsp, Immediate(kDoubleSize * XMMRegister::kMaxNumRegisters));
903
+ for (int i = 0; i < XMMRegister::kMaxNumRegisters; i++) {
846
904
  XMMRegister reg = XMMRegister::from_code(i);
847
905
  movsd(Operand(rsp, i * kDoubleSize), reg);
848
906
  }
@@ -856,11 +914,11 @@ void MacroAssembler::PopCallerSaved(SaveFPRegsMode fp_mode,
856
914
  Register exclusion3) {
857
915
  if (fp_mode == kSaveFPRegs) {
858
916
  CpuFeatures::Scope scope(SSE2);
859
- for (int i = 0; i < XMMRegister::kNumRegisters; i++) {
917
+ for (int i = 0; i < XMMRegister::kMaxNumRegisters; i++) {
860
918
  XMMRegister reg = XMMRegister::from_code(i);
861
919
  movsd(reg, Operand(rsp, i * kDoubleSize));
862
920
  }
863
- addq(rsp, Immediate(kDoubleSize * XMMRegister::kNumRegisters));
921
+ addq(rsp, Immediate(kDoubleSize * XMMRegister::kMaxNumRegisters));
864
922
  }
865
923
  for (int i = kNumberOfSavedRegs - 1; i >= 0; i--) {
866
924
  Register reg = saved_regs[i];
@@ -879,7 +937,7 @@ void MacroAssembler::Set(Register dst, int64_t x) {
879
937
  } else if (is_int32(x)) {
880
938
  movq(dst, Immediate(static_cast<int32_t>(x)));
881
939
  } else {
882
- movq(dst, x, RelocInfo::NONE);
940
+ movq(dst, x, RelocInfo::NONE64);
883
941
  }
884
942
  }
885
943
 
@@ -892,6 +950,38 @@ void MacroAssembler::Set(const Operand& dst, int64_t x) {
892
950
  }
893
951
  }
894
952
 
953
+
954
+ bool MacroAssembler::IsUnsafeInt(const int x) {
955
+ static const int kMaxBits = 17;
956
+ return !is_intn(x, kMaxBits);
957
+ }
958
+
959
+
960
+ void MacroAssembler::SafeMove(Register dst, Smi* src) {
961
+ ASSERT(!dst.is(kScratchRegister));
962
+ ASSERT(kSmiValueSize == 32); // JIT cookie can be converted to Smi.
963
+ if (IsUnsafeInt(src->value()) && jit_cookie() != 0) {
964
+ Move(dst, Smi::FromInt(src->value() ^ jit_cookie()));
965
+ Move(kScratchRegister, Smi::FromInt(jit_cookie()));
966
+ xor_(dst, kScratchRegister);
967
+ } else {
968
+ Move(dst, src);
969
+ }
970
+ }
971
+
972
+
973
+ void MacroAssembler::SafePush(Smi* src) {
974
+ ASSERT(kSmiValueSize == 32); // JIT cookie can be converted to Smi.
975
+ if (IsUnsafeInt(src->value()) && jit_cookie() != 0) {
976
+ Push(Smi::FromInt(src->value() ^ jit_cookie()));
977
+ Move(kScratchRegister, Smi::FromInt(jit_cookie()));
978
+ xor_(Operand(rsp, 0), kScratchRegister);
979
+ } else {
980
+ Push(src);
981
+ }
982
+ }
983
+
984
+
895
985
  // ----------------------------------------------------------------------------
896
986
  // Smi tagging, untagging and tag detection.
897
987
 
@@ -912,7 +1002,7 @@ void MacroAssembler::LoadSmiConstant(Register dst, Smi* source) {
912
1002
  if (emit_debug_code()) {
913
1003
  movq(dst,
914
1004
  reinterpret_cast<uint64_t>(Smi::FromInt(kSmiConstantRegisterValue)),
915
- RelocInfo::NONE);
1005
+ RelocInfo::NONE64);
916
1006
  cmpq(dst, kSmiConstantRegister);
917
1007
  if (allow_stub_calls()) {
918
1008
  Assert(equal, "Uninitialized kSmiConstantRegister");
@@ -959,7 +1049,7 @@ void MacroAssembler::LoadSmiConstant(Register dst, Smi* source) {
959
1049
  UNREACHABLE();
960
1050
  return;
961
1051
  default:
962
- movq(dst, reinterpret_cast<uint64_t>(source), RelocInfo::NONE);
1052
+ movq(dst, reinterpret_cast<uint64_t>(source), RelocInfo::NONE64);
963
1053
  return;
964
1054
  }
965
1055
  if (negative) {
@@ -1040,18 +1130,14 @@ void MacroAssembler::SmiTest(Register src) {
1040
1130
 
1041
1131
 
1042
1132
  void MacroAssembler::SmiCompare(Register smi1, Register smi2) {
1043
- if (emit_debug_code()) {
1044
- AbortIfNotSmi(smi1);
1045
- AbortIfNotSmi(smi2);
1046
- }
1133
+ AssertSmi(smi1);
1134
+ AssertSmi(smi2);
1047
1135
  cmpq(smi1, smi2);
1048
1136
  }
1049
1137
 
1050
1138
 
1051
1139
  void MacroAssembler::SmiCompare(Register dst, Smi* src) {
1052
- if (emit_debug_code()) {
1053
- AbortIfNotSmi(dst);
1054
- }
1140
+ AssertSmi(dst);
1055
1141
  Cmp(dst, src);
1056
1142
  }
1057
1143
 
@@ -1068,27 +1154,21 @@ void MacroAssembler::Cmp(Register dst, Smi* src) {
1068
1154
 
1069
1155
 
1070
1156
  void MacroAssembler::SmiCompare(Register dst, const Operand& src) {
1071
- if (emit_debug_code()) {
1072
- AbortIfNotSmi(dst);
1073
- AbortIfNotSmi(src);
1074
- }
1157
+ AssertSmi(dst);
1158
+ AssertSmi(src);
1075
1159
  cmpq(dst, src);
1076
1160
  }
1077
1161
 
1078
1162
 
1079
1163
  void MacroAssembler::SmiCompare(const Operand& dst, Register src) {
1080
- if (emit_debug_code()) {
1081
- AbortIfNotSmi(dst);
1082
- AbortIfNotSmi(src);
1083
- }
1164
+ AssertSmi(dst);
1165
+ AssertSmi(src);
1084
1166
  cmpq(dst, src);
1085
1167
  }
1086
1168
 
1087
1169
 
1088
1170
  void MacroAssembler::SmiCompare(const Operand& dst, Smi* src) {
1089
- if (emit_debug_code()) {
1090
- AbortIfNotSmi(dst);
1091
- }
1171
+ AssertSmi(dst);
1092
1172
  cmpl(Operand(dst, kSmiShift / kBitsPerByte), Immediate(src->value()));
1093
1173
  }
1094
1174
 
@@ -2165,7 +2245,7 @@ void MacroAssembler::JumpIfInstanceTypeIsNotSequentialAscii(
2165
2245
  kIsNotStringMask | kStringRepresentationMask | kStringEncodingMask;
2166
2246
 
2167
2247
  andl(scratch, Immediate(kFlatAsciiStringMask));
2168
- cmpl(scratch, Immediate(kStringTag | kSeqStringTag | kAsciiStringTag));
2248
+ cmpl(scratch, Immediate(kStringTag | kSeqStringTag | kOneByteStringTag));
2169
2249
  j(not_equal, failure, near_jump);
2170
2250
  }
2171
2251
 
@@ -2377,7 +2457,7 @@ void MacroAssembler::Call(Address destination, RelocInfo::Mode rmode) {
2377
2457
 
2378
2458
  void MacroAssembler::Call(Handle<Code> code_object,
2379
2459
  RelocInfo::Mode rmode,
2380
- unsigned ast_id) {
2460
+ TypeFeedbackId ast_id) {
2381
2461
  #ifdef DEBUG
2382
2462
  int end_position = pc_offset() + CallSize(code_object);
2383
2463
  #endif
@@ -2460,6 +2540,12 @@ MacroAssembler::kSafepointPushRegisterIndices[Register::kNumRegisters] = {
2460
2540
  };
2461
2541
 
2462
2542
 
2543
+ void MacroAssembler::StoreToSafepointRegisterSlot(Register dst,
2544
+ const Immediate& imm) {
2545
+ movq(SafepointRegisterSlot(dst), imm);
2546
+ }
2547
+
2548
+
2463
2549
  void MacroAssembler::StoreToSafepointRegisterSlot(Register dst, Register src) {
2464
2550
  movq(SafepointRegisterSlot(dst), src);
2465
2551
  }
@@ -2700,7 +2786,8 @@ void MacroAssembler::StoreNumberToDoubleElements(
2700
2786
  Register elements,
2701
2787
  Register index,
2702
2788
  XMMRegister xmm_scratch,
2703
- Label* fail) {
2789
+ Label* fail,
2790
+ int elements_offset) {
2704
2791
  Label smi_value, is_nan, maybe_nan, not_nan, have_double_value, done;
2705
2792
 
2706
2793
  JumpIfSmi(maybe_number, &smi_value, Label::kNear);
@@ -2719,7 +2806,8 @@ void MacroAssembler::StoreNumberToDoubleElements(
2719
2806
  bind(&not_nan);
2720
2807
  movsd(xmm_scratch, FieldOperand(maybe_number, HeapNumber::kValueOffset));
2721
2808
  bind(&have_double_value);
2722
- movsd(FieldOperand(elements, index, times_8, FixedDoubleArray::kHeaderSize),
2809
+ movsd(FieldOperand(elements, index, times_8,
2810
+ FixedDoubleArray::kHeaderSize - elements_offset),
2723
2811
  xmm_scratch);
2724
2812
  jmp(&done);
2725
2813
 
@@ -2742,7 +2830,8 @@ void MacroAssembler::StoreNumberToDoubleElements(
2742
2830
  // Preserve original value.
2743
2831
  SmiToInteger32(kScratchRegister, maybe_number);
2744
2832
  cvtlsi2sd(xmm_scratch, kScratchRegister);
2745
- movsd(FieldOperand(elements, index, times_8, FixedDoubleArray::kHeaderSize),
2833
+ movsd(FieldOperand(elements, index, times_8,
2834
+ FixedDoubleArray::kHeaderSize - elements_offset),
2746
2835
  xmm_scratch);
2747
2836
  bind(&done);
2748
2837
  }
@@ -2760,7 +2849,7 @@ void MacroAssembler::CompareMap(Register obj,
2760
2849
  Map* current_map = *map;
2761
2850
  while (CanTransitionToMoreGeneralFastElementsKind(kind, packed)) {
2762
2851
  kind = GetNextMoreGeneralFastElementsKind(kind, packed);
2763
- current_map = current_map->LookupElementsTransitionMap(kind, NULL);
2852
+ current_map = current_map->LookupElementsTransitionMap(kind);
2764
2853
  if (!current_map) break;
2765
2854
  j(equal, early_success, Label::kNear);
2766
2855
  Cmp(FieldOperand(obj, HeapObject::kMapOffset),
@@ -2799,33 +2888,57 @@ void MacroAssembler::ClampUint8(Register reg) {
2799
2888
 
2800
2889
  void MacroAssembler::ClampDoubleToUint8(XMMRegister input_reg,
2801
2890
  XMMRegister temp_xmm_reg,
2802
- Register result_reg,
2803
- Register temp_reg) {
2891
+ Register result_reg) {
2804
2892
  Label done;
2805
- Set(result_reg, 0);
2893
+ Label conv_failure;
2806
2894
  xorps(temp_xmm_reg, temp_xmm_reg);
2807
- ucomisd(input_reg, temp_xmm_reg);
2808
- j(below, &done, Label::kNear);
2809
- uint64_t one_half = BitCast<uint64_t, double>(0.5);
2810
- Set(temp_reg, one_half);
2811
- movq(temp_xmm_reg, temp_reg);
2812
- addsd(temp_xmm_reg, input_reg);
2813
- cvttsd2si(result_reg, temp_xmm_reg);
2895
+ cvtsd2si(result_reg, input_reg);
2814
2896
  testl(result_reg, Immediate(0xFFFFFF00));
2815
2897
  j(zero, &done, Label::kNear);
2898
+ cmpl(result_reg, Immediate(0x80000000));
2899
+ j(equal, &conv_failure, Label::kNear);
2900
+ movl(result_reg, Immediate(0));
2901
+ setcc(above, result_reg);
2902
+ subl(result_reg, Immediate(1));
2903
+ andl(result_reg, Immediate(255));
2904
+ jmp(&done, Label::kNear);
2905
+ bind(&conv_failure);
2906
+ Set(result_reg, 0);
2907
+ ucomisd(input_reg, temp_xmm_reg);
2908
+ j(below, &done, Label::kNear);
2816
2909
  Set(result_reg, 255);
2817
2910
  bind(&done);
2818
2911
  }
2819
2912
 
2820
2913
 
2914
+ void MacroAssembler::LoadUint32(XMMRegister dst,
2915
+ Register src,
2916
+ XMMRegister scratch) {
2917
+ if (FLAG_debug_code) {
2918
+ cmpq(src, Immediate(0xffffffff));
2919
+ Assert(below_equal, "input GPR is expected to have upper32 cleared");
2920
+ }
2921
+ cvtqsi2sd(dst, src);
2922
+ }
2923
+
2924
+
2821
2925
  void MacroAssembler::LoadInstanceDescriptors(Register map,
2822
2926
  Register descriptors) {
2823
- movq(descriptors, FieldOperand(map,
2824
- Map::kInstanceDescriptorsOrBitField3Offset));
2825
- Label not_smi;
2826
- JumpIfNotSmi(descriptors, &not_smi, Label::kNear);
2827
- Move(descriptors, isolate()->factory()->empty_descriptor_array());
2828
- bind(&not_smi);
2927
+ movq(descriptors, FieldOperand(map, Map::kDescriptorsOffset));
2928
+ }
2929
+
2930
+
2931
+ void MacroAssembler::NumberOfOwnDescriptors(Register dst, Register map) {
2932
+ movq(dst, FieldOperand(map, Map::kBitField3Offset));
2933
+ DecodeField<Map::NumberOfOwnDescriptorsBits>(dst);
2934
+ }
2935
+
2936
+
2937
+ void MacroAssembler::EnumLength(Register dst, Register map) {
2938
+ STATIC_ASSERT(Map::EnumLengthBits::kShift == 0);
2939
+ movq(dst, FieldOperand(map, Map::kBitField3Offset));
2940
+ Move(kScratchRegister, Smi::FromInt(Map::EnumLengthBits::kMask));
2941
+ and_(dst, kScratchRegister);
2829
2942
  }
2830
2943
 
2831
2944
 
@@ -2844,61 +2957,75 @@ void MacroAssembler::DispatchMap(Register obj,
2844
2957
  }
2845
2958
 
2846
2959
 
2847
- void MacroAssembler::AbortIfNotNumber(Register object) {
2848
- Label ok;
2849
- Condition is_smi = CheckSmi(object);
2850
- j(is_smi, &ok, Label::kNear);
2851
- Cmp(FieldOperand(object, HeapObject::kMapOffset),
2852
- isolate()->factory()->heap_number_map());
2853
- Assert(equal, "Operand not a number");
2854
- bind(&ok);
2960
+ void MacroAssembler::AssertNumber(Register object) {
2961
+ if (emit_debug_code()) {
2962
+ Label ok;
2963
+ Condition is_smi = CheckSmi(object);
2964
+ j(is_smi, &ok, Label::kNear);
2965
+ Cmp(FieldOperand(object, HeapObject::kMapOffset),
2966
+ isolate()->factory()->heap_number_map());
2967
+ Check(equal, "Operand is not a number");
2968
+ bind(&ok);
2969
+ }
2855
2970
  }
2856
2971
 
2857
2972
 
2858
- void MacroAssembler::AbortIfSmi(Register object) {
2859
- Condition is_smi = CheckSmi(object);
2860
- Assert(NegateCondition(is_smi), "Operand is a smi");
2973
+ void MacroAssembler::AssertNotSmi(Register object) {
2974
+ if (emit_debug_code()) {
2975
+ Condition is_smi = CheckSmi(object);
2976
+ Check(NegateCondition(is_smi), "Operand is a smi");
2977
+ }
2861
2978
  }
2862
2979
 
2863
2980
 
2864
- void MacroAssembler::AbortIfNotSmi(Register object) {
2865
- Condition is_smi = CheckSmi(object);
2866
- Assert(is_smi, "Operand is not a smi");
2981
+ void MacroAssembler::AssertSmi(Register object) {
2982
+ if (emit_debug_code()) {
2983
+ Condition is_smi = CheckSmi(object);
2984
+ Check(is_smi, "Operand is not a smi");
2985
+ }
2867
2986
  }
2868
2987
 
2869
2988
 
2870
- void MacroAssembler::AbortIfNotSmi(const Operand& object) {
2871
- Condition is_smi = CheckSmi(object);
2872
- Assert(is_smi, "Operand is not a smi");
2989
+ void MacroAssembler::AssertSmi(const Operand& object) {
2990
+ if (emit_debug_code()) {
2991
+ Condition is_smi = CheckSmi(object);
2992
+ Check(is_smi, "Operand is not a smi");
2993
+ }
2873
2994
  }
2874
2995
 
2875
2996
 
2876
- void MacroAssembler::AbortIfNotZeroExtended(Register int32_register) {
2877
- ASSERT(!int32_register.is(kScratchRegister));
2878
- movq(kScratchRegister, 0x100000000l, RelocInfo::NONE);
2879
- cmpq(kScratchRegister, int32_register);
2880
- Assert(above_equal, "32 bit value in register is not zero-extended");
2997
+ void MacroAssembler::AssertZeroExtended(Register int32_register) {
2998
+ if (emit_debug_code()) {
2999
+ ASSERT(!int32_register.is(kScratchRegister));
3000
+ movq(kScratchRegister, 0x100000000l, RelocInfo::NONE64);
3001
+ cmpq(kScratchRegister, int32_register);
3002
+ Check(above_equal, "32 bit value in register is not zero-extended");
3003
+ }
2881
3004
  }
2882
3005
 
2883
3006
 
2884
- void MacroAssembler::AbortIfNotString(Register object) {
2885
- testb(object, Immediate(kSmiTagMask));
2886
- Assert(not_equal, "Operand is not a string");
2887
- push(object);
2888
- movq(object, FieldOperand(object, HeapObject::kMapOffset));
2889
- CmpInstanceType(object, FIRST_NONSTRING_TYPE);
2890
- pop(object);
2891
- Assert(below, "Operand is not a string");
3007
+ void MacroAssembler::AssertString(Register object) {
3008
+ if (emit_debug_code()) {
3009
+ testb(object, Immediate(kSmiTagMask));
3010
+ Check(not_equal, "Operand is a smi and not a string");
3011
+ push(object);
3012
+ movq(object, FieldOperand(object, HeapObject::kMapOffset));
3013
+ CmpInstanceType(object, FIRST_NONSTRING_TYPE);
3014
+ pop(object);
3015
+ Check(below, "Operand is not a string");
3016
+ }
2892
3017
  }
2893
3018
 
2894
3019
 
2895
- void MacroAssembler::AbortIfNotRootValue(Register src,
2896
- Heap::RootListIndex root_value_index,
2897
- const char* message) {
2898
- ASSERT(!src.is(kScratchRegister));
2899
- LoadRoot(kScratchRegister, root_value_index);
2900
- cmpq(src, kScratchRegister);
2901
- Check(equal, message);
3020
+ void MacroAssembler::AssertRootValue(Register src,
3021
+ Heap::RootListIndex root_value_index,
3022
+ const char* message) {
3023
+ if (emit_debug_code()) {
3024
+ ASSERT(!src.is(kScratchRegister));
3025
+ LoadRoot(kScratchRegister, root_value_index);
3026
+ cmpq(src, kScratchRegister);
3027
+ Check(equal, message);
3028
+ }
2902
3029
  }
2903
3030
 
2904
3031
 
@@ -3287,11 +3414,11 @@ void MacroAssembler::EnterExitFrameEpilogue(int arg_stack_space,
3287
3414
  #endif
3288
3415
  // Optionally save all XMM registers.
3289
3416
  if (save_doubles) {
3290
- int space = XMMRegister::kNumRegisters * kDoubleSize +
3417
+ int space = XMMRegister::kMaxNumRegisters * kDoubleSize +
3291
3418
  arg_stack_space * kPointerSize;
3292
3419
  subq(rsp, Immediate(space));
3293
3420
  int offset = -2 * kPointerSize;
3294
- for (int i = 0; i < XMMRegister::kNumAllocatableRegisters; i++) {
3421
+ for (int i = 0; i < XMMRegister::NumAllocatableRegisters(); i++) {
3295
3422
  XMMRegister reg = XMMRegister::FromAllocationIndex(i);
3296
3423
  movsd(Operand(rbp, offset - ((i + 1) * kDoubleSize)), reg);
3297
3424
  }
@@ -3335,7 +3462,7 @@ void MacroAssembler::LeaveExitFrame(bool save_doubles) {
3335
3462
  // r15 : argv
3336
3463
  if (save_doubles) {
3337
3464
  int offset = -2 * kPointerSize;
3338
- for (int i = 0; i < XMMRegister::kNumAllocatableRegisters; i++) {
3465
+ for (int i = 0; i < XMMRegister::NumAllocatableRegisters(); i++) {
3339
3466
  XMMRegister reg = XMMRegister::FromAllocationIndex(i);
3340
3467
  movsd(reg, Operand(rbp, offset - ((i + 1) * kDoubleSize)));
3341
3468
  }
@@ -3395,20 +3522,21 @@ void MacroAssembler::CheckAccessGlobalProxy(Register holder_reg,
3395
3522
  cmpq(scratch, Immediate(0));
3396
3523
  Check(not_equal, "we should not have an empty lexical context");
3397
3524
  }
3398
- // Load the global context of the current context.
3399
- int offset = Context::kHeaderSize + Context::GLOBAL_INDEX * kPointerSize;
3525
+ // Load the native context of the current context.
3526
+ int offset =
3527
+ Context::kHeaderSize + Context::GLOBAL_OBJECT_INDEX * kPointerSize;
3400
3528
  movq(scratch, FieldOperand(scratch, offset));
3401
- movq(scratch, FieldOperand(scratch, GlobalObject::kGlobalContextOffset));
3529
+ movq(scratch, FieldOperand(scratch, GlobalObject::kNativeContextOffset));
3402
3530
 
3403
- // Check the context is a global context.
3531
+ // Check the context is a native context.
3404
3532
  if (emit_debug_code()) {
3405
3533
  Cmp(FieldOperand(scratch, HeapObject::kMapOffset),
3406
- isolate()->factory()->global_context_map());
3407
- Check(equal, "JSGlobalObject::global_context should be a global context.");
3534
+ isolate()->factory()->native_context_map());
3535
+ Check(equal, "JSGlobalObject::native_context should be a native context.");
3408
3536
  }
3409
3537
 
3410
3538
  // Check if both contexts are the same.
3411
- cmpq(scratch, FieldOperand(holder_reg, JSGlobalProxy::kContextOffset));
3539
+ cmpq(scratch, FieldOperand(holder_reg, JSGlobalProxy::kNativeContextOffset));
3412
3540
  j(equal, &same_contexts);
3413
3541
 
3414
3542
  // Compare security tokens.
@@ -3416,23 +3544,24 @@ void MacroAssembler::CheckAccessGlobalProxy(Register holder_reg,
3416
3544
  // compatible with the security token in the receiving global
3417
3545
  // object.
3418
3546
 
3419
- // Check the context is a global context.
3547
+ // Check the context is a native context.
3420
3548
  if (emit_debug_code()) {
3421
3549
  // Preserve original value of holder_reg.
3422
3550
  push(holder_reg);
3423
- movq(holder_reg, FieldOperand(holder_reg, JSGlobalProxy::kContextOffset));
3551
+ movq(holder_reg,
3552
+ FieldOperand(holder_reg, JSGlobalProxy::kNativeContextOffset));
3424
3553
  CompareRoot(holder_reg, Heap::kNullValueRootIndex);
3425
3554
  Check(not_equal, "JSGlobalProxy::context() should not be null.");
3426
3555
 
3427
- // Read the first word and compare to global_context_map(),
3556
+ // Read the first word and compare to native_context_map(),
3428
3557
  movq(holder_reg, FieldOperand(holder_reg, HeapObject::kMapOffset));
3429
- CompareRoot(holder_reg, Heap::kGlobalContextMapRootIndex);
3430
- Check(equal, "JSGlobalObject::global_context should be a global context.");
3558
+ CompareRoot(holder_reg, Heap::kNativeContextMapRootIndex);
3559
+ Check(equal, "JSGlobalObject::native_context should be a native context.");
3431
3560
  pop(holder_reg);
3432
3561
  }
3433
3562
 
3434
3563
  movq(kScratchRegister,
3435
- FieldOperand(holder_reg, JSGlobalProxy::kContextOffset));
3564
+ FieldOperand(holder_reg, JSGlobalProxy::kNativeContextOffset));
3436
3565
  int token_offset =
3437
3566
  Context::kHeaderSize + Context::SECURITY_TOKEN_INDEX * kPointerSize;
3438
3567
  movq(scratch, FieldOperand(scratch, token_offset));
@@ -3615,6 +3744,7 @@ void MacroAssembler::AllocateInNewSpace(int object_size,
3615
3744
  Register scratch,
3616
3745
  Label* gc_required,
3617
3746
  AllocationFlags flags) {
3747
+ ASSERT((flags & (RESULT_CONTAINS_TOP | SIZE_IN_WORDS)) == 0);
3618
3748
  if (!FLAG_inline_new) {
3619
3749
  if (emit_debug_code()) {
3620
3750
  // Trash the registers to simulate an allocation failure.
@@ -3634,6 +3764,13 @@ void MacroAssembler::AllocateInNewSpace(int object_size,
3634
3764
  // Load address of new object into result.
3635
3765
  LoadAllocationTopHelper(result, scratch, flags);
3636
3766
 
3767
+ // Align the next allocation. Storing the filler map without checking top is
3768
+ // always safe because the limit of the heap is always aligned.
3769
+ if (((flags & DOUBLE_ALIGNMENT) != 0) && FLAG_debug_code) {
3770
+ testq(result, Immediate(kDoubleAlignmentMask));
3771
+ Check(zero, "Allocation is not double aligned");
3772
+ }
3773
+
3637
3774
  // Calculate new top and bail out if new space is exhausted.
3638
3775
  ExternalReference new_space_allocation_limit =
3639
3776
  ExternalReference::new_space_allocation_limit_address(isolate());
@@ -3652,15 +3789,17 @@ void MacroAssembler::AllocateInNewSpace(int object_size,
3652
3789
  // Update allocation top.
3653
3790
  UpdateAllocationTopHelper(top_reg, scratch);
3654
3791
 
3792
+ bool tag_result = (flags & TAG_OBJECT) != 0;
3655
3793
  if (top_reg.is(result)) {
3656
- if ((flags & TAG_OBJECT) != 0) {
3794
+ if (tag_result) {
3657
3795
  subq(result, Immediate(object_size - kHeapObjectTag));
3658
3796
  } else {
3659
3797
  subq(result, Immediate(object_size));
3660
3798
  }
3661
- } else if ((flags & TAG_OBJECT) != 0) {
3799
+ } else if (tag_result) {
3662
3800
  // Tag the result if requested.
3663
- addq(result, Immediate(kHeapObjectTag));
3801
+ ASSERT(kHeapObjectTag == 1);
3802
+ incq(result);
3664
3803
  }
3665
3804
  }
3666
3805
 
@@ -3673,6 +3812,7 @@ void MacroAssembler::AllocateInNewSpace(int header_size,
3673
3812
  Register scratch,
3674
3813
  Label* gc_required,
3675
3814
  AllocationFlags flags) {
3815
+ ASSERT((flags & SIZE_IN_WORDS) == 0);
3676
3816
  if (!FLAG_inline_new) {
3677
3817
  if (emit_debug_code()) {
3678
3818
  // Trash the registers to simulate an allocation failure.
@@ -3691,6 +3831,13 @@ void MacroAssembler::AllocateInNewSpace(int header_size,
3691
3831
  // Load address of new object into result.
3692
3832
  LoadAllocationTopHelper(result, scratch, flags);
3693
3833
 
3834
+ // Align the next allocation. Storing the filler map without checking top is
3835
+ // always safe because the limit of the heap is always aligned.
3836
+ if (((flags & DOUBLE_ALIGNMENT) != 0) && FLAG_debug_code) {
3837
+ testq(result, Immediate(kDoubleAlignmentMask));
3838
+ Check(zero, "Allocation is not double aligned");
3839
+ }
3840
+
3694
3841
  // Calculate new top and bail out if new space is exhausted.
3695
3842
  ExternalReference new_space_allocation_limit =
3696
3843
  ExternalReference::new_space_allocation_limit_address(isolate());
@@ -3709,7 +3856,8 @@ void MacroAssembler::AllocateInNewSpace(int header_size,
3709
3856
 
3710
3857
  // Tag the result if requested.
3711
3858
  if ((flags & TAG_OBJECT) != 0) {
3712
- addq(result, Immediate(kHeapObjectTag));
3859
+ ASSERT(kHeapObjectTag == 1);
3860
+ incq(result);
3713
3861
  }
3714
3862
  }
3715
3863
 
@@ -3720,6 +3868,7 @@ void MacroAssembler::AllocateInNewSpace(Register object_size,
3720
3868
  Register scratch,
3721
3869
  Label* gc_required,
3722
3870
  AllocationFlags flags) {
3871
+ ASSERT((flags & (RESULT_CONTAINS_TOP | SIZE_IN_WORDS)) == 0);
3723
3872
  if (!FLAG_inline_new) {
3724
3873
  if (emit_debug_code()) {
3725
3874
  // Trash the registers to simulate an allocation failure.
@@ -3753,6 +3902,13 @@ void MacroAssembler::AllocateInNewSpace(Register object_size,
3753
3902
  // Update allocation top.
3754
3903
  UpdateAllocationTopHelper(result_end, scratch);
3755
3904
 
3905
+ // Align the next allocation. Storing the filler map without checking top is
3906
+ // always safe because the limit of the heap is always aligned.
3907
+ if (((flags & DOUBLE_ALIGNMENT) != 0) && FLAG_debug_code) {
3908
+ testq(result, Immediate(kDoubleAlignmentMask));
3909
+ Check(zero, "Allocation is not double aligned");
3910
+ }
3911
+
3756
3912
  // Tag the result if requested.
3757
3913
  if ((flags & TAG_OBJECT) != 0) {
3758
3914
  addq(result, Immediate(kHeapObjectTag));
@@ -3839,7 +3995,7 @@ void MacroAssembler::AllocateAsciiString(Register result,
3839
3995
  Label* gc_required) {
3840
3996
  // Calculate the number of bytes needed for the characters in the string while
3841
3997
  // observing object alignment.
3842
- const int kHeaderAlignment = SeqAsciiString::kHeaderSize &
3998
+ const int kHeaderAlignment = SeqOneByteString::kHeaderSize &
3843
3999
  kObjectAlignmentMask;
3844
4000
  movl(scratch1, length);
3845
4001
  ASSERT(kCharSize == 1);
@@ -3850,7 +4006,7 @@ void MacroAssembler::AllocateAsciiString(Register result,
3850
4006
  }
3851
4007
 
3852
4008
  // Allocate ASCII string in new space.
3853
- AllocateInNewSpace(SeqAsciiString::kHeaderSize,
4009
+ AllocateInNewSpace(SeqOneByteString::kHeaderSize,
3854
4010
  times_1,
3855
4011
  scratch1,
3856
4012
  result,
@@ -3954,7 +4110,7 @@ void MacroAssembler::CopyBytes(Register destination,
3954
4110
  int min_length,
3955
4111
  Register scratch) {
3956
4112
  ASSERT(min_length >= 0);
3957
- if (FLAG_debug_code) {
4113
+ if (emit_debug_code()) {
3958
4114
  cmpl(length, Immediate(min_length));
3959
4115
  Assert(greater_equal, "Invalid min_length");
3960
4116
  }
@@ -4052,8 +4208,9 @@ void MacroAssembler::LoadTransitionedArrayMapConditional(
4052
4208
  Register scratch,
4053
4209
  Label* no_map_match) {
4054
4210
  // Load the global or builtins object from the current context.
4055
- movq(scratch, Operand(rsi, Context::SlotOffset(Context::GLOBAL_INDEX)));
4056
- movq(scratch, FieldOperand(scratch, GlobalObject::kGlobalContextOffset));
4211
+ movq(scratch,
4212
+ Operand(rsi, Context::SlotOffset(Context::GLOBAL_OBJECT_INDEX)));
4213
+ movq(scratch, FieldOperand(scratch, GlobalObject::kNativeContextOffset));
4057
4214
 
4058
4215
  // Check that the function's map is the same as the expected cached map.
4059
4216
  movq(scratch, Operand(scratch,
@@ -4103,10 +4260,11 @@ static const int kRegisterPassedArguments = 6;
4103
4260
 
4104
4261
  void MacroAssembler::LoadGlobalFunction(int index, Register function) {
4105
4262
  // Load the global or builtins object from the current context.
4106
- movq(function, Operand(rsi, Context::SlotOffset(Context::GLOBAL_INDEX)));
4107
- // Load the global context from the global or builtins object.
4108
- movq(function, FieldOperand(function, GlobalObject::kGlobalContextOffset));
4109
- // Load the function from the global context.
4263
+ movq(function,
4264
+ Operand(rsi, Context::SlotOffset(Context::GLOBAL_OBJECT_INDEX)));
4265
+ // Load the native context from the global or builtins object.
4266
+ movq(function, FieldOperand(function, GlobalObject::kNativeContextOffset));
4267
+ // Load the function from the native context.
4110
4268
  movq(function, Operand(function, Context::SlotOffset(index)));
4111
4269
  }
4112
4270
 
@@ -4331,7 +4489,7 @@ void MacroAssembler::EnsureNotWhite(
4331
4489
  testq(Operand(bitmap_scratch, MemoryChunk::kHeaderSize), mask_scratch);
4332
4490
  j(not_zero, &done, Label::kNear);
4333
4491
 
4334
- if (FLAG_debug_code) {
4492
+ if (emit_debug_code()) {
4335
4493
  // Check for impossible bit pattern.
4336
4494
  Label ok;
4337
4495
  push(mask_scratch);
@@ -4383,7 +4541,7 @@ void MacroAssembler::EnsureNotWhite(
4383
4541
 
4384
4542
  bind(&not_external);
4385
4543
  // Sequential string, either ASCII or UC16.
4386
- ASSERT(kAsciiStringTag == 0x04);
4544
+ ASSERT(kOneByteStringTag == 0x04);
4387
4545
  and_(length, Immediate(kStringEncodingMask));
4388
4546
  xor_(length, Immediate(kStringEncodingMask));
4389
4547
  addq(length, Immediate(0x04));
@@ -4406,49 +4564,64 @@ void MacroAssembler::EnsureNotWhite(
4406
4564
 
4407
4565
 
4408
4566
  void MacroAssembler::CheckEnumCache(Register null_value, Label* call_runtime) {
4409
- Label next;
4567
+ Label next, start;
4410
4568
  Register empty_fixed_array_value = r8;
4411
4569
  LoadRoot(empty_fixed_array_value, Heap::kEmptyFixedArrayRootIndex);
4412
- Register empty_descriptor_array_value = r9;
4413
- LoadRoot(empty_descriptor_array_value,
4414
- Heap::kEmptyDescriptorArrayRootIndex);
4415
4570
  movq(rcx, rax);
4416
- bind(&next);
4417
-
4418
- // Check that there are no elements. Register rcx contains the
4419
- // current JS object we've reached through the prototype chain.
4420
- cmpq(empty_fixed_array_value,
4421
- FieldOperand(rcx, JSObject::kElementsOffset));
4422
- j(not_equal, call_runtime);
4423
4571
 
4424
- // Check that instance descriptors are not empty so that we can
4425
- // check for an enum cache. Leave the map in rbx for the subsequent
4426
- // prototype load.
4572
+ // Check if the enum length field is properly initialized, indicating that
4573
+ // there is an enum cache.
4427
4574
  movq(rbx, FieldOperand(rcx, HeapObject::kMapOffset));
4428
- movq(rdx, FieldOperand(rbx, Map::kInstanceDescriptorsOrBitField3Offset));
4429
- JumpIfSmi(rdx, call_runtime);
4430
4575
 
4431
- // Check that there is an enum cache in the non-empty instance
4432
- // descriptors (rdx). This is the case if the next enumeration
4433
- // index field does not contain a smi.
4434
- movq(rdx, FieldOperand(rdx, DescriptorArray::kEnumerationIndexOffset));
4435
- JumpIfSmi(rdx, call_runtime);
4576
+ EnumLength(rdx, rbx);
4577
+ Cmp(rdx, Smi::FromInt(Map::kInvalidEnumCache));
4578
+ j(equal, call_runtime);
4579
+
4580
+ jmp(&start);
4581
+
4582
+ bind(&next);
4583
+
4584
+ movq(rbx, FieldOperand(rcx, HeapObject::kMapOffset));
4436
4585
 
4437
4586
  // For all objects but the receiver, check that the cache is empty.
4438
- Label check_prototype;
4439
- cmpq(rcx, rax);
4440
- j(equal, &check_prototype, Label::kNear);
4441
- movq(rdx, FieldOperand(rdx, DescriptorArray::kEnumCacheBridgeCacheOffset));
4442
- cmpq(rdx, empty_fixed_array_value);
4587
+ EnumLength(rdx, rbx);
4588
+ Cmp(rdx, Smi::FromInt(0));
4589
+ j(not_equal, call_runtime);
4590
+
4591
+ bind(&start);
4592
+
4593
+ // Check that there are no elements. Register rcx contains the current JS
4594
+ // object we've reached through the prototype chain.
4595
+ cmpq(empty_fixed_array_value,
4596
+ FieldOperand(rcx, JSObject::kElementsOffset));
4443
4597
  j(not_equal, call_runtime);
4444
4598
 
4445
- // Load the prototype from the map and loop if non-null.
4446
- bind(&check_prototype);
4447
4599
  movq(rcx, FieldOperand(rbx, Map::kPrototypeOffset));
4448
4600
  cmpq(rcx, null_value);
4449
4601
  j(not_equal, &next);
4450
4602
  }
4451
4603
 
4604
+ void MacroAssembler::TestJSArrayForAllocationSiteInfo(
4605
+ Register receiver_reg,
4606
+ Register scratch_reg) {
4607
+ Label no_info_available;
4608
+ ExternalReference new_space_start =
4609
+ ExternalReference::new_space_start(isolate());
4610
+ ExternalReference new_space_allocation_top =
4611
+ ExternalReference::new_space_allocation_top_address(isolate());
4612
+
4613
+ lea(scratch_reg, Operand(receiver_reg,
4614
+ JSArray::kSize + AllocationSiteInfo::kSize - kHeapObjectTag));
4615
+ movq(kScratchRegister, new_space_start);
4616
+ cmpq(scratch_reg, kScratchRegister);
4617
+ j(less, &no_info_available);
4618
+ cmpq(scratch_reg, ExternalOperand(new_space_allocation_top));
4619
+ j(greater, &no_info_available);
4620
+ CompareRoot(MemOperand(scratch_reg, -AllocationSiteInfo::kSize),
4621
+ Heap::kAllocationSiteInfoMapRootIndex);
4622
+ bind(&no_info_available);
4623
+ }
4624
+
4452
4625
 
4453
4626
  } } // namespace v8::internal
4454
4627