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.
- checksums.yaml +4 -4
- data/.travis.yml +1 -2
- data/Gemfile +1 -1
- data/Rakefile +6 -7
- data/lib/libv8/version.rb +1 -1
- data/vendor/v8/.gitignore +24 -3
- data/vendor/v8/AUTHORS +7 -0
- data/vendor/v8/ChangeLog +839 -0
- data/vendor/v8/DEPS +1 -1
- data/vendor/v8/Makefile.android +92 -0
- data/vendor/v8/OWNERS +11 -0
- data/vendor/v8/PRESUBMIT.py +71 -0
- data/vendor/v8/SConstruct +34 -39
- data/vendor/v8/build/android.gypi +56 -37
- data/vendor/v8/build/common.gypi +112 -30
- data/vendor/v8/build/gyp_v8 +1 -1
- data/vendor/v8/build/standalone.gypi +15 -11
- data/vendor/v8/include/v8-debug.h +9 -1
- data/vendor/v8/include/v8-preparser.h +4 -3
- data/vendor/v8/include/v8-profiler.h +25 -25
- data/vendor/v8/include/v8-testing.h +4 -3
- data/vendor/v8/include/v8.h +994 -540
- data/vendor/v8/preparser/preparser-process.cc +3 -3
- data/vendor/v8/samples/lineprocessor.cc +20 -27
- data/vendor/v8/samples/process.cc +18 -14
- data/vendor/v8/samples/shell.cc +16 -15
- data/vendor/v8/src/SConscript +15 -14
- data/vendor/v8/src/accessors.cc +169 -77
- data/vendor/v8/src/accessors.h +4 -0
- data/vendor/v8/src/allocation-inl.h +2 -2
- data/vendor/v8/src/allocation.h +7 -7
- data/vendor/v8/src/api.cc +810 -497
- data/vendor/v8/src/api.h +85 -60
- data/vendor/v8/src/arm/assembler-arm-inl.h +179 -22
- data/vendor/v8/src/arm/assembler-arm.cc +633 -264
- data/vendor/v8/src/arm/assembler-arm.h +264 -197
- data/vendor/v8/src/arm/builtins-arm.cc +117 -27
- data/vendor/v8/src/arm/code-stubs-arm.cc +1241 -700
- data/vendor/v8/src/arm/code-stubs-arm.h +35 -138
- data/vendor/v8/src/arm/codegen-arm.cc +285 -16
- data/vendor/v8/src/arm/codegen-arm.h +22 -0
- data/vendor/v8/src/arm/constants-arm.cc +5 -3
- data/vendor/v8/src/arm/constants-arm.h +24 -11
- data/vendor/v8/src/arm/debug-arm.cc +3 -3
- data/vendor/v8/src/arm/deoptimizer-arm.cc +382 -92
- data/vendor/v8/src/arm/disasm-arm.cc +61 -12
- data/vendor/v8/src/arm/frames-arm.h +0 -14
- data/vendor/v8/src/arm/full-codegen-arm.cc +332 -304
- data/vendor/v8/src/arm/ic-arm.cc +180 -259
- data/vendor/v8/src/arm/lithium-arm.cc +364 -316
- data/vendor/v8/src/arm/lithium-arm.h +512 -275
- data/vendor/v8/src/arm/lithium-codegen-arm.cc +1768 -809
- data/vendor/v8/src/arm/lithium-codegen-arm.h +97 -35
- data/vendor/v8/src/arm/lithium-gap-resolver-arm.cc +12 -5
- data/vendor/v8/src/arm/macro-assembler-arm.cc +439 -228
- data/vendor/v8/src/arm/macro-assembler-arm.h +116 -70
- data/vendor/v8/src/arm/regexp-macro-assembler-arm.cc +54 -44
- data/vendor/v8/src/arm/regexp-macro-assembler-arm.h +3 -10
- data/vendor/v8/src/arm/simulator-arm.cc +272 -238
- data/vendor/v8/src/arm/simulator-arm.h +38 -8
- data/vendor/v8/src/arm/stub-cache-arm.cc +522 -895
- data/vendor/v8/src/array.js +101 -70
- data/vendor/v8/src/assembler.cc +270 -19
- data/vendor/v8/src/assembler.h +110 -15
- data/vendor/v8/src/ast.cc +79 -69
- data/vendor/v8/src/ast.h +255 -301
- data/vendor/v8/src/atomicops.h +7 -1
- data/vendor/v8/src/atomicops_internals_tsan.h +335 -0
- data/vendor/v8/src/bootstrapper.cc +481 -418
- data/vendor/v8/src/bootstrapper.h +4 -4
- data/vendor/v8/src/builtins.cc +498 -311
- data/vendor/v8/src/builtins.h +75 -47
- data/vendor/v8/src/checks.cc +2 -1
- data/vendor/v8/src/checks.h +8 -0
- data/vendor/v8/src/code-stubs-hydrogen.cc +253 -0
- data/vendor/v8/src/code-stubs.cc +249 -84
- data/vendor/v8/src/code-stubs.h +501 -169
- data/vendor/v8/src/codegen.cc +36 -18
- data/vendor/v8/src/codegen.h +25 -3
- data/vendor/v8/src/collection.js +54 -17
- data/vendor/v8/src/compilation-cache.cc +24 -16
- data/vendor/v8/src/compilation-cache.h +15 -6
- data/vendor/v8/src/compiler.cc +497 -195
- data/vendor/v8/src/compiler.h +246 -38
- data/vendor/v8/src/contexts.cc +64 -24
- data/vendor/v8/src/contexts.h +60 -29
- data/vendor/v8/src/conversions-inl.h +24 -14
- data/vendor/v8/src/conversions.h +7 -4
- data/vendor/v8/src/counters.cc +21 -12
- data/vendor/v8/src/counters.h +44 -16
- data/vendor/v8/src/cpu-profiler.h +1 -1
- data/vendor/v8/src/d8-debug.cc +2 -2
- data/vendor/v8/src/d8-readline.cc +13 -2
- data/vendor/v8/src/d8.cc +681 -273
- data/vendor/v8/src/d8.gyp +4 -4
- data/vendor/v8/src/d8.h +38 -18
- data/vendor/v8/src/d8.js +0 -617
- data/vendor/v8/src/data-flow.h +55 -0
- data/vendor/v8/src/date.js +1 -42
- data/vendor/v8/src/dateparser-inl.h +5 -1
- data/vendor/v8/src/debug-agent.cc +10 -15
- data/vendor/v8/src/debug-debugger.js +147 -149
- data/vendor/v8/src/debug.cc +323 -164
- data/vendor/v8/src/debug.h +26 -14
- data/vendor/v8/src/deoptimizer.cc +765 -290
- data/vendor/v8/src/deoptimizer.h +130 -28
- data/vendor/v8/src/disassembler.cc +10 -4
- data/vendor/v8/src/elements-kind.cc +7 -2
- data/vendor/v8/src/elements-kind.h +19 -0
- data/vendor/v8/src/elements.cc +607 -285
- data/vendor/v8/src/elements.h +36 -13
- data/vendor/v8/src/execution.cc +52 -31
- data/vendor/v8/src/execution.h +4 -4
- data/vendor/v8/src/extensions/externalize-string-extension.cc +5 -4
- data/vendor/v8/src/extensions/gc-extension.cc +5 -1
- data/vendor/v8/src/extensions/statistics-extension.cc +153 -0
- data/vendor/v8/src/{inspector.h → extensions/statistics-extension.h} +12 -23
- data/vendor/v8/src/factory.cc +101 -134
- data/vendor/v8/src/factory.h +36 -31
- data/vendor/v8/src/flag-definitions.h +102 -25
- data/vendor/v8/src/flags.cc +9 -5
- data/vendor/v8/src/frames-inl.h +10 -0
- data/vendor/v8/src/frames.cc +116 -26
- data/vendor/v8/src/frames.h +96 -12
- data/vendor/v8/src/full-codegen.cc +219 -74
- data/vendor/v8/src/full-codegen.h +63 -21
- data/vendor/v8/src/func-name-inferrer.cc +8 -7
- data/vendor/v8/src/func-name-inferrer.h +5 -3
- data/vendor/v8/src/gdb-jit.cc +71 -57
- data/vendor/v8/src/global-handles.cc +230 -101
- data/vendor/v8/src/global-handles.h +26 -27
- data/vendor/v8/src/globals.h +17 -19
- data/vendor/v8/src/handles-inl.h +59 -12
- data/vendor/v8/src/handles.cc +180 -200
- data/vendor/v8/src/handles.h +80 -11
- data/vendor/v8/src/hashmap.h +60 -40
- data/vendor/v8/src/heap-inl.h +107 -45
- data/vendor/v8/src/heap-profiler.cc +38 -19
- data/vendor/v8/src/heap-profiler.h +24 -14
- data/vendor/v8/src/heap.cc +1123 -738
- data/vendor/v8/src/heap.h +385 -146
- data/vendor/v8/src/hydrogen-instructions.cc +700 -217
- data/vendor/v8/src/hydrogen-instructions.h +1158 -472
- data/vendor/v8/src/hydrogen.cc +3319 -1662
- data/vendor/v8/src/hydrogen.h +411 -170
- data/vendor/v8/src/ia32/assembler-ia32-inl.h +46 -16
- data/vendor/v8/src/ia32/assembler-ia32.cc +131 -61
- data/vendor/v8/src/ia32/assembler-ia32.h +115 -57
- data/vendor/v8/src/ia32/builtins-ia32.cc +99 -5
- data/vendor/v8/src/ia32/code-stubs-ia32.cc +787 -495
- data/vendor/v8/src/ia32/code-stubs-ia32.h +10 -100
- data/vendor/v8/src/ia32/codegen-ia32.cc +227 -23
- data/vendor/v8/src/ia32/codegen-ia32.h +14 -0
- data/vendor/v8/src/ia32/deoptimizer-ia32.cc +428 -87
- data/vendor/v8/src/ia32/disasm-ia32.cc +28 -1
- data/vendor/v8/src/ia32/frames-ia32.h +6 -16
- data/vendor/v8/src/ia32/full-codegen-ia32.cc +280 -272
- data/vendor/v8/src/ia32/ic-ia32.cc +150 -250
- data/vendor/v8/src/ia32/lithium-codegen-ia32.cc +1600 -517
- data/vendor/v8/src/ia32/lithium-codegen-ia32.h +90 -24
- data/vendor/v8/src/ia32/lithium-gap-resolver-ia32.cc +10 -6
- data/vendor/v8/src/ia32/lithium-gap-resolver-ia32.h +2 -2
- data/vendor/v8/src/ia32/lithium-ia32.cc +405 -302
- data/vendor/v8/src/ia32/lithium-ia32.h +526 -271
- data/vendor/v8/src/ia32/macro-assembler-ia32.cc +378 -119
- data/vendor/v8/src/ia32/macro-assembler-ia32.h +62 -28
- data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.cc +43 -30
- data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.h +2 -10
- data/vendor/v8/src/ia32/stub-cache-ia32.cc +492 -678
- data/vendor/v8/src/ic-inl.h +9 -4
- data/vendor/v8/src/ic.cc +836 -923
- data/vendor/v8/src/ic.h +228 -247
- data/vendor/v8/src/incremental-marking-inl.h +26 -30
- data/vendor/v8/src/incremental-marking.cc +276 -248
- data/vendor/v8/src/incremental-marking.h +29 -37
- data/vendor/v8/src/interface.cc +34 -25
- data/vendor/v8/src/interface.h +69 -25
- data/vendor/v8/src/interpreter-irregexp.cc +2 -2
- data/vendor/v8/src/isolate.cc +382 -76
- data/vendor/v8/src/isolate.h +109 -56
- data/vendor/v8/src/json-parser.h +217 -104
- data/vendor/v8/src/json-stringifier.h +745 -0
- data/vendor/v8/src/json.js +10 -132
- data/vendor/v8/src/jsregexp-inl.h +106 -0
- data/vendor/v8/src/jsregexp.cc +517 -285
- data/vendor/v8/src/jsregexp.h +145 -117
- data/vendor/v8/src/list-inl.h +35 -22
- data/vendor/v8/src/list.h +46 -19
- data/vendor/v8/src/lithium-allocator-inl.h +22 -2
- data/vendor/v8/src/lithium-allocator.cc +85 -70
- data/vendor/v8/src/lithium-allocator.h +21 -39
- data/vendor/v8/src/lithium.cc +259 -5
- data/vendor/v8/src/lithium.h +131 -32
- data/vendor/v8/src/liveedit-debugger.js +52 -3
- data/vendor/v8/src/liveedit.cc +393 -113
- data/vendor/v8/src/liveedit.h +7 -3
- data/vendor/v8/src/log-utils.cc +4 -2
- data/vendor/v8/src/log.cc +170 -140
- data/vendor/v8/src/log.h +62 -11
- data/vendor/v8/src/macro-assembler.h +17 -0
- data/vendor/v8/src/macros.py +2 -0
- data/vendor/v8/src/mark-compact-inl.h +3 -23
- data/vendor/v8/src/mark-compact.cc +801 -830
- data/vendor/v8/src/mark-compact.h +154 -47
- data/vendor/v8/src/marking-thread.cc +85 -0
- data/vendor/v8/src/{inspector.cc → marking-thread.h} +32 -24
- data/vendor/v8/src/math.js +12 -18
- data/vendor/v8/src/messages.cc +18 -8
- data/vendor/v8/src/messages.js +314 -261
- data/vendor/v8/src/mips/assembler-mips-inl.h +58 -6
- data/vendor/v8/src/mips/assembler-mips.cc +92 -75
- data/vendor/v8/src/mips/assembler-mips.h +54 -60
- data/vendor/v8/src/mips/builtins-mips.cc +116 -17
- data/vendor/v8/src/mips/code-stubs-mips.cc +919 -556
- data/vendor/v8/src/mips/code-stubs-mips.h +22 -131
- data/vendor/v8/src/mips/codegen-mips.cc +281 -6
- data/vendor/v8/src/mips/codegen-mips.h +22 -0
- data/vendor/v8/src/mips/constants-mips.cc +2 -0
- data/vendor/v8/src/mips/constants-mips.h +12 -2
- data/vendor/v8/src/mips/deoptimizer-mips.cc +286 -50
- data/vendor/v8/src/mips/disasm-mips.cc +13 -0
- data/vendor/v8/src/mips/full-codegen-mips.cc +297 -284
- data/vendor/v8/src/mips/ic-mips.cc +182 -263
- data/vendor/v8/src/mips/lithium-codegen-mips.cc +1208 -556
- data/vendor/v8/src/mips/lithium-codegen-mips.h +72 -19
- data/vendor/v8/src/mips/lithium-gap-resolver-mips.cc +9 -2
- data/vendor/v8/src/mips/lithium-mips.cc +290 -302
- data/vendor/v8/src/mips/lithium-mips.h +463 -266
- data/vendor/v8/src/mips/macro-assembler-mips.cc +208 -115
- data/vendor/v8/src/mips/macro-assembler-mips.h +67 -24
- data/vendor/v8/src/mips/regexp-macro-assembler-mips.cc +40 -25
- data/vendor/v8/src/mips/regexp-macro-assembler-mips.h +3 -9
- data/vendor/v8/src/mips/simulator-mips.cc +112 -40
- data/vendor/v8/src/mips/simulator-mips.h +5 -0
- data/vendor/v8/src/mips/stub-cache-mips.cc +502 -884
- data/vendor/v8/src/mirror-debugger.js +157 -30
- data/vendor/v8/src/mksnapshot.cc +88 -14
- data/vendor/v8/src/object-observe.js +235 -0
- data/vendor/v8/src/objects-debug.cc +178 -176
- data/vendor/v8/src/objects-inl.h +1333 -486
- data/vendor/v8/src/objects-printer.cc +125 -43
- data/vendor/v8/src/objects-visiting-inl.h +578 -6
- data/vendor/v8/src/objects-visiting.cc +2 -2
- data/vendor/v8/src/objects-visiting.h +172 -79
- data/vendor/v8/src/objects.cc +3533 -2885
- data/vendor/v8/src/objects.h +1352 -1131
- data/vendor/v8/src/optimizing-compiler-thread.cc +152 -0
- data/vendor/v8/src/optimizing-compiler-thread.h +111 -0
- data/vendor/v8/src/parser.cc +390 -500
- data/vendor/v8/src/parser.h +45 -33
- data/vendor/v8/src/platform-cygwin.cc +10 -21
- data/vendor/v8/src/platform-freebsd.cc +36 -41
- data/vendor/v8/src/platform-linux.cc +160 -124
- data/vendor/v8/src/platform-macos.cc +30 -27
- data/vendor/v8/src/platform-nullos.cc +17 -1
- data/vendor/v8/src/platform-openbsd.cc +19 -50
- data/vendor/v8/src/platform-posix.cc +14 -0
- data/vendor/v8/src/platform-solaris.cc +20 -53
- data/vendor/v8/src/platform-win32.cc +49 -26
- data/vendor/v8/src/platform.h +40 -1
- data/vendor/v8/src/preparser.cc +8 -5
- data/vendor/v8/src/preparser.h +2 -2
- data/vendor/v8/src/prettyprinter.cc +16 -0
- data/vendor/v8/src/prettyprinter.h +2 -0
- data/vendor/v8/src/profile-generator-inl.h +1 -0
- data/vendor/v8/src/profile-generator.cc +209 -147
- data/vendor/v8/src/profile-generator.h +15 -12
- data/vendor/v8/src/property-details.h +46 -31
- data/vendor/v8/src/property.cc +27 -46
- data/vendor/v8/src/property.h +163 -83
- data/vendor/v8/src/proxy.js +7 -2
- data/vendor/v8/src/regexp-macro-assembler-irregexp.cc +4 -13
- data/vendor/v8/src/regexp-macro-assembler-irregexp.h +1 -2
- data/vendor/v8/src/regexp-macro-assembler-tracer.cc +1 -11
- data/vendor/v8/src/regexp-macro-assembler-tracer.h +0 -1
- data/vendor/v8/src/regexp-macro-assembler.cc +31 -14
- data/vendor/v8/src/regexp-macro-assembler.h +14 -11
- data/vendor/v8/src/regexp-stack.cc +1 -0
- data/vendor/v8/src/regexp.js +9 -8
- data/vendor/v8/src/rewriter.cc +18 -7
- data/vendor/v8/src/runtime-profiler.cc +52 -43
- data/vendor/v8/src/runtime-profiler.h +0 -25
- data/vendor/v8/src/runtime.cc +2006 -2023
- data/vendor/v8/src/runtime.h +56 -49
- data/vendor/v8/src/safepoint-table.cc +12 -18
- data/vendor/v8/src/safepoint-table.h +11 -8
- data/vendor/v8/src/scanner.cc +1 -0
- data/vendor/v8/src/scanner.h +4 -10
- data/vendor/v8/src/scopeinfo.cc +35 -9
- data/vendor/v8/src/scopeinfo.h +64 -3
- data/vendor/v8/src/scopes.cc +251 -156
- data/vendor/v8/src/scopes.h +61 -27
- data/vendor/v8/src/serialize.cc +348 -396
- data/vendor/v8/src/serialize.h +125 -114
- data/vendor/v8/src/small-pointer-list.h +11 -11
- data/vendor/v8/src/{smart-array-pointer.h → smart-pointers.h} +64 -15
- data/vendor/v8/src/snapshot-common.cc +64 -15
- data/vendor/v8/src/snapshot-empty.cc +7 -1
- data/vendor/v8/src/snapshot.h +9 -2
- data/vendor/v8/src/spaces-inl.h +17 -0
- data/vendor/v8/src/spaces.cc +477 -183
- data/vendor/v8/src/spaces.h +238 -58
- data/vendor/v8/src/splay-tree-inl.h +8 -7
- data/vendor/v8/src/splay-tree.h +24 -10
- data/vendor/v8/src/store-buffer.cc +12 -5
- data/vendor/v8/src/store-buffer.h +2 -4
- data/vendor/v8/src/string-search.h +22 -6
- data/vendor/v8/src/string-stream.cc +11 -8
- data/vendor/v8/src/string.js +47 -15
- data/vendor/v8/src/stub-cache.cc +461 -224
- data/vendor/v8/src/stub-cache.h +164 -102
- data/vendor/v8/src/sweeper-thread.cc +105 -0
- data/vendor/v8/src/sweeper-thread.h +81 -0
- data/vendor/v8/src/token.h +1 -0
- data/vendor/v8/src/transitions-inl.h +220 -0
- data/vendor/v8/src/transitions.cc +160 -0
- data/vendor/v8/src/transitions.h +207 -0
- data/vendor/v8/src/type-info.cc +182 -181
- data/vendor/v8/src/type-info.h +31 -19
- data/vendor/v8/src/unicode-inl.h +62 -106
- data/vendor/v8/src/unicode.cc +57 -67
- data/vendor/v8/src/unicode.h +45 -91
- data/vendor/v8/src/uri.js +57 -29
- data/vendor/v8/src/utils.h +105 -5
- data/vendor/v8/src/v8-counters.cc +54 -11
- data/vendor/v8/src/v8-counters.h +134 -19
- data/vendor/v8/src/v8.cc +29 -29
- data/vendor/v8/src/v8.h +1 -0
- data/vendor/v8/src/v8conversions.cc +26 -22
- data/vendor/v8/src/v8globals.h +56 -43
- data/vendor/v8/src/v8natives.js +83 -30
- data/vendor/v8/src/v8threads.cc +42 -21
- data/vendor/v8/src/v8threads.h +4 -1
- data/vendor/v8/src/v8utils.cc +9 -93
- data/vendor/v8/src/v8utils.h +37 -33
- data/vendor/v8/src/variables.cc +6 -3
- data/vendor/v8/src/variables.h +6 -13
- data/vendor/v8/src/version.cc +2 -2
- data/vendor/v8/src/vm-state-inl.h +11 -0
- data/vendor/v8/src/x64/assembler-x64-inl.h +39 -8
- data/vendor/v8/src/x64/assembler-x64.cc +78 -64
- data/vendor/v8/src/x64/assembler-x64.h +38 -33
- data/vendor/v8/src/x64/builtins-x64.cc +105 -7
- data/vendor/v8/src/x64/code-stubs-x64.cc +790 -413
- data/vendor/v8/src/x64/code-stubs-x64.h +10 -106
- data/vendor/v8/src/x64/codegen-x64.cc +210 -8
- data/vendor/v8/src/x64/codegen-x64.h +20 -1
- data/vendor/v8/src/x64/deoptimizer-x64.cc +336 -75
- data/vendor/v8/src/x64/disasm-x64.cc +15 -0
- data/vendor/v8/src/x64/frames-x64.h +0 -14
- data/vendor/v8/src/x64/full-codegen-x64.cc +293 -270
- data/vendor/v8/src/x64/ic-x64.cc +153 -251
- data/vendor/v8/src/x64/lithium-codegen-x64.cc +1379 -531
- data/vendor/v8/src/x64/lithium-codegen-x64.h +67 -23
- data/vendor/v8/src/x64/lithium-gap-resolver-x64.cc +2 -2
- data/vendor/v8/src/x64/lithium-x64.cc +349 -289
- data/vendor/v8/src/x64/lithium-x64.h +460 -250
- data/vendor/v8/src/x64/macro-assembler-x64.cc +350 -177
- data/vendor/v8/src/x64/macro-assembler-x64.h +67 -49
- data/vendor/v8/src/x64/regexp-macro-assembler-x64.cc +46 -33
- data/vendor/v8/src/x64/regexp-macro-assembler-x64.h +2 -3
- data/vendor/v8/src/x64/stub-cache-x64.cc +484 -653
- data/vendor/v8/src/zone-inl.h +9 -27
- data/vendor/v8/src/zone.cc +5 -5
- data/vendor/v8/src/zone.h +53 -27
- data/vendor/v8/test/benchmarks/testcfg.py +5 -0
- data/vendor/v8/test/cctest/cctest.cc +4 -0
- data/vendor/v8/test/cctest/cctest.gyp +3 -1
- data/vendor/v8/test/cctest/cctest.h +57 -9
- data/vendor/v8/test/cctest/cctest.status +15 -15
- data/vendor/v8/test/cctest/test-accessors.cc +26 -0
- data/vendor/v8/test/cctest/test-alloc.cc +22 -30
- data/vendor/v8/test/cctest/test-api.cc +1943 -314
- data/vendor/v8/test/cctest/test-assembler-arm.cc +133 -13
- data/vendor/v8/test/cctest/test-assembler-ia32.cc +1 -1
- data/vendor/v8/test/cctest/test-assembler-mips.cc +12 -0
- data/vendor/v8/test/cctest/test-ast.cc +4 -2
- data/vendor/v8/test/cctest/test-compiler.cc +61 -29
- data/vendor/v8/test/cctest/test-dataflow.cc +2 -2
- data/vendor/v8/test/cctest/test-debug.cc +212 -33
- data/vendor/v8/test/cctest/test-decls.cc +257 -11
- data/vendor/v8/test/cctest/test-dictionary.cc +24 -10
- data/vendor/v8/test/cctest/test-disasm-arm.cc +118 -1
- data/vendor/v8/test/cctest/test-disasm-ia32.cc +3 -2
- data/vendor/v8/test/cctest/test-flags.cc +14 -1
- data/vendor/v8/test/cctest/test-func-name-inference.cc +7 -4
- data/vendor/v8/test/cctest/test-global-object.cc +51 -0
- data/vendor/v8/test/cctest/test-hashing.cc +32 -23
- data/vendor/v8/test/cctest/test-heap-profiler.cc +131 -77
- data/vendor/v8/test/cctest/test-heap.cc +1084 -143
- data/vendor/v8/test/cctest/test-list.cc +1 -1
- data/vendor/v8/test/cctest/test-liveedit.cc +3 -2
- data/vendor/v8/test/cctest/test-lockers.cc +12 -13
- data/vendor/v8/test/cctest/test-log.cc +10 -8
- data/vendor/v8/test/cctest/test-macro-assembler-x64.cc +2 -2
- data/vendor/v8/test/cctest/test-mark-compact.cc +44 -22
- data/vendor/v8/test/cctest/test-object-observe.cc +434 -0
- data/vendor/v8/test/cctest/test-parsing.cc +86 -39
- data/vendor/v8/test/cctest/test-platform-linux.cc +6 -0
- data/vendor/v8/test/cctest/test-platform-win32.cc +7 -0
- data/vendor/v8/test/cctest/test-random.cc +5 -4
- data/vendor/v8/test/cctest/test-regexp.cc +137 -101
- data/vendor/v8/test/cctest/test-serialize.cc +150 -230
- data/vendor/v8/test/cctest/test-sockets.cc +1 -1
- data/vendor/v8/test/cctest/test-spaces.cc +139 -0
- data/vendor/v8/test/cctest/test-strings.cc +736 -74
- data/vendor/v8/test/cctest/test-thread-termination.cc +10 -11
- data/vendor/v8/test/cctest/test-threads.cc +4 -4
- data/vendor/v8/test/cctest/test-utils.cc +16 -0
- data/vendor/v8/test/cctest/test-weakmaps.cc +7 -3
- data/vendor/v8/test/cctest/testcfg.py +64 -5
- data/vendor/v8/test/es5conform/testcfg.py +5 -0
- data/vendor/v8/test/message/message.status +1 -1
- data/vendor/v8/test/message/overwritten-builtins.out +3 -0
- data/vendor/v8/test/message/testcfg.py +89 -8
- data/vendor/v8/test/message/try-catch-finally-no-message.out +26 -26
- data/vendor/v8/test/mjsunit/accessor-map-sharing.js +18 -2
- data/vendor/v8/test/mjsunit/allocation-site-info.js +126 -0
- data/vendor/v8/test/mjsunit/array-bounds-check-removal.js +62 -1
- data/vendor/v8/test/mjsunit/array-iteration.js +1 -1
- data/vendor/v8/test/mjsunit/array-literal-transitions.js +2 -0
- data/vendor/v8/test/mjsunit/array-natives-elements.js +317 -0
- data/vendor/v8/test/mjsunit/array-reduce.js +8 -8
- data/vendor/v8/test/mjsunit/array-slice.js +12 -0
- data/vendor/v8/test/mjsunit/array-store-and-grow.js +4 -1
- data/vendor/v8/test/mjsunit/assert-opt-and-deopt.js +1 -1
- data/vendor/v8/test/mjsunit/bugs/bug-2337.js +53 -0
- data/vendor/v8/test/mjsunit/compare-known-objects-slow.js +69 -0
- data/vendor/v8/test/mjsunit/compiler/alloc-object-huge.js +3 -1
- data/vendor/v8/test/mjsunit/compiler/inline-accessors.js +368 -0
- data/vendor/v8/test/mjsunit/compiler/inline-arguments.js +87 -1
- data/vendor/v8/test/mjsunit/compiler/inline-closures.js +49 -0
- data/vendor/v8/test/mjsunit/compiler/inline-construct.js +55 -43
- data/vendor/v8/test/mjsunit/compiler/inline-literals.js +39 -0
- data/vendor/v8/test/mjsunit/compiler/multiply-add.js +69 -0
- data/vendor/v8/test/mjsunit/compiler/optimized-closures.js +57 -0
- data/vendor/v8/test/mjsunit/compiler/parallel-proto-change.js +44 -0
- data/vendor/v8/test/mjsunit/compiler/property-static.js +69 -0
- data/vendor/v8/test/mjsunit/compiler/proto-chain-constant.js +55 -0
- data/vendor/v8/test/mjsunit/compiler/proto-chain-load.js +44 -0
- data/vendor/v8/test/mjsunit/compiler/regress-gvn.js +3 -2
- data/vendor/v8/test/mjsunit/compiler/regress-or.js +6 -2
- data/vendor/v8/test/mjsunit/compiler/rotate.js +224 -0
- data/vendor/v8/test/mjsunit/compiler/uint32.js +173 -0
- data/vendor/v8/test/mjsunit/count-based-osr.js +2 -1
- data/vendor/v8/test/mjsunit/d8-os.js +3 -3
- data/vendor/v8/test/mjsunit/date-parse.js +3 -0
- data/vendor/v8/test/mjsunit/date.js +22 -0
- data/vendor/v8/test/mjsunit/debug-break-inline.js +1 -0
- data/vendor/v8/test/mjsunit/debug-evaluate-locals-optimized-double.js +22 -12
- data/vendor/v8/test/mjsunit/debug-evaluate-locals-optimized.js +21 -10
- data/vendor/v8/test/mjsunit/debug-liveedit-compile-error.js +60 -0
- data/vendor/v8/test/mjsunit/debug-liveedit-double-call.js +142 -0
- data/vendor/v8/test/mjsunit/debug-liveedit-literals.js +94 -0
- data/vendor/v8/test/mjsunit/debug-liveedit-restart-frame.js +153 -0
- data/vendor/v8/test/mjsunit/debug-multiple-breakpoints.js +1 -1
- data/vendor/v8/test/mjsunit/debug-script-breakpoints-closure.js +67 -0
- data/vendor/v8/test/mjsunit/debug-script-breakpoints-nested.js +82 -0
- data/vendor/v8/test/mjsunit/debug-script.js +4 -2
- data/vendor/v8/test/mjsunit/debug-set-variable-value.js +308 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part1.js +190 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part2.js +83 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part3.js +80 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part4.js +80 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part5.js +77 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part6.js +79 -0
- data/vendor/v8/test/mjsunit/debug-stepout-scope-part7.js +79 -0
- data/vendor/v8/test/mjsunit/{debug-stepout-scope.js → debug-stepout-scope-part8.js} +0 -189
- data/vendor/v8/test/mjsunit/delete-non-configurable.js +74 -0
- data/vendor/v8/test/mjsunit/deopt-minus-zero.js +56 -0
- data/vendor/v8/test/mjsunit/elements-kind.js +6 -4
- data/vendor/v8/test/mjsunit/elements-length-no-holey.js +33 -0
- data/vendor/v8/test/mjsunit/elements-transition-hoisting.js +46 -19
- data/vendor/v8/test/mjsunit/error-accessors.js +54 -0
- data/vendor/v8/test/mjsunit/error-constructors.js +1 -14
- data/vendor/v8/test/mjsunit/error-tostring.js +8 -0
- data/vendor/v8/test/mjsunit/eval-stack-trace.js +204 -0
- data/vendor/v8/test/mjsunit/external-array.js +364 -1
- data/vendor/v8/test/mjsunit/fast-array-length.js +37 -0
- data/vendor/v8/test/mjsunit/fast-non-keyed.js +113 -0
- data/vendor/v8/test/mjsunit/fast-prototype.js +117 -0
- data/vendor/v8/test/mjsunit/function-call.js +14 -18
- data/vendor/v8/test/mjsunit/fuzz-natives-part1.js +230 -0
- data/vendor/v8/test/mjsunit/fuzz-natives-part2.js +229 -0
- data/vendor/v8/test/mjsunit/fuzz-natives-part3.js +229 -0
- data/vendor/v8/test/mjsunit/{fuzz-natives.js → fuzz-natives-part4.js} +12 -2
- data/vendor/v8/test/mjsunit/generated-transition-stub.js +218 -0
- data/vendor/v8/test/mjsunit/greedy.js +1 -1
- data/vendor/v8/test/mjsunit/harmony/block-conflicts.js +2 -1
- data/vendor/v8/test/mjsunit/harmony/block-let-crankshaft.js +1 -1
- data/vendor/v8/test/mjsunit/harmony/collections.js +69 -11
- data/vendor/v8/test/mjsunit/harmony/debug-blockscopes.js +2 -2
- data/vendor/v8/test/mjsunit/harmony/module-linking.js +180 -3
- data/vendor/v8/test/mjsunit/harmony/module-parsing.js +31 -0
- data/vendor/v8/test/mjsunit/harmony/module-recompile.js +87 -0
- data/vendor/v8/test/mjsunit/harmony/module-resolution.js +15 -2
- data/vendor/v8/test/mjsunit/harmony/object-observe.js +1056 -0
- data/vendor/v8/test/mjsunit/harmony/proxies-json.js +178 -0
- data/vendor/v8/test/mjsunit/harmony/proxies.js +25 -10
- data/vendor/v8/test/mjsunit/json-parser-recursive.js +33 -0
- data/vendor/v8/test/mjsunit/json-stringify-recursive.js +52 -0
- data/vendor/v8/test/mjsunit/json.js +38 -2
- data/vendor/v8/test/mjsunit/json2.js +153 -0
- data/vendor/v8/test/mjsunit/limit-locals.js +5 -4
- data/vendor/v8/test/mjsunit/manual-parallel-recompile.js +79 -0
- data/vendor/v8/test/mjsunit/math-exp-precision.js +64 -0
- data/vendor/v8/test/mjsunit/math-floor-negative.js +59 -0
- data/vendor/v8/test/mjsunit/math-floor-of-div-minus-zero.js +41 -0
- data/vendor/v8/test/mjsunit/math-floor-of-div-nosudiv.js +288 -0
- data/vendor/v8/test/mjsunit/math-floor-of-div.js +81 -9
- data/vendor/v8/test/mjsunit/{math-floor.js → math-floor-part1.js} +1 -72
- data/vendor/v8/test/mjsunit/math-floor-part2.js +76 -0
- data/vendor/v8/test/mjsunit/math-floor-part3.js +78 -0
- data/vendor/v8/test/mjsunit/math-floor-part4.js +76 -0
- data/vendor/v8/test/mjsunit/mirror-object.js +43 -9
- data/vendor/v8/test/mjsunit/mjsunit.js +1 -1
- data/vendor/v8/test/mjsunit/mjsunit.status +52 -27
- data/vendor/v8/test/mjsunit/mul-exhaustive-part1.js +491 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part10.js +470 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part2.js +525 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part3.js +532 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part4.js +509 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part5.js +505 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part6.js +554 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part7.js +497 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part8.js +526 -0
- data/vendor/v8/test/mjsunit/mul-exhaustive-part9.js +533 -0
- data/vendor/v8/test/mjsunit/new-function.js +34 -0
- data/vendor/v8/test/mjsunit/numops-fuzz-part1.js +1172 -0
- data/vendor/v8/test/mjsunit/numops-fuzz-part2.js +1178 -0
- data/vendor/v8/test/mjsunit/numops-fuzz-part3.js +1178 -0
- data/vendor/v8/test/mjsunit/numops-fuzz-part4.js +1177 -0
- data/vendor/v8/test/mjsunit/object-define-property.js +107 -2
- data/vendor/v8/test/mjsunit/override-read-only-property.js +6 -4
- data/vendor/v8/test/mjsunit/packed-elements.js +2 -2
- data/vendor/v8/test/mjsunit/parse-int-float.js +4 -4
- data/vendor/v8/test/mjsunit/pixel-array-rounding.js +1 -1
- data/vendor/v8/test/mjsunit/readonly.js +228 -0
- data/vendor/v8/test/mjsunit/regexp-capture-3.js +16 -18
- data/vendor/v8/test/mjsunit/regexp-capture.js +2 -0
- data/vendor/v8/test/mjsunit/regexp-global.js +122 -0
- data/vendor/v8/test/mjsunit/regexp-results-cache.js +78 -0
- data/vendor/v8/test/mjsunit/regress/regress-1117.js +12 -3
- data/vendor/v8/test/mjsunit/regress/regress-1118.js +1 -1
- data/vendor/v8/test/mjsunit/regress/regress-115100.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-1199637.js +1 -3
- data/vendor/v8/test/mjsunit/regress/regress-121407.js +1 -1
- data/vendor/v8/test/mjsunit/regress/regress-131923.js +30 -0
- data/vendor/v8/test/mjsunit/regress/regress-131994.js +70 -0
- data/vendor/v8/test/mjsunit/regress/regress-133211.js +35 -0
- data/vendor/v8/test/mjsunit/regress/regress-133211b.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-136048.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-137768.js +73 -0
- data/vendor/v8/test/mjsunit/regress/regress-143967.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-145201.js +107 -0
- data/vendor/v8/test/mjsunit/regress/regress-147497.js +45 -0
- data/vendor/v8/test/mjsunit/regress/regress-148378.js +38 -0
- data/vendor/v8/test/mjsunit/regress/regress-1563.js +1 -1
- data/vendor/v8/test/mjsunit/regress/regress-1591.js +48 -0
- data/vendor/v8/test/mjsunit/regress/regress-164442.js +45 -0
- data/vendor/v8/test/mjsunit/regress/regress-165637.js +61 -0
- data/vendor/v8/test/mjsunit/regress/regress-166379.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-166553.js +33 -0
- data/vendor/v8/test/mjsunit/regress/regress-1692.js +1 -1
- data/vendor/v8/test/mjsunit/regress/regress-171641.js +40 -0
- data/vendor/v8/test/mjsunit/regress/regress-1980.js +1 -1
- data/vendor/v8/test/mjsunit/regress/regress-2073.js +99 -0
- data/vendor/v8/test/mjsunit/regress/regress-2119.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-2156.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-2163.js +70 -0
- data/vendor/v8/test/mjsunit/regress/regress-2170.js +58 -0
- data/vendor/v8/test/mjsunit/regress/regress-2172.js +35 -0
- data/vendor/v8/test/mjsunit/regress/regress-2185-2.js +145 -0
- data/vendor/v8/test/mjsunit/regress/regress-2185.js +38 -0
- data/vendor/v8/test/mjsunit/regress/regress-2186.js +49 -0
- data/vendor/v8/test/mjsunit/regress/regress-2193.js +58 -0
- data/vendor/v8/test/mjsunit/regress/regress-2219.js +32 -0
- data/vendor/v8/test/mjsunit/regress/regress-2225.js +65 -0
- data/vendor/v8/test/mjsunit/regress/regress-2226.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-2234.js +41 -0
- data/vendor/v8/test/mjsunit/regress/regress-2243.js +31 -0
- data/vendor/v8/test/mjsunit/regress/regress-2249.js +33 -0
- data/vendor/v8/test/mjsunit/regress/regress-2250.js +68 -0
- data/vendor/v8/test/mjsunit/regress/regress-2261.js +113 -0
- data/vendor/v8/test/mjsunit/regress/regress-2263.js +30 -0
- data/vendor/v8/test/mjsunit/regress/regress-2284.js +32 -0
- data/vendor/v8/test/mjsunit/regress/regress-2285.js +32 -0
- data/vendor/v8/test/mjsunit/regress/regress-2286.js +32 -0
- data/vendor/v8/test/mjsunit/regress/regress-2289.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-2291.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-2294.js +70 -0
- data/vendor/v8/test/mjsunit/regress/regress-2296.js +40 -0
- data/vendor/v8/test/mjsunit/regress/regress-2315.js +40 -0
- data/vendor/v8/test/mjsunit/regress/regress-2318.js +66 -0
- data/vendor/v8/test/mjsunit/regress/regress-2322.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-2326.js +54 -0
- data/vendor/v8/test/mjsunit/regress/regress-2336.js +53 -0
- data/vendor/v8/test/mjsunit/regress/regress-2339.js +59 -0
- data/vendor/v8/test/mjsunit/regress/regress-2346.js +123 -0
- data/vendor/v8/test/mjsunit/regress/regress-2373.js +29 -0
- data/vendor/v8/test/mjsunit/regress/regress-2374.js +33 -0
- data/vendor/v8/test/mjsunit/regress/regress-2398.js +41 -0
- data/vendor/v8/test/mjsunit/regress/regress-2410.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-2416.js +75 -0
- data/vendor/v8/test/mjsunit/regress/regress-2419.js +37 -0
- data/vendor/v8/test/mjsunit/regress/regress-2433.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-2437.js +156 -0
- data/vendor/v8/test/mjsunit/regress/regress-2438.js +52 -0
- data/vendor/v8/test/mjsunit/regress/regress-2443.js +129 -0
- data/vendor/v8/test/mjsunit/regress/regress-2444.js +120 -0
- data/vendor/v8/test/mjsunit/regress/regress-2489.js +50 -0
- data/vendor/v8/test/mjsunit/regress/regress-2499.js +40 -0
- data/vendor/v8/test/mjsunit/regress/regress-334.js +1 -1
- data/vendor/v8/test/mjsunit/regress/regress-492.js +39 -1
- data/vendor/v8/test/mjsunit/regress/regress-builtin-array-op.js +38 -0
- data/vendor/v8/test/mjsunit/regress/regress-cnlt-elements.js +43 -0
- data/vendor/v8/test/mjsunit/regress/regress-cnlt-enum-indices.js +45 -0
- data/vendor/v8/test/mjsunit/regress/regress-cntl-descriptors-enum.js +46 -0
- data/vendor/v8/test/mjsunit/regress/regress-convert-enum.js +60 -0
- data/vendor/v8/test/mjsunit/regress/regress-convert-enum2.js +46 -0
- data/vendor/v8/test/mjsunit/regress/regress-convert-transition.js +40 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-119926.js +3 -1
- data/vendor/v8/test/mjsunit/regress/regress-crbug-125148.js +90 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-134055.js +63 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-134609.js +59 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-135008.js +45 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-135066.js +55 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-137689.js +47 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-138887.js +48 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-140083.js +44 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-142087.js +38 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-142218.js +44 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-145961.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-146910.js +33 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-147475.js +48 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-148376.js +35 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-150545.js +53 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-150729.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-157019.js +54 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-157520.js +38 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-158185.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-160010.js +35 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-162085.js +71 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-168545.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-170856.js +33 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-172345.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-173974.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-crbug-18639.js +9 -5
- data/vendor/v8/test/mjsunit/regress/regress-debug-code-recompilation.js +2 -1
- data/vendor/v8/test/mjsunit/regress/regress-deep-proto.js +45 -0
- data/vendor/v8/test/mjsunit/regress/regress-delete-empty-double.js +40 -0
- data/vendor/v8/test/mjsunit/regress/regress-iteration-order.js +42 -0
- data/vendor/v8/test/mjsunit/regress/regress-json-stringify-gc.js +41 -0
- data/vendor/v8/test/mjsunit/regress/regress-latin-1.js +78 -0
- data/vendor/v8/test/mjsunit/regress/regress-load-elements.js +49 -0
- data/vendor/v8/test/mjsunit/regress/regress-observe-empty-double-array.js +38 -0
- data/vendor/v8/test/mjsunit/regress/regress-undefined-store-keyed-fast-element.js +37 -0
- data/vendor/v8/test/mjsunit/shift-for-integer-div.js +59 -0
- data/vendor/v8/test/mjsunit/stack-traces-gc.js +119 -0
- data/vendor/v8/test/mjsunit/stack-traces-overflow.js +122 -0
- data/vendor/v8/test/mjsunit/stack-traces.js +39 -1
- data/vendor/v8/test/mjsunit/str-to-num.js +7 -2
- data/vendor/v8/test/mjsunit/strict-mode.js +36 -11
- data/vendor/v8/test/mjsunit/string-charcodeat.js +3 -0
- data/vendor/v8/test/mjsunit/string-natives.js +72 -0
- data/vendor/v8/test/mjsunit/string-split.js +17 -0
- data/vendor/v8/test/mjsunit/testcfg.py +76 -6
- data/vendor/v8/test/mjsunit/tools/tickprocessor.js +4 -1
- data/vendor/v8/test/mjsunit/try-finally-continue.js +72 -0
- data/vendor/v8/test/mjsunit/typed-array-slice.js +61 -0
- data/vendor/v8/test/mjsunit/unbox-double-arrays.js +2 -0
- data/vendor/v8/test/mjsunit/uri.js +12 -0
- data/vendor/v8/test/mjsunit/with-readonly.js +4 -2
- data/vendor/v8/test/mozilla/mozilla.status +19 -113
- data/vendor/v8/test/mozilla/testcfg.py +122 -3
- data/vendor/v8/test/preparser/preparser.status +5 -0
- data/vendor/v8/test/preparser/strict-identifiers.pyt +1 -1
- data/vendor/v8/test/preparser/testcfg.py +101 -5
- data/vendor/v8/test/sputnik/sputnik.status +1 -1
- data/vendor/v8/test/sputnik/testcfg.py +5 -0
- data/vendor/v8/test/test262/README +2 -2
- data/vendor/v8/test/test262/test262.status +13 -36
- data/vendor/v8/test/test262/testcfg.py +102 -8
- data/vendor/v8/tools/android-build.sh +0 -0
- data/vendor/v8/tools/android-ll-prof.sh +69 -0
- data/vendor/v8/tools/android-run.py +109 -0
- data/vendor/v8/tools/android-sync.sh +105 -0
- data/vendor/v8/tools/bash-completion.sh +0 -0
- data/vendor/v8/tools/check-static-initializers.sh +0 -0
- data/vendor/v8/tools/common-includes.sh +15 -22
- data/vendor/v8/tools/disasm.py +4 -4
- data/vendor/v8/tools/fuzz-harness.sh +0 -0
- data/vendor/v8/tools/gen-postmortem-metadata.py +6 -8
- data/vendor/v8/tools/grokdump.py +404 -129
- data/vendor/v8/tools/gyp/v8.gyp +105 -43
- data/vendor/v8/tools/linux-tick-processor +5 -5
- data/vendor/v8/tools/ll_prof.py +75 -15
- data/vendor/v8/tools/merge-to-branch.sh +2 -2
- data/vendor/v8/tools/plot-timer-events +70 -0
- data/vendor/v8/tools/plot-timer-events.js +510 -0
- data/vendor/v8/tools/presubmit.py +1 -0
- data/vendor/v8/tools/push-to-trunk.sh +14 -4
- data/vendor/v8/tools/run-llprof.sh +69 -0
- data/vendor/v8/tools/run-tests.py +372 -0
- data/vendor/v8/tools/run-valgrind.py +1 -1
- data/vendor/v8/tools/status-file-converter.py +39 -0
- data/vendor/v8/tools/test-server.py +224 -0
- data/vendor/v8/tools/test-wrapper-gypbuild.py +13 -16
- data/vendor/v8/tools/test.py +10 -19
- data/vendor/v8/tools/testrunner/README +174 -0
- data/vendor/v8/tools/testrunner/__init__.py +26 -0
- data/vendor/v8/tools/testrunner/local/__init__.py +26 -0
- data/vendor/v8/tools/testrunner/local/commands.py +153 -0
- data/vendor/v8/tools/testrunner/local/execution.py +182 -0
- data/vendor/v8/tools/testrunner/local/old_statusfile.py +460 -0
- data/vendor/v8/tools/testrunner/local/progress.py +238 -0
- data/vendor/v8/tools/testrunner/local/statusfile.py +145 -0
- data/vendor/v8/tools/testrunner/local/testsuite.py +187 -0
- data/vendor/v8/tools/testrunner/local/utils.py +108 -0
- data/vendor/v8/tools/testrunner/local/verbose.py +99 -0
- data/vendor/v8/tools/testrunner/network/__init__.py +26 -0
- data/vendor/v8/tools/testrunner/network/distro.py +90 -0
- data/vendor/v8/tools/testrunner/network/endpoint.py +124 -0
- data/vendor/v8/tools/testrunner/network/network_execution.py +253 -0
- data/vendor/v8/tools/testrunner/network/perfdata.py +120 -0
- data/vendor/v8/tools/testrunner/objects/__init__.py +26 -0
- data/vendor/v8/tools/testrunner/objects/context.py +50 -0
- data/vendor/v8/tools/testrunner/objects/output.py +60 -0
- data/vendor/v8/tools/testrunner/objects/peer.py +80 -0
- data/vendor/v8/tools/testrunner/objects/testcase.py +83 -0
- data/vendor/v8/tools/testrunner/objects/workpacket.py +90 -0
- data/vendor/v8/tools/testrunner/server/__init__.py +26 -0
- data/vendor/v8/tools/testrunner/server/compression.py +111 -0
- data/vendor/v8/tools/testrunner/server/constants.py +51 -0
- data/vendor/v8/tools/testrunner/server/daemon.py +147 -0
- data/vendor/v8/tools/testrunner/server/local_handler.py +119 -0
- data/vendor/v8/tools/testrunner/server/main.py +245 -0
- data/vendor/v8/tools/testrunner/server/presence_handler.py +120 -0
- data/vendor/v8/tools/testrunner/server/signatures.py +63 -0
- data/vendor/v8/tools/testrunner/server/status_handler.py +112 -0
- data/vendor/v8/tools/testrunner/server/work_handler.py +150 -0
- data/vendor/v8/tools/tick-processor.html +168 -0
- data/vendor/v8/tools/tickprocessor-driver.js +5 -3
- data/vendor/v8/tools/tickprocessor.js +58 -15
- metadata +534 -30
- data/patches/add-freebsd9-and-freebsd10-to-gyp-GetFlavor.patch +0 -11
- data/patches/do-not-imply-vfp3-and-armv7.patch +0 -44
- data/patches/fPIC-on-x64.patch +0 -14
- data/vendor/v8/src/liveobjectlist-inl.h +0 -126
- data/vendor/v8/src/liveobjectlist.cc +0 -2631
- data/vendor/v8/src/liveobjectlist.h +0 -319
- data/vendor/v8/test/mjsunit/mul-exhaustive.js +0 -4629
- data/vendor/v8/test/mjsunit/numops-fuzz.js +0 -4609
- data/vendor/v8/test/mjsunit/regress/regress-1969.js +0 -5045
@@ -35,6 +35,7 @@
|
|
35
35
|
#include "code-stubs.h"
|
36
36
|
#include "codegen.h"
|
37
37
|
#include "compiler.h"
|
38
|
+
#include "data-flow.h"
|
38
39
|
|
39
40
|
namespace v8 {
|
40
41
|
namespace internal {
|
@@ -48,7 +49,9 @@ class JumpPatchSite;
|
|
48
49
|
// debugger to piggybag on.
|
49
50
|
class BreakableStatementChecker: public AstVisitor {
|
50
51
|
public:
|
51
|
-
BreakableStatementChecker() : is_breakable_(false) {
|
52
|
+
BreakableStatementChecker() : is_breakable_(false) {
|
53
|
+
InitializeAstVisitor();
|
54
|
+
}
|
52
55
|
|
53
56
|
void Check(Statement* stmt);
|
54
57
|
void Check(Expression* stmt);
|
@@ -63,6 +66,7 @@ class BreakableStatementChecker: public AstVisitor {
|
|
63
66
|
|
64
67
|
bool is_breakable_;
|
65
68
|
|
69
|
+
DEFINE_AST_VISITOR_SUBCLASS_MEMBERS();
|
66
70
|
DISALLOW_COPY_AND_ASSIGN(BreakableStatementChecker);
|
67
71
|
};
|
68
72
|
|
@@ -86,11 +90,18 @@ class FullCodeGenerator: public AstVisitor {
|
|
86
90
|
globals_(NULL),
|
87
91
|
context_(NULL),
|
88
92
|
bailout_entries_(info->HasDeoptimizationSupport()
|
89
|
-
? info->function()->ast_node_count() : 0
|
90
|
-
|
93
|
+
? info->function()->ast_node_count() : 0,
|
94
|
+
info->zone()),
|
95
|
+
stack_checks_(2, info->zone()), // There's always at least one.
|
91
96
|
type_feedback_cells_(info->HasDeoptimizationSupport()
|
92
|
-
? info->function()->ast_node_count() : 0
|
93
|
-
|
97
|
+
? info->function()->ast_node_count() : 0,
|
98
|
+
info->zone()),
|
99
|
+
ic_total_count_(0),
|
100
|
+
zone_(info->zone()) {
|
101
|
+
Initialize();
|
102
|
+
}
|
103
|
+
|
104
|
+
void Initialize();
|
94
105
|
|
95
106
|
static bool MakeCode(CompilationInfo* info);
|
96
107
|
|
@@ -108,6 +119,23 @@ class FullCodeGenerator: public AstVisitor {
|
|
108
119
|
return NULL;
|
109
120
|
}
|
110
121
|
|
122
|
+
Zone* zone() const { return zone_; }
|
123
|
+
|
124
|
+
static const int kMaxBackEdgeWeight = 127;
|
125
|
+
|
126
|
+
#if V8_TARGET_ARCH_IA32
|
127
|
+
static const int kBackEdgeDistanceUnit = 100;
|
128
|
+
#elif V8_TARGET_ARCH_X64
|
129
|
+
static const int kBackEdgeDistanceUnit = 162;
|
130
|
+
#elif V8_TARGET_ARCH_ARM
|
131
|
+
static const int kBackEdgeDistanceUnit = 142;
|
132
|
+
#elif V8_TARGET_ARCH_MIPS
|
133
|
+
static const int kBackEdgeDistanceUnit = 142;
|
134
|
+
#else
|
135
|
+
#error Unsupported target architecture.
|
136
|
+
#endif
|
137
|
+
|
138
|
+
|
111
139
|
private:
|
112
140
|
class Breakable;
|
113
141
|
class Iteration;
|
@@ -236,7 +264,7 @@ class FullCodeGenerator: public AstVisitor {
|
|
236
264
|
// The finally block of a try/finally statement.
|
237
265
|
class Finally : public NestedStatement {
|
238
266
|
public:
|
239
|
-
static const int kElementCount =
|
267
|
+
static const int kElementCount = 5;
|
240
268
|
|
241
269
|
explicit Finally(FullCodeGenerator* codegen) : NestedStatement(codegen) { }
|
242
270
|
virtual ~Finally() {}
|
@@ -372,9 +400,15 @@ class FullCodeGenerator: public AstVisitor {
|
|
372
400
|
void VisitInDuplicateContext(Expression* expr);
|
373
401
|
|
374
402
|
void VisitDeclarations(ZoneList<Declaration*>* declarations);
|
403
|
+
void DeclareModules(Handle<FixedArray> descriptions);
|
375
404
|
void DeclareGlobals(Handle<FixedArray> pairs);
|
376
405
|
int DeclareGlobalsFlags();
|
377
406
|
|
407
|
+
// Generate code to allocate all (including nested) modules and contexts.
|
408
|
+
// Because of recursive linking and the presence of module alias declarations,
|
409
|
+
// this has to be a separate pass _before_ populating or executing any module.
|
410
|
+
void AllocateModules(ZoneList<Declaration*>* declarations);
|
411
|
+
|
378
412
|
// Try to perform a comparison as a fast inlined literal compare if
|
379
413
|
// the operands allow it. Returns true if the compare operations
|
380
414
|
// has been matched and all code generated; false otherwise.
|
@@ -393,11 +427,12 @@ class FullCodeGenerator: public AstVisitor {
|
|
393
427
|
|
394
428
|
// Bailout support.
|
395
429
|
void PrepareForBailout(Expression* node, State state);
|
396
|
-
void PrepareForBailoutForId(
|
430
|
+
void PrepareForBailoutForId(BailoutId id, State state);
|
397
431
|
|
398
432
|
// Cache cell support. This associates AST ids with global property cells
|
399
433
|
// that will be cleared during GC and collected by the type-feedback oracle.
|
400
|
-
void RecordTypeFeedbackCell(
|
434
|
+
void RecordTypeFeedbackCell(TypeFeedbackId id,
|
435
|
+
Handle<JSGlobalPropertyCell> cell);
|
401
436
|
|
402
437
|
// Record a call's return site offset, used to rebuild the frame if the
|
403
438
|
// called function was inlined at the site.
|
@@ -417,14 +452,13 @@ class FullCodeGenerator: public AstVisitor {
|
|
417
452
|
// neither a with nor a catch context.
|
418
453
|
void EmitDebugCheckDeclarationContext(Variable* variable);
|
419
454
|
|
420
|
-
// Platform-specific code for checking the stack limit at the back edge of
|
421
|
-
// a loop.
|
422
455
|
// This is meant to be called at loop back edges, |back_edge_target| is
|
423
456
|
// the jump target of the back edge and is used to approximate the amount
|
424
457
|
// of code inside the loop.
|
425
|
-
void
|
426
|
-
|
427
|
-
|
458
|
+
void EmitBackEdgeBookkeeping(IterationStatement* stmt,
|
459
|
+
Label* back_edge_target);
|
460
|
+
// Record the OSR AST id corresponding to a back edge in the code.
|
461
|
+
void RecordBackEdge(BailoutId osr_ast_id);
|
428
462
|
// Emit a table of stack check ids and pcs into the code stream. Return
|
429
463
|
// the offset of the start of the table.
|
430
464
|
unsigned EmitStackCheckTable();
|
@@ -515,7 +549,7 @@ class FullCodeGenerator: public AstVisitor {
|
|
515
549
|
|
516
550
|
void CallIC(Handle<Code> code,
|
517
551
|
RelocInfo::Mode rmode = RelocInfo::CODE_TARGET,
|
518
|
-
|
552
|
+
TypeFeedbackId id = TypeFeedbackId::None());
|
519
553
|
|
520
554
|
void SetFunctionPosition(FunctionLiteral* fun);
|
521
555
|
void SetReturnPosition(FunctionLiteral* fun);
|
@@ -586,12 +620,12 @@ class FullCodeGenerator: public AstVisitor {
|
|
586
620
|
Handle<FixedArray> handler_table() { return handler_table_; }
|
587
621
|
|
588
622
|
struct BailoutEntry {
|
589
|
-
|
623
|
+
BailoutId id;
|
590
624
|
unsigned pc_and_state;
|
591
625
|
};
|
592
626
|
|
593
627
|
struct TypeFeedbackCellEntry {
|
594
|
-
|
628
|
+
TypeFeedbackId ast_id;
|
595
629
|
Handle<JSGlobalPropertyCell> cell;
|
596
630
|
};
|
597
631
|
|
@@ -779,16 +813,24 @@ class FullCodeGenerator: public AstVisitor {
|
|
779
813
|
NestedStatement* nesting_stack_;
|
780
814
|
int loop_depth_;
|
781
815
|
ZoneList<Handle<Object> >* globals_;
|
816
|
+
Handle<FixedArray> modules_;
|
817
|
+
int module_index_;
|
782
818
|
const ExpressionContext* context_;
|
783
819
|
ZoneList<BailoutEntry> bailout_entries_;
|
820
|
+
GrowableBitVector prepared_bailout_ids_;
|
821
|
+
// TODO(svenpanne) Rename this to something like back_edges_ and rename
|
822
|
+
// related functions accordingly.
|
784
823
|
ZoneList<BailoutEntry> stack_checks_;
|
785
824
|
ZoneList<TypeFeedbackCellEntry> type_feedback_cells_;
|
786
825
|
int ic_total_count_;
|
787
826
|
Handle<FixedArray> handler_table_;
|
788
827
|
Handle<JSGlobalPropertyCell> profiling_counter_;
|
828
|
+
bool generate_debug_code_;
|
829
|
+
Zone* zone_;
|
789
830
|
|
790
831
|
friend class NestedStatement;
|
791
832
|
|
833
|
+
DEFINE_AST_VISITOR_SUBCLASS_MEMBERS();
|
792
834
|
DISALLOW_COPY_AND_ASSIGN(FullCodeGenerator);
|
793
835
|
};
|
794
836
|
|
@@ -796,16 +838,16 @@ class FullCodeGenerator: public AstVisitor {
|
|
796
838
|
// A map from property names to getter/setter pairs allocated in the zone.
|
797
839
|
class AccessorTable: public TemplateHashMap<Literal,
|
798
840
|
ObjectLiteral::Accessors,
|
799
|
-
|
841
|
+
ZoneAllocationPolicy> {
|
800
842
|
public:
|
801
843
|
explicit AccessorTable(Zone* zone) :
|
802
|
-
TemplateHashMap<Literal,
|
803
|
-
|
804
|
-
|
844
|
+
TemplateHashMap<Literal, ObjectLiteral::Accessors,
|
845
|
+
ZoneAllocationPolicy>(Literal::Match,
|
846
|
+
ZoneAllocationPolicy(zone)),
|
805
847
|
zone_(zone) { }
|
806
848
|
|
807
849
|
Iterator lookup(Literal* literal) {
|
808
|
-
Iterator it = find(literal, true);
|
850
|
+
Iterator it = find(literal, true, ZoneAllocationPolicy(zone_));
|
809
851
|
if (it->second == NULL) it->second = new(zone_) ObjectLiteral::Accessors();
|
810
852
|
return it;
|
811
853
|
}
|
@@ -34,11 +34,12 @@
|
|
34
34
|
namespace v8 {
|
35
35
|
namespace internal {
|
36
36
|
|
37
|
-
FuncNameInferrer::FuncNameInferrer(Isolate* isolate)
|
37
|
+
FuncNameInferrer::FuncNameInferrer(Isolate* isolate, Zone* zone)
|
38
38
|
: isolate_(isolate),
|
39
|
-
entries_stack_(10),
|
40
|
-
names_stack_(5),
|
41
|
-
funcs_to_infer_(4)
|
39
|
+
entries_stack_(10, zone),
|
40
|
+
names_stack_(5, zone),
|
41
|
+
funcs_to_infer_(4, zone),
|
42
|
+
zone_(zone) {
|
42
43
|
}
|
43
44
|
|
44
45
|
|
@@ -48,21 +49,21 @@ void FuncNameInferrer::PushEnclosingName(Handle<String> name) {
|
|
48
49
|
// and starts with a capital letter.
|
49
50
|
if (name->length() > 0 && Runtime::IsUpperCaseChar(
|
50
51
|
isolate()->runtime_state(), name->Get(0))) {
|
51
|
-
names_stack_.Add(Name(name, kEnclosingConstructorName));
|
52
|
+
names_stack_.Add(Name(name, kEnclosingConstructorName), zone());
|
52
53
|
}
|
53
54
|
}
|
54
55
|
|
55
56
|
|
56
57
|
void FuncNameInferrer::PushLiteralName(Handle<String> name) {
|
57
58
|
if (IsOpen() && !isolate()->heap()->prototype_symbol()->Equals(*name)) {
|
58
|
-
names_stack_.Add(Name(name, kLiteralName));
|
59
|
+
names_stack_.Add(Name(name, kLiteralName), zone());
|
59
60
|
}
|
60
61
|
}
|
61
62
|
|
62
63
|
|
63
64
|
void FuncNameInferrer::PushVariableName(Handle<String> name) {
|
64
65
|
if (IsOpen() && !isolate()->heap()->result_symbol()->Equals(*name)) {
|
65
|
-
names_stack_.Add(Name(name, kVariableName));
|
66
|
+
names_stack_.Add(Name(name, kVariableName), zone());
|
66
67
|
}
|
67
68
|
}
|
68
69
|
|
@@ -45,7 +45,7 @@ class Isolate;
|
|
45
45
|
// a name.
|
46
46
|
class FuncNameInferrer : public ZoneObject {
|
47
47
|
public:
|
48
|
-
|
48
|
+
FuncNameInferrer(Isolate* isolate, Zone* zone);
|
49
49
|
|
50
50
|
// Returns whether we have entered name collection state.
|
51
51
|
bool IsOpen() const { return !entries_stack_.is_empty(); }
|
@@ -55,7 +55,7 @@ class FuncNameInferrer : public ZoneObject {
|
|
55
55
|
|
56
56
|
// Enters name collection state.
|
57
57
|
void Enter() {
|
58
|
-
entries_stack_.Add(names_stack_.length());
|
58
|
+
entries_stack_.Add(names_stack_.length(), zone());
|
59
59
|
}
|
60
60
|
|
61
61
|
// Pushes an encountered name onto names stack when in collection state.
|
@@ -66,7 +66,7 @@ class FuncNameInferrer : public ZoneObject {
|
|
66
66
|
// Adds a function to infer name for.
|
67
67
|
void AddFunction(FunctionLiteral* func_to_infer) {
|
68
68
|
if (IsOpen()) {
|
69
|
-
funcs_to_infer_.Add(func_to_infer);
|
69
|
+
funcs_to_infer_.Add(func_to_infer, zone());
|
70
70
|
}
|
71
71
|
}
|
72
72
|
|
@@ -105,6 +105,7 @@ class FuncNameInferrer : public ZoneObject {
|
|
105
105
|
};
|
106
106
|
|
107
107
|
Isolate* isolate() { return isolate_; }
|
108
|
+
Zone* zone() const { return zone_; }
|
108
109
|
|
109
110
|
// Constructs a full name in dotted notation from gathered names.
|
110
111
|
Handle<String> MakeNameFromStack();
|
@@ -119,6 +120,7 @@ class FuncNameInferrer : public ZoneObject {
|
|
119
120
|
ZoneList<int> entries_stack_;
|
120
121
|
ZoneList<Name> names_stack_;
|
121
122
|
ZoneList<FunctionLiteral*> funcs_to_infer_;
|
123
|
+
Zone* zone_;
|
122
124
|
|
123
125
|
DISALLOW_COPY_AND_ASSIGN(FuncNameInferrer);
|
124
126
|
};
|
data/vendor/v8/src/gdb-jit.cc
CHANGED
@@ -31,11 +31,13 @@
|
|
31
31
|
|
32
32
|
#include "bootstrapper.h"
|
33
33
|
#include "compiler.h"
|
34
|
+
#include "frames.h"
|
35
|
+
#include "frames-inl.h"
|
34
36
|
#include "global-handles.h"
|
35
37
|
#include "messages.h"
|
36
|
-
#include "platform.h"
|
37
38
|
#include "natives.h"
|
38
|
-
#include "
|
39
|
+
#include "platform.h"
|
40
|
+
#include "scopes.h"
|
39
41
|
|
40
42
|
namespace v8 {
|
41
43
|
namespace internal {
|
@@ -194,7 +196,7 @@ class DebugSectionBase : public ZoneObject {
|
|
194
196
|
|
195
197
|
virtual void WriteBody(Writer::Slot<THeader> header, Writer* writer) {
|
196
198
|
uintptr_t start = writer->position();
|
197
|
-
if (
|
199
|
+
if (WriteBodyInternal(writer)) {
|
198
200
|
uintptr_t end = writer->position();
|
199
201
|
header->offset = start;
|
200
202
|
#if defined(__MACH_O)
|
@@ -204,7 +206,7 @@ class DebugSectionBase : public ZoneObject {
|
|
204
206
|
}
|
205
207
|
}
|
206
208
|
|
207
|
-
virtual bool
|
209
|
+
virtual bool WriteBodyInternal(Writer* writer) {
|
208
210
|
return false;
|
209
211
|
}
|
210
212
|
|
@@ -340,14 +342,14 @@ class ELFSection : public DebugSectionBase<ELFSectionHeader> {
|
|
340
342
|
|
341
343
|
virtual void WriteBody(Writer::Slot<Header> header, Writer* w) {
|
342
344
|
uintptr_t start = w->position();
|
343
|
-
if (
|
345
|
+
if (WriteBodyInternal(w)) {
|
344
346
|
uintptr_t end = w->position();
|
345
347
|
header->offset = start;
|
346
348
|
header->size = end - start;
|
347
349
|
}
|
348
350
|
}
|
349
351
|
|
350
|
-
virtual bool
|
352
|
+
virtual bool WriteBodyInternal(Writer* w) {
|
351
353
|
return false;
|
352
354
|
}
|
353
355
|
|
@@ -627,9 +629,9 @@ class MachO BASE_EMBEDDED {
|
|
627
629
|
#if defined(__ELF)
|
628
630
|
class ELF BASE_EMBEDDED {
|
629
631
|
public:
|
630
|
-
ELF() : sections_(6) {
|
631
|
-
sections_.Add(new ELFSection("", ELFSection::TYPE_NULL, 0));
|
632
|
-
sections_.Add(new StringTable(".shstrtab"));
|
632
|
+
ELF(Zone* zone) : sections_(6, zone) {
|
633
|
+
sections_.Add(new(zone) ELFSection("", ELFSection::TYPE_NULL, 0), zone);
|
634
|
+
sections_.Add(new(zone) StringTable(".shstrtab"), zone);
|
633
635
|
}
|
634
636
|
|
635
637
|
void Write(Writer* w) {
|
@@ -642,8 +644,8 @@ class ELF BASE_EMBEDDED {
|
|
642
644
|
return sections_[index];
|
643
645
|
}
|
644
646
|
|
645
|
-
uint32_t AddSection(ELFSection* section) {
|
646
|
-
sections_.Add(section);
|
647
|
+
uint32_t AddSection(ELFSection* section, Zone* zone) {
|
648
|
+
sections_.Add(section, zone);
|
647
649
|
section->set_index(sections_.length() - 1);
|
648
650
|
return sections_.length() - 1;
|
649
651
|
}
|
@@ -675,7 +677,7 @@ class ELF BASE_EMBEDDED {
|
|
675
677
|
{ 0x7f, 'E', 'L', 'F', 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0};
|
676
678
|
#elif defined(V8_TARGET_ARCH_X64)
|
677
679
|
const uint8_t ident[16] =
|
678
|
-
{ 0x7f, 'E', 'L', 'F', 2, 1, 1, 0, 0, 0
|
680
|
+
{ 0x7f, 'E', 'L', 'F', 2, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0};
|
679
681
|
#else
|
680
682
|
#error Unsupported target architecture.
|
681
683
|
#endif
|
@@ -852,10 +854,10 @@ class ELFSymbol BASE_EMBEDDED {
|
|
852
854
|
|
853
855
|
class ELFSymbolTable : public ELFSection {
|
854
856
|
public:
|
855
|
-
|
857
|
+
ELFSymbolTable(const char* name, Zone* zone)
|
856
858
|
: ELFSection(name, TYPE_SYMTAB, sizeof(uintptr_t)),
|
857
|
-
locals_(1),
|
858
|
-
globals_(1) {
|
859
|
+
locals_(1, zone),
|
860
|
+
globals_(1, zone) {
|
859
861
|
}
|
860
862
|
|
861
863
|
virtual void WriteBody(Writer::Slot<Header> header, Writer* w) {
|
@@ -883,11 +885,11 @@ class ELFSymbolTable : public ELFSection {
|
|
883
885
|
strtab->DetachWriter();
|
884
886
|
}
|
885
887
|
|
886
|
-
void Add(const ELFSymbol& symbol) {
|
888
|
+
void Add(const ELFSymbol& symbol, Zone* zone) {
|
887
889
|
if (symbol.binding() == ELFSymbol::BIND_LOCAL) {
|
888
|
-
locals_.Add(symbol);
|
890
|
+
locals_.Add(symbol, zone);
|
889
891
|
} else {
|
890
|
-
globals_.Add(symbol);
|
892
|
+
globals_.Add(symbol, zone);
|
891
893
|
}
|
892
894
|
}
|
893
895
|
|
@@ -1019,26 +1021,29 @@ class CodeDescription BASE_EMBEDDED {
|
|
1019
1021
|
static void CreateSymbolsTable(CodeDescription* desc,
|
1020
1022
|
ELF* elf,
|
1021
1023
|
int text_section_index) {
|
1022
|
-
|
1023
|
-
|
1024
|
+
Zone* zone = desc->info()->zone();
|
1025
|
+
ELFSymbolTable* symtab = new(zone) ELFSymbolTable(".symtab", zone);
|
1026
|
+
StringTable* strtab = new(zone) StringTable(".strtab");
|
1024
1027
|
|
1025
1028
|
// Symbol table should be followed by the linked string table.
|
1026
|
-
elf->AddSection(symtab);
|
1027
|
-
elf->AddSection(strtab);
|
1029
|
+
elf->AddSection(symtab, zone);
|
1030
|
+
elf->AddSection(strtab, zone);
|
1028
1031
|
|
1029
1032
|
symtab->Add(ELFSymbol("V8 Code",
|
1030
1033
|
0,
|
1031
1034
|
0,
|
1032
1035
|
ELFSymbol::BIND_LOCAL,
|
1033
1036
|
ELFSymbol::TYPE_FILE,
|
1034
|
-
ELFSection::INDEX_ABSOLUTE)
|
1037
|
+
ELFSection::INDEX_ABSOLUTE),
|
1038
|
+
zone);
|
1035
1039
|
|
1036
1040
|
symtab->Add(ELFSymbol(desc->name(),
|
1037
1041
|
0,
|
1038
1042
|
desc->CodeSize(),
|
1039
1043
|
ELFSymbol::BIND_GLOBAL,
|
1040
1044
|
ELFSymbol::TYPE_FUNC,
|
1041
|
-
text_section_index)
|
1045
|
+
text_section_index),
|
1046
|
+
zone);
|
1042
1047
|
}
|
1043
1048
|
#endif // defined(__ELF)
|
1044
1049
|
|
@@ -1074,7 +1079,7 @@ class DebugInfoSection : public DebugSection {
|
|
1074
1079
|
DW_ATE_SIGNED = 0x5
|
1075
1080
|
};
|
1076
1081
|
|
1077
|
-
bool
|
1082
|
+
bool WriteBodyInternal(Writer* w) {
|
1078
1083
|
uintptr_t cu_start = w->position();
|
1079
1084
|
Writer::Slot<uint32_t> size = w->CreateSlotHere<uint32_t>();
|
1080
1085
|
uintptr_t start = w->position();
|
@@ -1094,8 +1099,7 @@ class DebugInfoSection : public DebugSection {
|
|
1094
1099
|
w->WriteString("v8value");
|
1095
1100
|
|
1096
1101
|
if (desc_->IsInfoAvailable()) {
|
1097
|
-
|
1098
|
-
ScopeInfo<FreeStoreAllocationPolicy> scope_info(info->scope());
|
1102
|
+
Scope* scope = desc_->info()->scope();
|
1099
1103
|
w->WriteULEB128(2);
|
1100
1104
|
w->WriteString(desc_->name());
|
1101
1105
|
w->Write<intptr_t>(desc_->CodeStart());
|
@@ -1106,23 +1110,27 @@ class DebugInfoSection : public DebugSection {
|
|
1106
1110
|
w->Write<uint8_t>(DW_OP_reg5); // The frame pointer's here on ia32
|
1107
1111
|
#elif defined(V8_TARGET_ARCH_X64)
|
1108
1112
|
w->Write<uint8_t>(DW_OP_reg6); // and here on x64.
|
1113
|
+
#elif defined(V8_TARGET_ARCH_ARM)
|
1114
|
+
UNIMPLEMENTED();
|
1115
|
+
#elif defined(V8_TARGET_ARCH_MIPS)
|
1116
|
+
UNIMPLEMENTED();
|
1109
1117
|
#else
|
1110
1118
|
#error Unsupported target architecture.
|
1111
1119
|
#endif
|
1112
1120
|
fb_block_size.set(static_cast<uint32_t>(w->position() - fb_block_start));
|
1113
1121
|
|
1114
|
-
int params =
|
1115
|
-
int slots =
|
1116
|
-
int context_slots =
|
1122
|
+
int params = scope->num_parameters();
|
1123
|
+
int slots = scope->num_stack_slots();
|
1124
|
+
int context_slots = scope->ContextLocalCount();
|
1117
1125
|
// The real slot ID is internal_slots + context_slot_id.
|
1118
1126
|
int internal_slots = Context::MIN_CONTEXT_SLOTS;
|
1119
|
-
int locals =
|
1127
|
+
int locals = scope->StackLocalCount();
|
1120
1128
|
int current_abbreviation = 4;
|
1121
1129
|
|
1122
1130
|
for (int param = 0; param < params; ++param) {
|
1123
1131
|
w->WriteULEB128(current_abbreviation++);
|
1124
1132
|
w->WriteString(
|
1125
|
-
*
|
1133
|
+
*scope->parameter(param)->name()->ToCString(DISALLOW_NULLS));
|
1126
1134
|
w->Write<uint32_t>(ty_offset);
|
1127
1135
|
Writer::Slot<uint32_t> block_size = w->CreateSlotHere<uint32_t>();
|
1128
1136
|
uintptr_t block_start = w->position();
|
@@ -1148,7 +1156,7 @@ class DebugInfoSection : public DebugSection {
|
|
1148
1156
|
ASSERT(Context::CLOSURE_INDEX == 0);
|
1149
1157
|
ASSERT(Context::PREVIOUS_INDEX == 1);
|
1150
1158
|
ASSERT(Context::EXTENSION_INDEX == 2);
|
1151
|
-
ASSERT(Context::
|
1159
|
+
ASSERT(Context::GLOBAL_OBJECT_INDEX == 3);
|
1152
1160
|
w->WriteULEB128(current_abbreviation++);
|
1153
1161
|
w->WriteString(".closure");
|
1154
1162
|
w->WriteULEB128(current_abbreviation++);
|
@@ -1167,10 +1175,13 @@ class DebugInfoSection : public DebugSection {
|
|
1167
1175
|
w->WriteString(builder.Finalize());
|
1168
1176
|
}
|
1169
1177
|
|
1178
|
+
ZoneList<Variable*> stack_locals(locals, scope->zone());
|
1179
|
+
ZoneList<Variable*> context_locals(context_slots, scope->zone());
|
1180
|
+
scope->CollectStackAndContextLocals(&stack_locals, &context_locals);
|
1170
1181
|
for (int local = 0; local < locals; ++local) {
|
1171
1182
|
w->WriteULEB128(current_abbreviation++);
|
1172
1183
|
w->WriteString(
|
1173
|
-
*
|
1184
|
+
*stack_locals[local]->name()->ToCString(DISALLOW_NULLS));
|
1174
1185
|
w->Write<uint32_t>(ty_offset);
|
1175
1186
|
Writer::Slot<uint32_t> block_size = w->CreateSlotHere<uint32_t>();
|
1176
1187
|
uintptr_t block_start = w->position();
|
@@ -1287,7 +1298,7 @@ class DebugAbbrevSection : public DebugSection {
|
|
1287
1298
|
w->WriteULEB128(0);
|
1288
1299
|
}
|
1289
1300
|
|
1290
|
-
bool
|
1301
|
+
bool WriteBodyInternal(Writer* w) {
|
1291
1302
|
int current_abbreviation = 1;
|
1292
1303
|
bool extra_info = desc_->IsInfoAvailable();
|
1293
1304
|
ASSERT(desc_->IsLineInfoAvailable());
|
@@ -1306,14 +1317,13 @@ class DebugAbbrevSection : public DebugSection {
|
|
1306
1317
|
w->WriteULEB128(0);
|
1307
1318
|
|
1308
1319
|
if (extra_info) {
|
1309
|
-
|
1310
|
-
|
1311
|
-
int
|
1312
|
-
int
|
1313
|
-
int context_slots = scope_info.number_of_context_slots();
|
1320
|
+
Scope* scope = desc_->info()->scope();
|
1321
|
+
int params = scope->num_parameters();
|
1322
|
+
int slots = scope->num_stack_slots();
|
1323
|
+
int context_slots = scope->ContextLocalCount();
|
1314
1324
|
// The real slot ID is internal_slots + context_slot_id.
|
1315
1325
|
int internal_slots = Context::MIN_CONTEXT_SLOTS;
|
1316
|
-
int locals =
|
1326
|
+
int locals = scope->StackLocalCount();
|
1317
1327
|
int total_children =
|
1318
1328
|
params + slots + context_slots + internal_slots + locals + 2;
|
1319
1329
|
|
@@ -1418,7 +1428,7 @@ class DebugLineSection : public DebugSection {
|
|
1418
1428
|
DW_LNE_DEFINE_FILE = 3
|
1419
1429
|
};
|
1420
1430
|
|
1421
|
-
bool
|
1431
|
+
bool WriteBodyInternal(Writer* w) {
|
1422
1432
|
// Write prologue.
|
1423
1433
|
Writer::Slot<uint32_t> total_length = w->CreateSlotHere<uint32_t>();
|
1424
1434
|
uintptr_t start = w->position();
|
@@ -1558,7 +1568,7 @@ class DebugLineSection : public DebugSection {
|
|
1558
1568
|
class UnwindInfoSection : public DebugSection {
|
1559
1569
|
public:
|
1560
1570
|
explicit UnwindInfoSection(CodeDescription* desc);
|
1561
|
-
virtual bool
|
1571
|
+
virtual bool WriteBodyInternal(Writer* w);
|
1562
1572
|
|
1563
1573
|
int WriteCIE(Writer* w);
|
1564
1574
|
void WriteFDE(Writer* w, int);
|
@@ -1770,7 +1780,7 @@ void UnwindInfoSection::WriteFDEStateAfterRBPPop(Writer* w) {
|
|
1770
1780
|
}
|
1771
1781
|
|
1772
1782
|
|
1773
|
-
bool UnwindInfoSection::
|
1783
|
+
bool UnwindInfoSection::WriteBodyInternal(Writer* w) {
|
1774
1784
|
uint32_t cie_position = WriteCIE(w);
|
1775
1785
|
WriteFDE(w, cie_position);
|
1776
1786
|
return true;
|
@@ -1780,13 +1790,14 @@ bool UnwindInfoSection::WriteBody(Writer* w) {
|
|
1780
1790
|
#endif // V8_TARGET_ARCH_X64
|
1781
1791
|
|
1782
1792
|
static void CreateDWARFSections(CodeDescription* desc, DebugObject* obj) {
|
1793
|
+
Zone* zone = desc->info()->zone();
|
1783
1794
|
if (desc->IsLineInfoAvailable()) {
|
1784
|
-
obj->AddSection(new DebugInfoSection(desc));
|
1785
|
-
obj->AddSection(new DebugAbbrevSection(desc));
|
1786
|
-
obj->AddSection(new DebugLineSection(desc));
|
1795
|
+
obj->AddSection(new(zone) DebugInfoSection(desc), zone);
|
1796
|
+
obj->AddSection(new(zone) DebugAbbrevSection(desc), zone);
|
1797
|
+
obj->AddSection(new(zone) DebugLineSection(desc), zone);
|
1787
1798
|
}
|
1788
1799
|
#ifdef V8_TARGET_ARCH_X64
|
1789
|
-
obj->AddSection(new UnwindInfoSection(desc));
|
1800
|
+
obj->AddSection(new(zone) UnwindInfoSection(desc), zone);
|
1790
1801
|
#endif
|
1791
1802
|
}
|
1792
1803
|
|
@@ -1905,7 +1916,8 @@ static void UnregisterCodeEntry(JITCodeEntry* entry) {
|
|
1905
1916
|
|
1906
1917
|
|
1907
1918
|
static JITCodeEntry* CreateELFObject(CodeDescription* desc) {
|
1908
|
-
|
1919
|
+
Zone* zone = desc->info()->zone();
|
1920
|
+
ZoneScope zone_scope(zone, DELETE_ON_EXIT);
|
1909
1921
|
#ifdef __MACH_O
|
1910
1922
|
MachO mach_o;
|
1911
1923
|
Writer w(&mach_o);
|
@@ -1918,17 +1930,19 @@ static JITCodeEntry* CreateELFObject(CodeDescription* desc) {
|
|
1918
1930
|
|
1919
1931
|
mach_o.Write(&w, desc->CodeStart(), desc->CodeSize());
|
1920
1932
|
#else
|
1921
|
-
ELF elf;
|
1933
|
+
ELF elf(zone);
|
1922
1934
|
Writer w(&elf);
|
1923
1935
|
|
1924
1936
|
int text_section_index = elf.AddSection(
|
1925
|
-
new FullHeaderELFSection(
|
1926
|
-
|
1927
|
-
|
1928
|
-
|
1929
|
-
|
1930
|
-
|
1931
|
-
|
1937
|
+
new(zone) FullHeaderELFSection(
|
1938
|
+
".text",
|
1939
|
+
ELFSection::TYPE_NOBITS,
|
1940
|
+
kCodeAlignment,
|
1941
|
+
desc->CodeStart(),
|
1942
|
+
0,
|
1943
|
+
desc->CodeSize(),
|
1944
|
+
ELFSection::FLAG_ALLOC | ELFSection::FLAG_EXEC),
|
1945
|
+
zone);
|
1932
1946
|
|
1933
1947
|
CreateSymbolsTable(desc, &elf, text_section_index);
|
1934
1948
|
|