therubyracer 0.9.0beta2 → 0.9.0beta3
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of therubyracer might be problematic. Click here for more details.
- data/.gitmodules +3 -0
- data/ext/v8/upstream/Makefile +1 -2
- data/ext/v8/upstream/v8/.gitignore +33 -0
- data/ext/v8/upstream/v8/AUTHORS +42 -0
- data/ext/v8/upstream/v8/ChangeLog +2663 -0
- data/ext/v8/upstream/{3.1.8 → v8}/LICENSE +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/LICENSE.strongtalk +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/LICENSE.v8 +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/LICENSE.valgrind +0 -0
- data/ext/v8/upstream/v8/SConstruct +1473 -0
- data/ext/v8/upstream/{3.1.8 → v8}/build/README.txt +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/build/all.gyp +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/build/armu.gypi +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/build/common.gypi +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/build/gyp_v8 +0 -0
- data/ext/v8/upstream/v8/include/v8-debug.h +394 -0
- data/ext/v8/upstream/v8/include/v8-preparser.h +116 -0
- data/ext/v8/upstream/v8/include/v8-profiler.h +505 -0
- data/ext/v8/upstream/v8/include/v8-testing.h +104 -0
- data/ext/v8/upstream/v8/include/v8.h +4000 -0
- data/ext/v8/upstream/{3.1.8 → v8}/include/v8stdint.h +0 -0
- data/ext/v8/upstream/v8/preparser/SConscript +38 -0
- data/ext/v8/upstream/v8/preparser/preparser-process.cc +169 -0
- data/ext/v8/upstream/v8/src/SConscript +380 -0
- data/ext/v8/upstream/v8/src/accessors.cc +766 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/accessors.h +0 -0
- data/ext/v8/upstream/v8/src/allocation-inl.h +49 -0
- data/ext/v8/upstream/v8/src/allocation.cc +122 -0
- data/ext/v8/upstream/v8/src/allocation.h +143 -0
- data/ext/v8/upstream/v8/src/api.cc +5678 -0
- data/ext/v8/upstream/v8/src/api.h +572 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/apinatives.js +0 -0
- data/ext/v8/upstream/v8/src/apiutils.h +73 -0
- data/ext/v8/upstream/v8/src/arguments.h +116 -0
- data/ext/v8/upstream/v8/src/arm/assembler-arm-inl.h +353 -0
- data/ext/v8/upstream/v8/src/arm/assembler-arm.cc +2877 -0
- data/ext/v8/upstream/v8/src/arm/assembler-arm.h +1382 -0
- data/ext/v8/upstream/v8/src/arm/builtins-arm.cc +1634 -0
- data/ext/v8/upstream/v8/src/arm/code-stubs-arm.cc +6917 -0
- data/ext/v8/upstream/v8/src/arm/code-stubs-arm.h +623 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/codegen-arm-inl.h +0 -0
- data/ext/v8/upstream/v8/src/arm/codegen-arm.cc +7437 -0
- data/ext/v8/upstream/v8/src/arm/codegen-arm.h +595 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/constants-arm.cc +0 -0
- data/ext/v8/upstream/v8/src/arm/constants-arm.h +778 -0
- data/ext/v8/upstream/v8/src/arm/cpu-arm.cc +149 -0
- data/ext/v8/upstream/v8/src/arm/debug-arm.cc +317 -0
- data/ext/v8/upstream/v8/src/arm/deoptimizer-arm.cc +737 -0
- data/ext/v8/upstream/v8/src/arm/disasm-arm.cc +1503 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/frames-arm.cc +0 -0
- data/ext/v8/upstream/v8/src/arm/frames-arm.h +168 -0
- data/ext/v8/upstream/v8/src/arm/full-codegen-arm.cc +4374 -0
- data/ext/v8/upstream/v8/src/arm/ic-arm.cc +1793 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/jump-target-arm.cc +0 -0
- data/ext/v8/upstream/v8/src/arm/lithium-arm.cc +2120 -0
- data/ext/v8/upstream/v8/src/arm/lithium-arm.h +2179 -0
- data/ext/v8/upstream/v8/src/arm/lithium-codegen-arm.cc +4132 -0
- data/ext/v8/upstream/v8/src/arm/lithium-codegen-arm.h +329 -0
- data/ext/v8/upstream/v8/src/arm/lithium-gap-resolver-arm.cc +305 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/lithium-gap-resolver-arm.h +0 -0
- data/ext/v8/upstream/v8/src/arm/macro-assembler-arm.cc +2939 -0
- data/ext/v8/upstream/v8/src/arm/macro-assembler-arm.h +1071 -0
- data/ext/v8/upstream/v8/src/arm/regexp-macro-assembler-arm.cc +1287 -0
- data/ext/v8/upstream/v8/src/arm/regexp-macro-assembler-arm.h +253 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/register-allocator-arm-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/register-allocator-arm.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/register-allocator-arm.h +0 -0
- data/ext/v8/upstream/v8/src/arm/simulator-arm.cc +3288 -0
- data/ext/v8/upstream/v8/src/arm/simulator-arm.h +413 -0
- data/ext/v8/upstream/v8/src/arm/stub-cache-arm.cc +4034 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/arm/virtual-frame-arm-inl.h +0 -0
- data/ext/v8/upstream/v8/src/arm/virtual-frame-arm.cc +843 -0
- data/ext/v8/upstream/v8/src/arm/virtual-frame-arm.h +523 -0
- data/ext/v8/upstream/v8/src/array.js +1249 -0
- data/ext/v8/upstream/v8/src/assembler.cc +1067 -0
- data/ext/v8/upstream/v8/src/assembler.h +823 -0
- data/ext/v8/upstream/v8/src/ast-inl.h +112 -0
- data/ext/v8/upstream/v8/src/ast.cc +1078 -0
- data/ext/v8/upstream/v8/src/ast.h +2234 -0
- data/ext/v8/upstream/v8/src/atomicops.h +167 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/atomicops_internals_arm_gcc.h +0 -0
- data/ext/v8/upstream/v8/src/atomicops_internals_mips_gcc.h +169 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/atomicops_internals_x86_gcc.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/atomicops_internals_x86_gcc.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/atomicops_internals_x86_macosx.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/atomicops_internals_x86_msvc.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/bignum-dtoa.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/bignum-dtoa.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/bignum.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/bignum.h +0 -0
- data/ext/v8/upstream/v8/src/bootstrapper.cc +2138 -0
- data/ext/v8/upstream/v8/src/bootstrapper.h +185 -0
- data/ext/v8/upstream/v8/src/builtins.cc +1708 -0
- data/ext/v8/upstream/v8/src/builtins.h +368 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/bytecodes-irregexp.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/cached-powers.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/cached-powers.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/char-predicates-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/char-predicates.h +0 -0
- data/ext/v8/upstream/v8/src/checks.cc +110 -0
- data/ext/v8/upstream/v8/src/checks.h +296 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/circular-queue-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/circular-queue.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/circular-queue.h +0 -0
- data/ext/v8/upstream/v8/src/code-stubs.cc +240 -0
- data/ext/v8/upstream/v8/src/code-stubs.h +971 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/code.h +0 -0
- data/ext/v8/upstream/v8/src/codegen-inl.h +68 -0
- data/ext/v8/upstream/v8/src/codegen.cc +505 -0
- data/ext/v8/upstream/v8/src/codegen.h +245 -0
- data/ext/v8/upstream/v8/src/compilation-cache.cc +540 -0
- data/ext/v8/upstream/v8/src/compilation-cache.h +287 -0
- data/ext/v8/upstream/v8/src/compiler.cc +792 -0
- data/ext/v8/upstream/v8/src/compiler.h +307 -0
- data/ext/v8/upstream/v8/src/contexts.cc +327 -0
- data/ext/v8/upstream/v8/src/contexts.h +382 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/conversions-inl.h +0 -0
- data/ext/v8/upstream/v8/src/conversions.cc +1125 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/conversions.h +0 -0
- data/ext/v8/upstream/v8/src/counters.cc +93 -0
- data/ext/v8/upstream/v8/src/counters.h +254 -0
- data/ext/v8/upstream/v8/src/cpu-profiler-inl.h +101 -0
- data/ext/v8/upstream/v8/src/cpu-profiler.cc +606 -0
- data/ext/v8/upstream/v8/src/cpu-profiler.h +305 -0
- data/ext/v8/upstream/v8/src/cpu.h +67 -0
- data/ext/v8/upstream/v8/src/d8-debug.cc +367 -0
- data/ext/v8/upstream/v8/src/d8-debug.h +158 -0
- data/ext/v8/upstream/v8/src/d8-posix.cc +695 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/d8-readline.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/d8-windows.cc +0 -0
- data/ext/v8/upstream/v8/src/d8.cc +796 -0
- data/ext/v8/upstream/v8/src/d8.gyp +88 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/d8.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/d8.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/data-flow.cc +0 -0
- data/ext/v8/upstream/v8/src/data-flow.h +379 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/date.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/dateparser-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/dateparser.cc +0 -0
- data/ext/v8/upstream/v8/src/dateparser.h +265 -0
- data/ext/v8/upstream/v8/src/debug-agent.cc +447 -0
- data/ext/v8/upstream/v8/src/debug-agent.h +129 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/debug-debugger.js +0 -0
- data/ext/v8/upstream/v8/src/debug.cc +3188 -0
- data/ext/v8/upstream/v8/src/debug.h +1055 -0
- data/ext/v8/upstream/v8/src/deoptimizer.cc +1296 -0
- data/ext/v8/upstream/v8/src/deoptimizer.h +629 -0
- data/ext/v8/upstream/v8/src/disasm.h +80 -0
- data/ext/v8/upstream/v8/src/disassembler.cc +339 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/disassembler.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/diy-fp.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/diy-fp.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/double.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/dtoa.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/dtoa.h +0 -0
- data/ext/v8/upstream/v8/src/execution.cc +791 -0
- data/ext/v8/upstream/v8/src/execution.h +291 -0
- data/ext/v8/upstream/v8/src/extensions/experimental/break-iterator.cc +250 -0
- data/ext/v8/upstream/v8/src/extensions/experimental/break-iterator.h +89 -0
- data/ext/v8/upstream/v8/src/extensions/experimental/experimental.gyp +55 -0
- data/ext/v8/upstream/v8/src/extensions/experimental/i18n-extension.cc +284 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/extensions/experimental/i18n-extension.h +0 -0
- data/ext/v8/upstream/v8/src/extensions/externalize-string-extension.cc +141 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/extensions/externalize-string-extension.h +0 -0
- data/ext/v8/upstream/v8/src/extensions/gc-extension.cc +58 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/extensions/gc-extension.h +0 -0
- data/ext/v8/upstream/v8/src/factory.cc +1194 -0
- data/ext/v8/upstream/v8/src/factory.h +436 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/fast-dtoa.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/fast-dtoa.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/fixed-dtoa.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/fixed-dtoa.h +0 -0
- data/ext/v8/upstream/v8/src/flag-definitions.h +556 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/flags.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/flags.h +0 -0
- data/ext/v8/upstream/v8/src/frame-element.cc +37 -0
- data/ext/v8/upstream/v8/src/frame-element.h +269 -0
- data/ext/v8/upstream/v8/src/frames-inl.h +236 -0
- data/ext/v8/upstream/v8/src/frames.cc +1273 -0
- data/ext/v8/upstream/v8/src/frames.h +854 -0
- data/ext/v8/upstream/v8/src/full-codegen.cc +1385 -0
- data/ext/v8/upstream/v8/src/full-codegen.h +753 -0
- data/ext/v8/upstream/v8/src/func-name-inferrer.cc +91 -0
- data/ext/v8/upstream/v8/src/func-name-inferrer.h +111 -0
- data/ext/v8/upstream/v8/src/gdb-jit.cc +1548 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/gdb-jit.h +0 -0
- data/ext/v8/upstream/v8/src/global-handles.cc +596 -0
- data/ext/v8/upstream/v8/src/global-handles.h +239 -0
- data/ext/v8/upstream/v8/src/globals.h +325 -0
- data/ext/v8/upstream/v8/src/handles-inl.h +177 -0
- data/ext/v8/upstream/v8/src/handles.cc +965 -0
- data/ext/v8/upstream/v8/src/handles.h +372 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/hashmap.cc +0 -0
- data/ext/v8/upstream/v8/src/hashmap.h +121 -0
- data/ext/v8/upstream/v8/src/heap-inl.h +703 -0
- data/ext/v8/upstream/v8/src/heap-profiler.cc +1173 -0
- data/ext/v8/upstream/v8/src/heap-profiler.h +396 -0
- data/ext/v8/upstream/v8/src/heap.cc +5856 -0
- data/ext/v8/upstream/v8/src/heap.h +2264 -0
- data/ext/v8/upstream/v8/src/hydrogen-instructions.cc +1639 -0
- data/ext/v8/upstream/v8/src/hydrogen-instructions.h +3657 -0
- data/ext/v8/upstream/v8/src/hydrogen.cc +6011 -0
- data/ext/v8/upstream/v8/src/hydrogen.h +1137 -0
- data/ext/v8/upstream/v8/src/ia32/assembler-ia32-inl.h +430 -0
- data/ext/v8/upstream/v8/src/ia32/assembler-ia32.cc +2846 -0
- data/ext/v8/upstream/v8/src/ia32/assembler-ia32.h +1159 -0
- data/ext/v8/upstream/v8/src/ia32/builtins-ia32.cc +1596 -0
- data/ext/v8/upstream/v8/src/ia32/code-stubs-ia32.cc +6549 -0
- data/ext/v8/upstream/v8/src/ia32/code-stubs-ia32.h +495 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/codegen-ia32-inl.h +0 -0
- data/ext/v8/upstream/v8/src/ia32/codegen-ia32.cc +10385 -0
- data/ext/v8/upstream/v8/src/ia32/codegen-ia32.h +801 -0
- data/ext/v8/upstream/v8/src/ia32/cpu-ia32.cc +88 -0
- data/ext/v8/upstream/v8/src/ia32/debug-ia32.cc +312 -0
- data/ext/v8/upstream/v8/src/ia32/deoptimizer-ia32.cc +774 -0
- data/ext/v8/upstream/v8/src/ia32/disasm-ia32.cc +1620 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/frames-ia32.cc +0 -0
- data/ext/v8/upstream/v8/src/ia32/frames-ia32.h +140 -0
- data/ext/v8/upstream/v8/src/ia32/full-codegen-ia32.cc +4357 -0
- data/ext/v8/upstream/v8/src/ia32/ic-ia32.cc +1779 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/jump-target-ia32.cc +0 -0
- data/ext/v8/upstream/v8/src/ia32/lithium-codegen-ia32.cc +4158 -0
- data/ext/v8/upstream/v8/src/ia32/lithium-codegen-ia32.h +318 -0
- data/ext/v8/upstream/v8/src/ia32/lithium-gap-resolver-ia32.cc +466 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/lithium-gap-resolver-ia32.h +0 -0
- data/ext/v8/upstream/v8/src/ia32/lithium-ia32.cc +2181 -0
- data/ext/v8/upstream/v8/src/ia32/lithium-ia32.h +2235 -0
- data/ext/v8/upstream/v8/src/ia32/macro-assembler-ia32.cc +2056 -0
- data/ext/v8/upstream/v8/src/ia32/macro-assembler-ia32.h +807 -0
- data/ext/v8/upstream/v8/src/ia32/regexp-macro-assembler-ia32.cc +1264 -0
- data/ext/v8/upstream/v8/src/ia32/regexp-macro-assembler-ia32.h +216 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/register-allocator-ia32-inl.h +0 -0
- data/ext/v8/upstream/v8/src/ia32/register-allocator-ia32.cc +157 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/register-allocator-ia32.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/ia32/simulator-ia32.cc +0 -0
- data/ext/v8/upstream/v8/src/ia32/simulator-ia32.h +72 -0
- data/ext/v8/upstream/v8/src/ia32/stub-cache-ia32.cc +3711 -0
- data/ext/v8/upstream/v8/src/ia32/virtual-frame-ia32.cc +1366 -0
- data/ext/v8/upstream/v8/src/ia32/virtual-frame-ia32.h +650 -0
- data/ext/v8/upstream/v8/src/ic-inl.h +130 -0
- data/ext/v8/upstream/v8/src/ic.cc +2389 -0
- data/ext/v8/upstream/v8/src/ic.h +675 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/inspector.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/inspector.h +0 -0
- data/ext/v8/upstream/v8/src/interpreter-irregexp.cc +659 -0
- data/ext/v8/upstream/v8/src/interpreter-irregexp.h +49 -0
- data/ext/v8/upstream/v8/src/isolate.cc +883 -0
- data/ext/v8/upstream/v8/src/isolate.h +1306 -0
- data/ext/v8/upstream/v8/src/json.js +342 -0
- data/ext/v8/upstream/v8/src/jsregexp.cc +5371 -0
- data/ext/v8/upstream/v8/src/jsregexp.h +1483 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/jump-target-heavy-inl.h +0 -0
- data/ext/v8/upstream/v8/src/jump-target-heavy.cc +427 -0
- data/ext/v8/upstream/v8/src/jump-target-heavy.h +238 -0
- data/ext/v8/upstream/v8/src/jump-target-inl.h +48 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/jump-target-light-inl.h +0 -0
- data/ext/v8/upstream/v8/src/jump-target-light.cc +111 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/jump-target-light.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/jump-target.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/jump-target.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/list-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/list.h +0 -0
- data/ext/v8/upstream/v8/src/lithium-allocator-inl.h +142 -0
- data/ext/v8/upstream/v8/src/lithium-allocator.cc +2105 -0
- data/ext/v8/upstream/v8/src/lithium-allocator.h +630 -0
- data/ext/v8/upstream/v8/src/lithium.cc +169 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/lithium.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/liveedit-debugger.js +0 -0
- data/ext/v8/upstream/v8/src/liveedit.cc +1693 -0
- data/ext/v8/upstream/v8/src/liveedit.h +179 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/liveobjectlist-inl.h +0 -0
- data/ext/v8/upstream/v8/src/liveobjectlist.cc +2589 -0
- data/ext/v8/upstream/v8/src/liveobjectlist.h +322 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/log-inl.h +0 -0
- data/ext/v8/upstream/v8/src/log-utils.cc +423 -0
- data/ext/v8/upstream/v8/src/log-utils.h +229 -0
- data/ext/v8/upstream/v8/src/log.cc +1666 -0
- data/ext/v8/upstream/v8/src/log.h +446 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/macro-assembler.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/macros.py +0 -0
- data/ext/v8/upstream/v8/src/mark-compact.cc +3092 -0
- data/ext/v8/upstream/v8/src/mark-compact.h +506 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/math.js +0 -0
- data/ext/v8/upstream/v8/src/messages.cc +166 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/messages.h +0 -0
- data/ext/v8/upstream/v8/src/messages.js +1090 -0
- data/ext/v8/upstream/v8/src/mips/assembler-mips-inl.h +335 -0
- data/ext/v8/upstream/v8/src/mips/assembler-mips.cc +2093 -0
- data/ext/v8/upstream/v8/src/mips/assembler-mips.h +1066 -0
- data/ext/v8/upstream/v8/src/mips/builtins-mips.cc +148 -0
- data/ext/v8/upstream/v8/src/mips/code-stubs-mips.cc +752 -0
- data/ext/v8/upstream/v8/src/mips/code-stubs-mips.h +511 -0
- data/ext/v8/upstream/v8/src/mips/codegen-mips-inl.h +64 -0
- data/ext/v8/upstream/v8/src/mips/codegen-mips.cc +1213 -0
- data/ext/v8/upstream/v8/src/mips/codegen-mips.h +633 -0
- data/ext/v8/upstream/v8/src/mips/constants-mips.cc +352 -0
- data/ext/v8/upstream/v8/src/mips/constants-mips.h +723 -0
- data/ext/v8/upstream/v8/src/mips/cpu-mips.cc +90 -0
- data/ext/v8/upstream/v8/src/mips/debug-mips.cc +155 -0
- data/ext/v8/upstream/v8/src/mips/deoptimizer-mips.cc +91 -0
- data/ext/v8/upstream/v8/src/mips/disasm-mips.cc +1023 -0
- data/ext/v8/upstream/v8/src/mips/frames-mips.cc +48 -0
- data/ext/v8/upstream/v8/src/mips/frames-mips.h +179 -0
- data/ext/v8/upstream/v8/src/mips/full-codegen-mips.cc +727 -0
- data/ext/v8/upstream/v8/src/mips/ic-mips.cc +244 -0
- data/ext/v8/upstream/v8/src/mips/jump-target-mips.cc +80 -0
- data/ext/v8/upstream/v8/src/mips/lithium-codegen-mips.h +65 -0
- data/ext/v8/upstream/v8/src/mips/lithium-mips.h +304 -0
- data/ext/v8/upstream/v8/src/mips/macro-assembler-mips.cc +3327 -0
- data/ext/v8/upstream/v8/src/mips/macro-assembler-mips.h +1058 -0
- data/ext/v8/upstream/v8/src/mips/regexp-macro-assembler-mips.cc +478 -0
- data/ext/v8/upstream/v8/src/mips/regexp-macro-assembler-mips.h +250 -0
- data/ext/v8/upstream/v8/src/mips/register-allocator-mips-inl.h +134 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/mips/register-allocator-mips.cc +0 -0
- data/ext/v8/upstream/v8/src/mips/register-allocator-mips.h +47 -0
- data/ext/v8/upstream/v8/src/mips/simulator-mips.cc +2438 -0
- data/ext/v8/upstream/v8/src/mips/simulator-mips.h +394 -0
- data/ext/v8/upstream/v8/src/mips/stub-cache-mips.cc +601 -0
- data/ext/v8/upstream/v8/src/mips/virtual-frame-mips-inl.h +58 -0
- data/ext/v8/upstream/v8/src/mips/virtual-frame-mips.cc +307 -0
- data/ext/v8/upstream/v8/src/mips/virtual-frame-mips.h +530 -0
- data/ext/v8/upstream/v8/src/mirror-debugger.js +2381 -0
- data/ext/v8/upstream/v8/src/mksnapshot.cc +256 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/natives.h +0 -0
- data/ext/v8/upstream/v8/src/objects-debug.cc +722 -0
- data/ext/v8/upstream/v8/src/objects-inl.h +4166 -0
- data/ext/v8/upstream/v8/src/objects-printer.cc +801 -0
- data/ext/v8/upstream/v8/src/objects-visiting.cc +142 -0
- data/ext/v8/upstream/v8/src/objects-visiting.h +422 -0
- data/ext/v8/upstream/v8/src/objects.cc +10296 -0
- data/ext/v8/upstream/v8/src/objects.h +6662 -0
- data/ext/v8/upstream/v8/src/parser.cc +5168 -0
- data/ext/v8/upstream/v8/src/parser.h +823 -0
- data/ext/v8/upstream/v8/src/platform-cygwin.cc +811 -0
- data/ext/v8/upstream/v8/src/platform-freebsd.cc +854 -0
- data/ext/v8/upstream/v8/src/platform-linux.cc +1120 -0
- data/ext/v8/upstream/v8/src/platform-macos.cc +865 -0
- data/ext/v8/upstream/v8/src/platform-nullos.cc +504 -0
- data/ext/v8/upstream/v8/src/platform-openbsd.cc +672 -0
- data/ext/v8/upstream/v8/src/platform-posix.cc +424 -0
- data/ext/v8/upstream/v8/src/platform-solaris.cc +796 -0
- data/ext/v8/upstream/v8/src/platform-tls-mac.h +62 -0
- data/ext/v8/upstream/v8/src/platform-tls-win32.h +62 -0
- data/ext/v8/upstream/v8/src/platform-tls.h +50 -0
- data/ext/v8/upstream/v8/src/platform-win32.cc +2072 -0
- data/ext/v8/upstream/v8/src/platform.h +693 -0
- data/ext/v8/upstream/v8/src/preparse-data.cc +185 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/preparse-data.h +0 -0
- data/ext/v8/upstream/v8/src/preparser-api.cc +219 -0
- data/ext/v8/upstream/v8/src/preparser.cc +1205 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/preparser.h +0 -0
- data/ext/v8/upstream/v8/src/prettyprinter.cc +1530 -0
- data/ext/v8/upstream/v8/src/prettyprinter.h +223 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/profile-generator-inl.h +0 -0
- data/ext/v8/upstream/v8/src/profile-generator.cc +3095 -0
- data/ext/v8/upstream/v8/src/profile-generator.h +1125 -0
- data/ext/v8/upstream/v8/src/property.cc +102 -0
- data/ext/v8/upstream/v8/src/property.h +348 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/regexp-macro-assembler-irregexp-inl.h +0 -0
- data/ext/v8/upstream/v8/src/regexp-macro-assembler-irregexp.cc +470 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/regexp-macro-assembler-irregexp.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/regexp-macro-assembler-tracer.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/regexp-macro-assembler-tracer.h +0 -0
- data/ext/v8/upstream/v8/src/regexp-macro-assembler.cc +266 -0
- data/ext/v8/upstream/v8/src/regexp-macro-assembler.h +236 -0
- data/ext/v8/upstream/v8/src/regexp-stack.cc +111 -0
- data/ext/v8/upstream/v8/src/regexp-stack.h +147 -0
- data/ext/v8/upstream/v8/src/regexp.js +483 -0
- data/ext/v8/upstream/v8/src/register-allocator-inl.h +141 -0
- data/ext/v8/upstream/v8/src/register-allocator.cc +98 -0
- data/ext/v8/upstream/v8/src/register-allocator.h +310 -0
- data/ext/v8/upstream/v8/src/rewriter.cc +1024 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/rewriter.h +0 -0
- data/ext/v8/upstream/v8/src/runtime-profiler.cc +478 -0
- data/ext/v8/upstream/v8/src/runtime-profiler.h +192 -0
- data/ext/v8/upstream/v8/src/runtime.cc +11949 -0
- data/ext/v8/upstream/v8/src/runtime.h +643 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/runtime.js +0 -0
- data/ext/v8/upstream/v8/src/safepoint-table.cc +256 -0
- data/ext/v8/upstream/v8/src/safepoint-table.h +269 -0
- data/ext/v8/upstream/v8/src/scanner-base.cc +964 -0
- data/ext/v8/upstream/v8/src/scanner-base.h +664 -0
- data/ext/v8/upstream/v8/src/scanner.cc +584 -0
- data/ext/v8/upstream/v8/src/scanner.h +196 -0
- data/ext/v8/upstream/v8/src/scopeinfo.cc +631 -0
- data/ext/v8/upstream/v8/src/scopeinfo.h +249 -0
- data/ext/v8/upstream/v8/src/scopes.cc +1093 -0
- data/ext/v8/upstream/v8/src/scopes.h +508 -0
- data/ext/v8/upstream/v8/src/serialize.cc +1574 -0
- data/ext/v8/upstream/v8/src/serialize.h +589 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/shell.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/simulator.h +0 -0
- data/ext/v8/upstream/v8/src/small-pointer-list.h +163 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/smart-pointer.h +0 -0
- data/ext/v8/upstream/v8/src/snapshot-common.cc +82 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/snapshot-empty.cc +0 -0
- data/ext/v8/upstream/v8/src/snapshot.h +73 -0
- data/ext/v8/upstream/v8/src/spaces-inl.h +529 -0
- data/ext/v8/upstream/v8/src/spaces.cc +3147 -0
- data/ext/v8/upstream/v8/src/spaces.h +2368 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/splay-tree-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/splay-tree.h +0 -0
- data/ext/v8/upstream/v8/src/string-search.cc +41 -0
- data/ext/v8/upstream/v8/src/string-search.h +568 -0
- data/ext/v8/upstream/v8/src/string-stream.cc +592 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/string-stream.h +0 -0
- data/ext/v8/upstream/v8/src/string.js +915 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/strtod.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/strtod.h +0 -0
- data/ext/v8/upstream/v8/src/stub-cache.cc +1940 -0
- data/ext/v8/upstream/v8/src/stub-cache.h +866 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/third_party/valgrind/valgrind.h +0 -0
- data/ext/v8/upstream/v8/src/token.cc +63 -0
- data/ext/v8/upstream/v8/src/token.h +288 -0
- data/ext/v8/upstream/v8/src/top.cc +983 -0
- data/ext/v8/upstream/v8/src/type-info.cc +472 -0
- data/ext/v8/upstream/v8/src/type-info.h +290 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/unbound-queue-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/unbound-queue.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/unicode-inl.h +0 -0
- data/ext/v8/upstream/v8/src/unicode.cc +1624 -0
- data/ext/v8/upstream/v8/src/unicode.h +280 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/uri.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/utils.cc +0 -0
- data/ext/v8/upstream/v8/src/utils.h +796 -0
- data/ext/v8/upstream/v8/src/v8-counters.cc +62 -0
- data/ext/v8/upstream/v8/src/v8-counters.h +311 -0
- data/ext/v8/upstream/v8/src/v8.cc +215 -0
- data/ext/v8/upstream/v8/src/v8.h +130 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/v8checks.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/v8dll-main.cc +0 -0
- data/ext/v8/upstream/v8/src/v8globals.h +486 -0
- data/ext/v8/upstream/{3.1.8/src/memory.h → v8/src/v8memory.h} +0 -0
- data/ext/v8/upstream/v8/src/v8natives.js +1293 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/v8preparserdll-main.cc +0 -0
- data/ext/v8/upstream/v8/src/v8threads.cc +453 -0
- data/ext/v8/upstream/v8/src/v8threads.h +164 -0
- data/ext/v8/upstream/v8/src/v8utils.h +317 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/variables.cc +0 -0
- data/ext/v8/upstream/v8/src/variables.h +212 -0
- data/ext/v8/upstream/v8/src/version.cc +116 -0
- data/ext/v8/upstream/v8/src/version.h +68 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/virtual-frame-heavy-inl.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/virtual-frame-heavy.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/virtual-frame-inl.h +0 -0
- data/ext/v8/upstream/v8/src/virtual-frame-light-inl.h +171 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/virtual-frame-light.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/virtual-frame.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/virtual-frame.h +0 -0
- data/ext/v8/upstream/v8/src/vm-state-inl.h +138 -0
- data/ext/v8/upstream/v8/src/vm-state.h +70 -0
- data/ext/v8/upstream/v8/src/win32-headers.h +96 -0
- data/ext/v8/upstream/v8/src/x64/assembler-x64-inl.h +456 -0
- data/ext/v8/upstream/v8/src/x64/assembler-x64.cc +2954 -0
- data/ext/v8/upstream/v8/src/x64/assembler-x64.h +1630 -0
- data/ext/v8/upstream/v8/src/x64/builtins-x64.cc +1493 -0
- data/ext/v8/upstream/v8/src/x64/code-stubs-x64.cc +5132 -0
- data/ext/v8/upstream/v8/src/x64/code-stubs-x64.h +477 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/codegen-x64-inl.h +0 -0
- data/ext/v8/upstream/v8/src/x64/codegen-x64.cc +8843 -0
- data/ext/v8/upstream/v8/src/x64/codegen-x64.h +753 -0
- data/ext/v8/upstream/v8/src/x64/cpu-x64.cc +88 -0
- data/ext/v8/upstream/v8/src/x64/debug-x64.cc +318 -0
- data/ext/v8/upstream/v8/src/x64/deoptimizer-x64.cc +815 -0
- data/ext/v8/upstream/v8/src/x64/disasm-x64.cc +1752 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/frames-x64.cc +0 -0
- data/ext/v8/upstream/v8/src/x64/frames-x64.h +130 -0
- data/ext/v8/upstream/v8/src/x64/full-codegen-x64.cc +4339 -0
- data/ext/v8/upstream/v8/src/x64/ic-x64.cc +1752 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/jump-target-x64.cc +0 -0
- data/ext/v8/upstream/v8/src/x64/lithium-codegen-x64.cc +3970 -0
- data/ext/v8/upstream/v8/src/x64/lithium-codegen-x64.h +318 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/lithium-gap-resolver-x64.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/lithium-gap-resolver-x64.h +0 -0
- data/ext/v8/upstream/v8/src/x64/lithium-x64.cc +2115 -0
- data/ext/v8/upstream/v8/src/x64/lithium-x64.h +2161 -0
- data/ext/v8/upstream/v8/src/x64/macro-assembler-x64.cc +2911 -0
- data/ext/v8/upstream/v8/src/x64/macro-assembler-x64.h +1984 -0
- data/ext/v8/upstream/v8/src/x64/regexp-macro-assembler-x64.cc +1398 -0
- data/ext/v8/upstream/v8/src/x64/regexp-macro-assembler-x64.h +282 -0
- data/ext/v8/upstream/v8/src/x64/register-allocator-x64-inl.h +87 -0
- data/ext/v8/upstream/v8/src/x64/register-allocator-x64.cc +95 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/register-allocator-x64.h +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/src/x64/simulator-x64.cc +0 -0
- data/ext/v8/upstream/v8/src/x64/simulator-x64.h +71 -0
- data/ext/v8/upstream/v8/src/x64/stub-cache-x64.cc +3460 -0
- data/ext/v8/upstream/v8/src/x64/virtual-frame-x64.cc +1296 -0
- data/ext/v8/upstream/v8/src/x64/virtual-frame-x64.h +597 -0
- data/ext/v8/upstream/v8/src/zone-inl.h +129 -0
- data/ext/v8/upstream/v8/src/zone.cc +196 -0
- data/ext/v8/upstream/v8/src/zone.h +236 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/codemap.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/consarray.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/csvparser.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/disasm.py +0 -0
- data/ext/v8/upstream/v8/tools/freebsd-tick-processor +10 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/gc-nvp-trace-processor.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/generate-ten-powers.scm +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/grokdump.py +0 -0
- data/ext/v8/upstream/v8/tools/gyp/v8.gyp +844 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/js2c.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/jsmin.py +0 -0
- data/ext/v8/upstream/v8/tools/linux-tick-processor +35 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/ll_prof.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/logreader.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/mac-nm +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/mac-tick-processor +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/oom_dump/README +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/oom_dump/SConstruct +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/oom_dump/oom_dump.cc +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/presubmit.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/process-heap-prof.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/profile.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/profile_view.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/run-valgrind.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/splaytree.js +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/stats-viewer.py +0 -0
- data/ext/v8/upstream/v8/tools/test.py +1490 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/tickprocessor-driver.js +0 -0
- data/ext/v8/upstream/v8/tools/tickprocessor.js +877 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/utils.py +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/README.txt +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/arm.vsprops +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/common.vsprops +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/d8.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/d8_arm.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/d8_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/d8js2c.cmd +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/debug.vsprops +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/ia32.vsprops +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/js2c.cmd +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/release.vsprops +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8.sln +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_arm.sln +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_arm.vcproj +0 -0
- data/ext/v8/upstream/v8/tools/visual_studio/v8_base.vcproj +1308 -0
- data/ext/v8/upstream/v8/tools/visual_studio/v8_base_arm.vcproj +1238 -0
- data/ext/v8/upstream/v8/tools/visual_studio/v8_base_x64.vcproj +1300 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_cctest.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_cctest_arm.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_cctest_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_mksnapshot.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_mksnapshot_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_process_sample.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_process_sample_arm.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_process_sample_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_shell_sample.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_shell_sample_arm.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_shell_sample_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_snapshot.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_snapshot_cc.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_snapshot_cc_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_snapshot_x64.vcproj +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_x64.sln +0 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/visual_studio/v8_x64.vcproj +0 -0
- data/ext/v8/upstream/v8/tools/visual_studio/x64.vsprops +18 -0
- data/ext/v8/upstream/{3.1.8 → v8}/tools/windows-tick-processor.bat +0 -0
- data/ext/v8/v8_callbacks.cpp +52 -92
- data/ext/v8/v8_date.cpp +2 -3
- data/ext/v8/v8_object.cpp +4 -0
- data/ext/v8/v8_template.cpp +2 -2
- data/ext/v8/v8_try_catch.cpp +8 -38
- data/lib/v8/version.rb +1 -1
- data/spec/ext/ext_spec_helper.rb +2 -20
- data/spec/ext/object_spec.rb +0 -12
- data/spec/ext/try_catch_spec.rb +29 -1
- data/spec/spec_helper.rb +1 -0
- data/spec/v8/portal/proxies_spec.rb +1 -84
- data/specmem/handle_memspec.rb +41 -0
- data/specmem/object_memspec.rb +16 -0
- data/specmem/proxies_memspec.rb +86 -0
- data/specmem/spec_helper.rb +24 -0
- data/therubyracer.gemspec +7 -2
- metadata +564 -541
- data/ext/v8/upstream/3.1.8/.gitignore +0 -31
- data/ext/v8/upstream/3.1.8/AUTHORS +0 -40
- data/ext/v8/upstream/3.1.8/ChangeLog +0 -2566
- data/ext/v8/upstream/3.1.8/SConstruct +0 -1192
- data/ext/v8/upstream/3.1.8/include/v8-debug.h +0 -384
- data/ext/v8/upstream/3.1.8/include/v8-preparser.h +0 -116
- data/ext/v8/upstream/3.1.8/include/v8-profiler.h +0 -426
- data/ext/v8/upstream/3.1.8/include/v8-testing.h +0 -99
- data/ext/v8/upstream/3.1.8/include/v8.h +0 -3846
- data/ext/v8/upstream/3.1.8/preparser/preparser-process.cc +0 -206
- data/ext/v8/upstream/3.1.8/src/SConscript +0 -356
- data/ext/v8/upstream/3.1.8/src/accessors.cc +0 -907
- data/ext/v8/upstream/3.1.8/src/allocation.cc +0 -204
- data/ext/v8/upstream/3.1.8/src/allocation.h +0 -176
- data/ext/v8/upstream/3.1.8/src/api.cc +0 -5191
- data/ext/v8/upstream/3.1.8/src/api.h +0 -508
- data/ext/v8/upstream/3.1.8/src/apiutils.h +0 -80
- data/ext/v8/upstream/3.1.8/src/arguments.h +0 -105
- data/ext/v8/upstream/3.1.8/src/arm/assembler-arm-inl.h +0 -352
- data/ext/v8/upstream/3.1.8/src/arm/assembler-arm.cc +0 -2756
- data/ext/v8/upstream/3.1.8/src/arm/assembler-arm.h +0 -1294
- data/ext/v8/upstream/3.1.8/src/arm/builtins-arm.cc +0 -1628
- data/ext/v8/upstream/3.1.8/src/arm/code-stubs-arm.cc +0 -6783
- data/ext/v8/upstream/3.1.8/src/arm/code-stubs-arm.h +0 -657
- data/ext/v8/upstream/3.1.8/src/arm/codegen-arm.cc +0 -7403
- data/ext/v8/upstream/3.1.8/src/arm/codegen-arm.h +0 -595
- data/ext/v8/upstream/3.1.8/src/arm/constants-arm.h +0 -769
- data/ext/v8/upstream/3.1.8/src/arm/cpu-arm.cc +0 -147
- data/ext/v8/upstream/3.1.8/src/arm/debug-arm.cc +0 -315
- data/ext/v8/upstream/3.1.8/src/arm/deoptimizer-arm.cc +0 -700
- data/ext/v8/upstream/3.1.8/src/arm/disasm-arm.cc +0 -1439
- data/ext/v8/upstream/3.1.8/src/arm/frames-arm.h +0 -168
- data/ext/v8/upstream/3.1.8/src/arm/full-codegen-arm.cc +0 -4230
- data/ext/v8/upstream/3.1.8/src/arm/ic-arm.cc +0 -1799
- data/ext/v8/upstream/3.1.8/src/arm/lithium-arm.cc +0 -2041
- data/ext/v8/upstream/3.1.8/src/arm/lithium-arm.h +0 -2046
- data/ext/v8/upstream/3.1.8/src/arm/lithium-codegen-arm.cc +0 -3822
- data/ext/v8/upstream/3.1.8/src/arm/lithium-codegen-arm.h +0 -312
- data/ext/v8/upstream/3.1.8/src/arm/lithium-gap-resolver-arm.cc +0 -303
- data/ext/v8/upstream/3.1.8/src/arm/macro-assembler-arm.cc +0 -2701
- data/ext/v8/upstream/3.1.8/src/arm/macro-assembler-arm.h +0 -1015
- data/ext/v8/upstream/3.1.8/src/arm/regexp-macro-assembler-arm.cc +0 -1280
- data/ext/v8/upstream/3.1.8/src/arm/regexp-macro-assembler-arm.h +0 -252
- data/ext/v8/upstream/3.1.8/src/arm/simulator-arm.cc +0 -3165
- data/ext/v8/upstream/3.1.8/src/arm/simulator-arm.h +0 -402
- data/ext/v8/upstream/3.1.8/src/arm/stub-cache-arm.cc +0 -4077
- data/ext/v8/upstream/3.1.8/src/arm/virtual-frame-arm.cc +0 -843
- data/ext/v8/upstream/3.1.8/src/arm/virtual-frame-arm.h +0 -520
- data/ext/v8/upstream/3.1.8/src/array.js +0 -1231
- data/ext/v8/upstream/3.1.8/src/assembler.cc +0 -973
- data/ext/v8/upstream/3.1.8/src/assembler.h +0 -787
- data/ext/v8/upstream/3.1.8/src/ast-inl.h +0 -107
- data/ext/v8/upstream/3.1.8/src/ast.cc +0 -1067
- data/ext/v8/upstream/3.1.8/src/ast.h +0 -2177
- data/ext/v8/upstream/3.1.8/src/atomicops.h +0 -165
- data/ext/v8/upstream/3.1.8/src/bootstrapper.cc +0 -1888
- data/ext/v8/upstream/3.1.8/src/bootstrapper.h +0 -118
- data/ext/v8/upstream/3.1.8/src/builtins.cc +0 -1586
- data/ext/v8/upstream/3.1.8/src/builtins.h +0 -339
- data/ext/v8/upstream/3.1.8/src/checks.cc +0 -110
- data/ext/v8/upstream/3.1.8/src/checks.h +0 -292
- data/ext/v8/upstream/3.1.8/src/code-stubs.cc +0 -230
- data/ext/v8/upstream/3.1.8/src/code-stubs.h +0 -950
- data/ext/v8/upstream/3.1.8/src/codegen-inl.h +0 -64
- data/ext/v8/upstream/3.1.8/src/codegen.cc +0 -495
- data/ext/v8/upstream/3.1.8/src/codegen.h +0 -245
- data/ext/v8/upstream/3.1.8/src/compilation-cache.cc +0 -654
- data/ext/v8/upstream/3.1.8/src/compilation-cache.h +0 -112
- data/ext/v8/upstream/3.1.8/src/compiler.cc +0 -806
- data/ext/v8/upstream/3.1.8/src/compiler.h +0 -290
- data/ext/v8/upstream/3.1.8/src/contexts.cc +0 -320
- data/ext/v8/upstream/3.1.8/src/contexts.h +0 -376
- data/ext/v8/upstream/3.1.8/src/conversions.cc +0 -1069
- data/ext/v8/upstream/3.1.8/src/counters.cc +0 -78
- data/ext/v8/upstream/3.1.8/src/counters.h +0 -242
- data/ext/v8/upstream/3.1.8/src/cpu-profiler-inl.h +0 -100
- data/ext/v8/upstream/3.1.8/src/cpu-profiler.cc +0 -554
- data/ext/v8/upstream/3.1.8/src/cpu-profiler.h +0 -291
- data/ext/v8/upstream/3.1.8/src/cpu.h +0 -65
- data/ext/v8/upstream/3.1.8/src/d8-debug.cc +0 -367
- data/ext/v8/upstream/3.1.8/src/d8-debug.h +0 -157
- data/ext/v8/upstream/3.1.8/src/d8-posix.cc +0 -693
- data/ext/v8/upstream/3.1.8/src/d8.cc +0 -792
- data/ext/v8/upstream/3.1.8/src/d8.gyp +0 -85
- data/ext/v8/upstream/3.1.8/src/data-flow.h +0 -379
- data/ext/v8/upstream/3.1.8/src/dateparser.h +0 -263
- data/ext/v8/upstream/3.1.8/src/debug-agent.cc +0 -446
- data/ext/v8/upstream/3.1.8/src/debug-agent.h +0 -131
- data/ext/v8/upstream/3.1.8/src/debug.cc +0 -3085
- data/ext/v8/upstream/3.1.8/src/debug.h +0 -1025
- data/ext/v8/upstream/3.1.8/src/deoptimizer.cc +0 -1185
- data/ext/v8/upstream/3.1.8/src/deoptimizer.h +0 -529
- data/ext/v8/upstream/3.1.8/src/disasm.h +0 -77
- data/ext/v8/upstream/3.1.8/src/disassembler.cc +0 -338
- data/ext/v8/upstream/3.1.8/src/execution.cc +0 -735
- data/ext/v8/upstream/3.1.8/src/execution.h +0 -322
- data/ext/v8/upstream/3.1.8/src/extensions/experimental/experimental.gyp +0 -53
- data/ext/v8/upstream/3.1.8/src/extensions/experimental/i18n-extension.cc +0 -264
- data/ext/v8/upstream/3.1.8/src/extensions/externalize-string-extension.cc +0 -141
- data/ext/v8/upstream/3.1.8/src/extensions/gc-extension.cc +0 -58
- data/ext/v8/upstream/3.1.8/src/factory.cc +0 -1087
- data/ext/v8/upstream/3.1.8/src/factory.h +0 -432
- data/ext/v8/upstream/3.1.8/src/flag-definitions.h +0 -552
- data/ext/v8/upstream/3.1.8/src/frame-element.cc +0 -42
- data/ext/v8/upstream/3.1.8/src/frame-element.h +0 -277
- data/ext/v8/upstream/3.1.8/src/frames-inl.h +0 -210
- data/ext/v8/upstream/3.1.8/src/frames.cc +0 -1232
- data/ext/v8/upstream/3.1.8/src/frames.h +0 -826
- data/ext/v8/upstream/3.1.8/src/full-codegen.cc +0 -1382
- data/ext/v8/upstream/3.1.8/src/full-codegen.h +0 -751
- data/ext/v8/upstream/3.1.8/src/func-name-inferrer.cc +0 -90
- data/ext/v8/upstream/3.1.8/src/func-name-inferrer.h +0 -111
- data/ext/v8/upstream/3.1.8/src/gdb-jit.cc +0 -1547
- data/ext/v8/upstream/3.1.8/src/global-handles.cc +0 -534
- data/ext/v8/upstream/3.1.8/src/global-handles.h +0 -181
- data/ext/v8/upstream/3.1.8/src/globals.h +0 -325
- data/ext/v8/upstream/3.1.8/src/handles-inl.h +0 -80
- data/ext/v8/upstream/3.1.8/src/handles.cc +0 -910
- data/ext/v8/upstream/3.1.8/src/handles.h +0 -424
- data/ext/v8/upstream/3.1.8/src/hashmap.h +0 -121
- data/ext/v8/upstream/3.1.8/src/heap-inl.h +0 -587
- data/ext/v8/upstream/3.1.8/src/heap-profiler.cc +0 -1128
- data/ext/v8/upstream/3.1.8/src/heap-profiler.h +0 -381
- data/ext/v8/upstream/3.1.8/src/heap.cc +0 -5610
- data/ext/v8/upstream/3.1.8/src/heap.h +0 -2218
- data/ext/v8/upstream/3.1.8/src/hydrogen-instructions.cc +0 -1490
- data/ext/v8/upstream/3.1.8/src/hydrogen-instructions.h +0 -3493
- data/ext/v8/upstream/3.1.8/src/hydrogen.cc +0 -6056
- data/ext/v8/upstream/3.1.8/src/hydrogen.h +0 -1091
- data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32-inl.h +0 -429
- data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32.cc +0 -2800
- data/ext/v8/upstream/3.1.8/src/ia32/assembler-ia32.h +0 -1093
- data/ext/v8/upstream/3.1.8/src/ia32/builtins-ia32.cc +0 -1590
- data/ext/v8/upstream/3.1.8/src/ia32/code-stubs-ia32.cc +0 -6624
- data/ext/v8/upstream/3.1.8/src/ia32/code-stubs-ia32.h +0 -536
- data/ext/v8/upstream/3.1.8/src/ia32/codegen-ia32.cc +0 -10354
- data/ext/v8/upstream/3.1.8/src/ia32/codegen-ia32.h +0 -798
- data/ext/v8/upstream/3.1.8/src/ia32/cpu-ia32.cc +0 -87
- data/ext/v8/upstream/3.1.8/src/ia32/debug-ia32.cc +0 -309
- data/ext/v8/upstream/3.1.8/src/ia32/deoptimizer-ia32.cc +0 -664
- data/ext/v8/upstream/3.1.8/src/ia32/disasm-ia32.cc +0 -1597
- data/ext/v8/upstream/3.1.8/src/ia32/frames-ia32.h +0 -140
- data/ext/v8/upstream/3.1.8/src/ia32/full-codegen-ia32.cc +0 -4278
- data/ext/v8/upstream/3.1.8/src/ia32/ic-ia32.cc +0 -1786
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-codegen-ia32.cc +0 -3880
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-codegen-ia32.h +0 -309
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-gap-resolver-ia32.cc +0 -460
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-ia32.cc +0 -2095
- data/ext/v8/upstream/3.1.8/src/ia32/lithium-ia32.h +0 -2127
- data/ext/v8/upstream/3.1.8/src/ia32/macro-assembler-ia32.cc +0 -2031
- data/ext/v8/upstream/3.1.8/src/ia32/macro-assembler-ia32.h +0 -798
- data/ext/v8/upstream/3.1.8/src/ia32/regexp-macro-assembler-ia32.cc +0 -1253
- data/ext/v8/upstream/3.1.8/src/ia32/regexp-macro-assembler-ia32.h +0 -215
- data/ext/v8/upstream/3.1.8/src/ia32/register-allocator-ia32.cc +0 -157
- data/ext/v8/upstream/3.1.8/src/ia32/simulator-ia32.h +0 -72
- data/ext/v8/upstream/3.1.8/src/ia32/stub-cache-ia32.cc +0 -3732
- data/ext/v8/upstream/3.1.8/src/ia32/virtual-frame-ia32.cc +0 -1360
- data/ext/v8/upstream/3.1.8/src/ia32/virtual-frame-ia32.h +0 -646
- data/ext/v8/upstream/3.1.8/src/ic-inl.h +0 -129
- data/ext/v8/upstream/3.1.8/src/ic.cc +0 -2333
- data/ext/v8/upstream/3.1.8/src/ic.h +0 -639
- data/ext/v8/upstream/3.1.8/src/interpreter-irregexp.cc +0 -655
- data/ext/v8/upstream/3.1.8/src/interpreter-irregexp.h +0 -48
- data/ext/v8/upstream/3.1.8/src/json.js +0 -342
- data/ext/v8/upstream/3.1.8/src/jsregexp.cc +0 -5340
- data/ext/v8/upstream/3.1.8/src/jsregexp.h +0 -1484
- data/ext/v8/upstream/3.1.8/src/jump-target-heavy.cc +0 -430
- data/ext/v8/upstream/3.1.8/src/jump-target-heavy.h +0 -244
- data/ext/v8/upstream/3.1.8/src/jump-target-inl.h +0 -48
- data/ext/v8/upstream/3.1.8/src/jump-target-light.cc +0 -111
- data/ext/v8/upstream/3.1.8/src/lithium-allocator-inl.h +0 -140
- data/ext/v8/upstream/3.1.8/src/lithium-allocator.cc +0 -2093
- data/ext/v8/upstream/3.1.8/src/lithium-allocator.h +0 -644
- data/ext/v8/upstream/3.1.8/src/lithium.cc +0 -168
- data/ext/v8/upstream/3.1.8/src/liveedit.cc +0 -1650
- data/ext/v8/upstream/3.1.8/src/liveedit.h +0 -174
- data/ext/v8/upstream/3.1.8/src/liveobjectlist.cc +0 -2527
- data/ext/v8/upstream/3.1.8/src/liveobjectlist.h +0 -322
- data/ext/v8/upstream/3.1.8/src/log-utils.cc +0 -336
- data/ext/v8/upstream/3.1.8/src/log-utils.h +0 -232
- data/ext/v8/upstream/3.1.8/src/log.cc +0 -1608
- data/ext/v8/upstream/3.1.8/src/log.h +0 -379
- data/ext/v8/upstream/3.1.8/src/mark-compact.cc +0 -2957
- data/ext/v8/upstream/3.1.8/src/mark-compact.h +0 -433
- data/ext/v8/upstream/3.1.8/src/messages.cc +0 -164
- data/ext/v8/upstream/3.1.8/src/messages.js +0 -1071
- data/ext/v8/upstream/3.1.8/src/mips/assembler-mips-inl.h +0 -215
- data/ext/v8/upstream/3.1.8/src/mips/assembler-mips.cc +0 -1219
- data/ext/v8/upstream/3.1.8/src/mips/assembler-mips.h +0 -667
- data/ext/v8/upstream/3.1.8/src/mips/builtins-mips.cc +0 -205
- data/ext/v8/upstream/3.1.8/src/mips/codegen-mips-inl.h +0 -70
- data/ext/v8/upstream/3.1.8/src/mips/codegen-mips.cc +0 -1437
- data/ext/v8/upstream/3.1.8/src/mips/codegen-mips.h +0 -431
- data/ext/v8/upstream/3.1.8/src/mips/constants-mips.cc +0 -328
- data/ext/v8/upstream/3.1.8/src/mips/constants-mips.h +0 -525
- data/ext/v8/upstream/3.1.8/src/mips/cpu-mips.cc +0 -73
- data/ext/v8/upstream/3.1.8/src/mips/debug-mips.cc +0 -127
- data/ext/v8/upstream/3.1.8/src/mips/disasm-mips.cc +0 -787
- data/ext/v8/upstream/3.1.8/src/mips/fast-codegen-mips.cc +0 -77
- data/ext/v8/upstream/3.1.8/src/mips/frames-mips.cc +0 -96
- data/ext/v8/upstream/3.1.8/src/mips/frames-mips.h +0 -164
- data/ext/v8/upstream/3.1.8/src/mips/full-codegen-mips.cc +0 -277
- data/ext/v8/upstream/3.1.8/src/mips/ic-mips.cc +0 -208
- data/ext/v8/upstream/3.1.8/src/mips/jump-target-mips.cc +0 -175
- data/ext/v8/upstream/3.1.8/src/mips/macro-assembler-mips.cc +0 -1326
- data/ext/v8/upstream/3.1.8/src/mips/macro-assembler-mips.h +0 -461
- data/ext/v8/upstream/3.1.8/src/mips/register-allocator-mips-inl.h +0 -137
- data/ext/v8/upstream/3.1.8/src/mips/register-allocator-mips.h +0 -46
- data/ext/v8/upstream/3.1.8/src/mips/simulator-mips.cc +0 -1650
- data/ext/v8/upstream/3.1.8/src/mips/simulator-mips.h +0 -311
- data/ext/v8/upstream/3.1.8/src/mips/stub-cache-mips.cc +0 -418
- data/ext/v8/upstream/3.1.8/src/mips/virtual-frame-mips.cc +0 -319
- data/ext/v8/upstream/3.1.8/src/mips/virtual-frame-mips.h +0 -548
- data/ext/v8/upstream/3.1.8/src/mirror-debugger.js +0 -2380
- data/ext/v8/upstream/3.1.8/src/mksnapshot.cc +0 -256
- data/ext/v8/upstream/3.1.8/src/objects-debug.cc +0 -722
- data/ext/v8/upstream/3.1.8/src/objects-inl.h +0 -3946
- data/ext/v8/upstream/3.1.8/src/objects-printer.cc +0 -801
- data/ext/v8/upstream/3.1.8/src/objects-visiting.cc +0 -142
- data/ext/v8/upstream/3.1.8/src/objects-visiting.h +0 -401
- data/ext/v8/upstream/3.1.8/src/objects.cc +0 -10044
- data/ext/v8/upstream/3.1.8/src/objects.h +0 -6571
- data/ext/v8/upstream/3.1.8/src/parser.cc +0 -5165
- data/ext/v8/upstream/3.1.8/src/parser.h +0 -802
- data/ext/v8/upstream/3.1.8/src/platform-cygwin.cc +0 -745
- data/ext/v8/upstream/3.1.8/src/platform-freebsd.cc +0 -702
- data/ext/v8/upstream/3.1.8/src/platform-linux.cc +0 -981
- data/ext/v8/upstream/3.1.8/src/platform-macos.cc +0 -732
- data/ext/v8/upstream/3.1.8/src/platform-nullos.cc +0 -498
- data/ext/v8/upstream/3.1.8/src/platform-openbsd.cc +0 -657
- data/ext/v8/upstream/3.1.8/src/platform-posix.cc +0 -399
- data/ext/v8/upstream/3.1.8/src/platform-solaris.cc +0 -714
- data/ext/v8/upstream/3.1.8/src/platform-win32.cc +0 -1974
- data/ext/v8/upstream/3.1.8/src/platform.h +0 -636
- data/ext/v8/upstream/3.1.8/src/preparse-data.cc +0 -183
- data/ext/v8/upstream/3.1.8/src/preparser-api.cc +0 -213
- data/ext/v8/upstream/3.1.8/src/preparser.cc +0 -1205
- data/ext/v8/upstream/3.1.8/src/prettyprinter.cc +0 -1539
- data/ext/v8/upstream/3.1.8/src/prettyprinter.h +0 -223
- data/ext/v8/upstream/3.1.8/src/profile-generator.cc +0 -2899
- data/ext/v8/upstream/3.1.8/src/profile-generator.h +0 -1151
- data/ext/v8/upstream/3.1.8/src/property.cc +0 -96
- data/ext/v8/upstream/3.1.8/src/property.h +0 -337
- data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler-irregexp.cc +0 -470
- data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler.cc +0 -257
- data/ext/v8/upstream/3.1.8/src/regexp-macro-assembler.h +0 -231
- data/ext/v8/upstream/3.1.8/src/regexp-stack.cc +0 -103
- data/ext/v8/upstream/3.1.8/src/regexp-stack.h +0 -123
- data/ext/v8/upstream/3.1.8/src/regexp.js +0 -483
- data/ext/v8/upstream/3.1.8/src/register-allocator-inl.h +0 -141
- data/ext/v8/upstream/3.1.8/src/register-allocator.cc +0 -104
- data/ext/v8/upstream/3.1.8/src/register-allocator.h +0 -320
- data/ext/v8/upstream/3.1.8/src/rewriter.cc +0 -1023
- data/ext/v8/upstream/3.1.8/src/runtime-profiler.cc +0 -443
- data/ext/v8/upstream/3.1.8/src/runtime-profiler.h +0 -77
- data/ext/v8/upstream/3.1.8/src/runtime.cc +0 -11592
- data/ext/v8/upstream/3.1.8/src/runtime.h +0 -582
- data/ext/v8/upstream/3.1.8/src/safepoint-table.cc +0 -253
- data/ext/v8/upstream/3.1.8/src/safepoint-table.h +0 -263
- data/ext/v8/upstream/3.1.8/src/scanner-base.cc +0 -971
- data/ext/v8/upstream/3.1.8/src/scanner-base.h +0 -653
- data/ext/v8/upstream/3.1.8/src/scanner.cc +0 -586
- data/ext/v8/upstream/3.1.8/src/scanner.h +0 -194
- data/ext/v8/upstream/3.1.8/src/scopeinfo.cc +0 -636
- data/ext/v8/upstream/3.1.8/src/scopeinfo.h +0 -238
- data/ext/v8/upstream/3.1.8/src/scopes.cc +0 -1063
- data/ext/v8/upstream/3.1.8/src/scopes.h +0 -494
- data/ext/v8/upstream/3.1.8/src/serialize.cc +0 -1535
- data/ext/v8/upstream/3.1.8/src/serialize.h +0 -584
- data/ext/v8/upstream/3.1.8/src/snapshot-common.cc +0 -82
- data/ext/v8/upstream/3.1.8/src/snapshot.h +0 -71
- data/ext/v8/upstream/3.1.8/src/spaces-inl.h +0 -524
- data/ext/v8/upstream/3.1.8/src/spaces.cc +0 -3254
- data/ext/v8/upstream/3.1.8/src/spaces.h +0 -2362
- data/ext/v8/upstream/3.1.8/src/string-search.cc +0 -40
- data/ext/v8/upstream/3.1.8/src/string-search.h +0 -567
- data/ext/v8/upstream/3.1.8/src/string-stream.cc +0 -584
- data/ext/v8/upstream/3.1.8/src/string.js +0 -915
- data/ext/v8/upstream/3.1.8/src/stub-cache.cc +0 -1878
- data/ext/v8/upstream/3.1.8/src/stub-cache.h +0 -849
- data/ext/v8/upstream/3.1.8/src/token.cc +0 -63
- data/ext/v8/upstream/3.1.8/src/token.h +0 -288
- data/ext/v8/upstream/3.1.8/src/top.cc +0 -1152
- data/ext/v8/upstream/3.1.8/src/top.h +0 -608
- data/ext/v8/upstream/3.1.8/src/type-info.cc +0 -406
- data/ext/v8/upstream/3.1.8/src/type-info.h +0 -283
- data/ext/v8/upstream/3.1.8/src/unicode.cc +0 -1624
- data/ext/v8/upstream/3.1.8/src/unicode.h +0 -280
- data/ext/v8/upstream/3.1.8/src/utils.h +0 -793
- data/ext/v8/upstream/3.1.8/src/v8-counters.cc +0 -55
- data/ext/v8/upstream/3.1.8/src/v8-counters.h +0 -290
- data/ext/v8/upstream/3.1.8/src/v8.cc +0 -270
- data/ext/v8/upstream/3.1.8/src/v8.h +0 -127
- data/ext/v8/upstream/3.1.8/src/v8globals.h +0 -480
- data/ext/v8/upstream/3.1.8/src/v8natives.js +0 -1252
- data/ext/v8/upstream/3.1.8/src/v8threads.cc +0 -440
- data/ext/v8/upstream/3.1.8/src/v8threads.h +0 -157
- data/ext/v8/upstream/3.1.8/src/v8utils.h +0 -354
- data/ext/v8/upstream/3.1.8/src/variables.h +0 -212
- data/ext/v8/upstream/3.1.8/src/version.cc +0 -95
- data/ext/v8/upstream/3.1.8/src/version.h +0 -64
- data/ext/v8/upstream/3.1.8/src/virtual-frame-light-inl.h +0 -170
- data/ext/v8/upstream/3.1.8/src/vm-state-inl.h +0 -134
- data/ext/v8/upstream/3.1.8/src/vm-state.h +0 -68
- data/ext/v8/upstream/3.1.8/src/win32-headers.h +0 -95
- data/ext/v8/upstream/3.1.8/src/x64/assembler-x64-inl.h +0 -455
- data/ext/v8/upstream/3.1.8/src/x64/assembler-x64.cc +0 -3162
- data/ext/v8/upstream/3.1.8/src/x64/assembler-x64.h +0 -1584
- data/ext/v8/upstream/3.1.8/src/x64/builtins-x64.cc +0 -1492
- data/ext/v8/upstream/3.1.8/src/x64/code-stubs-x64.cc +0 -5150
- data/ext/v8/upstream/3.1.8/src/x64/code-stubs-x64.h +0 -519
- data/ext/v8/upstream/3.1.8/src/x64/codegen-x64.cc +0 -8835
- data/ext/v8/upstream/3.1.8/src/x64/codegen-x64.h +0 -750
- data/ext/v8/upstream/3.1.8/src/x64/cpu-x64.cc +0 -86
- data/ext/v8/upstream/3.1.8/src/x64/debug-x64.cc +0 -316
- data/ext/v8/upstream/3.1.8/src/x64/deoptimizer-x64.cc +0 -781
- data/ext/v8/upstream/3.1.8/src/x64/disasm-x64.cc +0 -1737
- data/ext/v8/upstream/3.1.8/src/x64/frames-x64.h +0 -130
- data/ext/v8/upstream/3.1.8/src/x64/full-codegen-x64.cc +0 -3984
- data/ext/v8/upstream/3.1.8/src/x64/ic-x64.cc +0 -1761
- data/ext/v8/upstream/3.1.8/src/x64/lithium-codegen-x64.cc +0 -3639
- data/ext/v8/upstream/3.1.8/src/x64/lithium-codegen-x64.h +0 -305
- data/ext/v8/upstream/3.1.8/src/x64/lithium-x64.cc +0 -2044
- data/ext/v8/upstream/3.1.8/src/x64/lithium-x64.h +0 -2052
- data/ext/v8/upstream/3.1.8/src/x64/macro-assembler-x64.cc +0 -2660
- data/ext/v8/upstream/3.1.8/src/x64/macro-assembler-x64.h +0 -1852
- data/ext/v8/upstream/3.1.8/src/x64/regexp-macro-assembler-x64.cc +0 -1382
- data/ext/v8/upstream/3.1.8/src/x64/regexp-macro-assembler-x64.h +0 -278
- data/ext/v8/upstream/3.1.8/src/x64/register-allocator-x64-inl.h +0 -87
- data/ext/v8/upstream/3.1.8/src/x64/register-allocator-x64.cc +0 -91
- data/ext/v8/upstream/3.1.8/src/x64/simulator-x64.h +0 -71
- data/ext/v8/upstream/3.1.8/src/x64/stub-cache-x64.cc +0 -3509
- data/ext/v8/upstream/3.1.8/src/x64/virtual-frame-x64.cc +0 -1292
- data/ext/v8/upstream/3.1.8/src/x64/virtual-frame-x64.h +0 -593
- data/ext/v8/upstream/3.1.8/src/zone-inl.h +0 -83
- data/ext/v8/upstream/3.1.8/src/zone.cc +0 -195
- data/ext/v8/upstream/3.1.8/src/zone.h +0 -233
- data/ext/v8/upstream/3.1.8/tools/gyp/v8.gyp +0 -869
- data/ext/v8/upstream/3.1.8/tools/linux-tick-processor +0 -33
- data/ext/v8/upstream/3.1.8/tools/tickprocessor.js +0 -863
- data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base.vcproj +0 -1296
- data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base_arm.vcproj +0 -1234
- data/ext/v8/upstream/3.1.8/tools/visual_studio/v8_base_x64.vcproj +0 -1296
- data/ext/v8/upstream/3.1.8/tools/visual_studio/x64.vsprops +0 -17
- data/spec/ext/mem_spec.rb +0 -42
@@ -1,700 +0,0 @@
|
|
1
|
-
// Copyright 2011 the V8 project authors. All rights reserved.
|
2
|
-
// Redistribution and use in source and binary forms, with or without
|
3
|
-
// modification, are permitted provided that the following conditions are
|
4
|
-
// met:
|
5
|
-
//
|
6
|
-
// * Redistributions of source code must retain the above copyright
|
7
|
-
// notice, this list of conditions and the following disclaimer.
|
8
|
-
// * Redistributions in binary form must reproduce the above
|
9
|
-
// copyright notice, this list of conditions and the following
|
10
|
-
// disclaimer in the documentation and/or other materials provided
|
11
|
-
// with the distribution.
|
12
|
-
// * Neither the name of Google Inc. nor the names of its
|
13
|
-
// contributors may be used to endorse or promote products derived
|
14
|
-
// from this software without specific prior written permission.
|
15
|
-
//
|
16
|
-
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
17
|
-
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
18
|
-
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
19
|
-
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
20
|
-
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
21
|
-
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
22
|
-
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
23
|
-
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
24
|
-
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
25
|
-
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
26
|
-
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
27
|
-
|
28
|
-
#include "v8.h"
|
29
|
-
|
30
|
-
#include "codegen.h"
|
31
|
-
#include "deoptimizer.h"
|
32
|
-
#include "full-codegen.h"
|
33
|
-
#include "safepoint-table.h"
|
34
|
-
|
35
|
-
namespace v8 {
|
36
|
-
namespace internal {
|
37
|
-
|
38
|
-
int Deoptimizer::table_entry_size_ = 16;
|
39
|
-
|
40
|
-
|
41
|
-
int Deoptimizer::patch_size() {
|
42
|
-
const int kCallInstructionSizeInWords = 3;
|
43
|
-
return kCallInstructionSizeInWords * Assembler::kInstrSize;
|
44
|
-
}
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
void Deoptimizer::DeoptimizeFunction(JSFunction* function) {
|
49
|
-
AssertNoAllocation no_allocation;
|
50
|
-
|
51
|
-
if (!function->IsOptimized()) return;
|
52
|
-
|
53
|
-
// Get the optimized code.
|
54
|
-
Code* code = function->code();
|
55
|
-
|
56
|
-
// Invalidate the relocation information, as it will become invalid by the
|
57
|
-
// code patching below, and is not needed any more.
|
58
|
-
code->InvalidateRelocation();
|
59
|
-
|
60
|
-
// For each return after a safepoint insert an absolute call to the
|
61
|
-
// corresponding deoptimization entry.
|
62
|
-
ASSERT(patch_size() % Assembler::kInstrSize == 0);
|
63
|
-
int call_size_in_words = patch_size() / Assembler::kInstrSize;
|
64
|
-
unsigned last_pc_offset = 0;
|
65
|
-
SafepointTable table(function->code());
|
66
|
-
for (unsigned i = 0; i < table.length(); i++) {
|
67
|
-
unsigned pc_offset = table.GetPcOffset(i);
|
68
|
-
SafepointEntry safepoint_entry = table.GetEntry(i);
|
69
|
-
int deoptimization_index = safepoint_entry.deoptimization_index();
|
70
|
-
int gap_code_size = safepoint_entry.gap_code_size();
|
71
|
-
// Check that we did not shoot past next safepoint.
|
72
|
-
// TODO(srdjan): How do we guarantee that safepoint code does not
|
73
|
-
// overlap other safepoint patching code?
|
74
|
-
CHECK(pc_offset >= last_pc_offset);
|
75
|
-
#ifdef DEBUG
|
76
|
-
// Destroy the code which is not supposed to be run again.
|
77
|
-
int instructions = (pc_offset - last_pc_offset) / Assembler::kInstrSize;
|
78
|
-
CodePatcher destroyer(code->instruction_start() + last_pc_offset,
|
79
|
-
instructions);
|
80
|
-
for (int x = 0; x < instructions; x++) {
|
81
|
-
destroyer.masm()->bkpt(0);
|
82
|
-
}
|
83
|
-
#endif
|
84
|
-
last_pc_offset = pc_offset;
|
85
|
-
if (deoptimization_index != Safepoint::kNoDeoptimizationIndex) {
|
86
|
-
last_pc_offset += gap_code_size;
|
87
|
-
CodePatcher patcher(code->instruction_start() + last_pc_offset,
|
88
|
-
call_size_in_words);
|
89
|
-
Address deoptimization_entry = Deoptimizer::GetDeoptimizationEntry(
|
90
|
-
deoptimization_index, Deoptimizer::LAZY);
|
91
|
-
patcher.masm()->Call(deoptimization_entry, RelocInfo::NONE);
|
92
|
-
last_pc_offset += patch_size();
|
93
|
-
}
|
94
|
-
}
|
95
|
-
|
96
|
-
|
97
|
-
#ifdef DEBUG
|
98
|
-
// Destroy the code which is not supposed to be run again.
|
99
|
-
int instructions =
|
100
|
-
(code->safepoint_table_offset() - last_pc_offset) / Assembler::kInstrSize;
|
101
|
-
CodePatcher destroyer(code->instruction_start() + last_pc_offset,
|
102
|
-
instructions);
|
103
|
-
for (int x = 0; x < instructions; x++) {
|
104
|
-
destroyer.masm()->bkpt(0);
|
105
|
-
}
|
106
|
-
#endif
|
107
|
-
|
108
|
-
// Add the deoptimizing code to the list.
|
109
|
-
DeoptimizingCodeListNode* node = new DeoptimizingCodeListNode(code);
|
110
|
-
node->set_next(deoptimizing_code_list_);
|
111
|
-
deoptimizing_code_list_ = node;
|
112
|
-
|
113
|
-
// Set the code for the function to non-optimized version.
|
114
|
-
function->ReplaceCode(function->shared()->code());
|
115
|
-
|
116
|
-
if (FLAG_trace_deopt) {
|
117
|
-
PrintF("[forced deoptimization: ");
|
118
|
-
function->PrintName();
|
119
|
-
PrintF(" / %x]\n", reinterpret_cast<uint32_t>(function));
|
120
|
-
}
|
121
|
-
}
|
122
|
-
|
123
|
-
|
124
|
-
void Deoptimizer::PatchStackCheckCodeAt(Address pc_after,
|
125
|
-
Code* check_code,
|
126
|
-
Code* replacement_code) {
|
127
|
-
const int kInstrSize = Assembler::kInstrSize;
|
128
|
-
// The call of the stack guard check has the following form:
|
129
|
-
// e1 5d 00 0c cmp sp, <limit>
|
130
|
-
// 2a 00 00 01 bcs ok
|
131
|
-
// e5 9f c? ?? ldr ip, [pc, <stack guard address>]
|
132
|
-
// e1 2f ff 3c blx ip
|
133
|
-
ASSERT(Memory::int32_at(pc_after - kInstrSize) ==
|
134
|
-
(al | B24 | B21 | 15*B16 | 15*B12 | 15*B8 | BLX | ip.code()));
|
135
|
-
ASSERT(Assembler::IsLdrPcImmediateOffset(
|
136
|
-
Assembler::instr_at(pc_after - 2 * kInstrSize)));
|
137
|
-
|
138
|
-
// We patch the code to the following form:
|
139
|
-
// e1 5d 00 0c cmp sp, <limit>
|
140
|
-
// e1 a0 00 00 mov r0, r0 (NOP)
|
141
|
-
// e5 9f c? ?? ldr ip, [pc, <on-stack replacement address>]
|
142
|
-
// e1 2f ff 3c blx ip
|
143
|
-
// and overwrite the constant containing the
|
144
|
-
// address of the stack check stub.
|
145
|
-
|
146
|
-
// Replace conditional jump with NOP.
|
147
|
-
CodePatcher patcher(pc_after - 3 * kInstrSize, 1);
|
148
|
-
patcher.masm()->nop();
|
149
|
-
|
150
|
-
// Replace the stack check address in the constant pool
|
151
|
-
// with the entry address of the replacement code.
|
152
|
-
uint32_t stack_check_address_offset = Memory::uint16_at(pc_after -
|
153
|
-
2 * kInstrSize) & 0xfff;
|
154
|
-
Address stack_check_address_pointer = pc_after + stack_check_address_offset;
|
155
|
-
ASSERT(Memory::uint32_at(stack_check_address_pointer) ==
|
156
|
-
reinterpret_cast<uint32_t>(check_code->entry()));
|
157
|
-
Memory::uint32_at(stack_check_address_pointer) =
|
158
|
-
reinterpret_cast<uint32_t>(replacement_code->entry());
|
159
|
-
}
|
160
|
-
|
161
|
-
|
162
|
-
void Deoptimizer::RevertStackCheckCodeAt(Address pc_after,
|
163
|
-
Code* check_code,
|
164
|
-
Code* replacement_code) {
|
165
|
-
const int kInstrSize = Assembler::kInstrSize;
|
166
|
-
ASSERT(Memory::uint32_at(pc_after - kInstrSize) == 0xe12fff3c);
|
167
|
-
ASSERT(Memory::uint8_at(pc_after - kInstrSize - 1) == 0xe5);
|
168
|
-
ASSERT(Memory::uint8_at(pc_after - kInstrSize - 2) == 0x9f);
|
169
|
-
|
170
|
-
// Replace NOP with conditional jump.
|
171
|
-
CodePatcher patcher(pc_after - 3 * kInstrSize, 1);
|
172
|
-
patcher.masm()->b(+4, cs);
|
173
|
-
|
174
|
-
// Replace the stack check address in the constant pool
|
175
|
-
// with the entry address of the replacement code.
|
176
|
-
uint32_t stack_check_address_offset = Memory::uint16_at(pc_after -
|
177
|
-
2 * kInstrSize) & 0xfff;
|
178
|
-
Address stack_check_address_pointer = pc_after + stack_check_address_offset;
|
179
|
-
ASSERT(Memory::uint32_at(stack_check_address_pointer) ==
|
180
|
-
reinterpret_cast<uint32_t>(replacement_code->entry()));
|
181
|
-
Memory::uint32_at(stack_check_address_pointer) =
|
182
|
-
reinterpret_cast<uint32_t>(check_code->entry());
|
183
|
-
}
|
184
|
-
|
185
|
-
|
186
|
-
static int LookupBailoutId(DeoptimizationInputData* data, unsigned ast_id) {
|
187
|
-
ByteArray* translations = data->TranslationByteArray();
|
188
|
-
int length = data->DeoptCount();
|
189
|
-
for (int i = 0; i < length; i++) {
|
190
|
-
if (static_cast<unsigned>(data->AstId(i)->value()) == ast_id) {
|
191
|
-
TranslationIterator it(translations, data->TranslationIndex(i)->value());
|
192
|
-
int value = it.Next();
|
193
|
-
ASSERT(Translation::BEGIN == static_cast<Translation::Opcode>(value));
|
194
|
-
// Read the number of frames.
|
195
|
-
value = it.Next();
|
196
|
-
if (value == 1) return i;
|
197
|
-
}
|
198
|
-
}
|
199
|
-
UNREACHABLE();
|
200
|
-
return -1;
|
201
|
-
}
|
202
|
-
|
203
|
-
|
204
|
-
void Deoptimizer::DoComputeOsrOutputFrame() {
|
205
|
-
DeoptimizationInputData* data = DeoptimizationInputData::cast(
|
206
|
-
optimized_code_->deoptimization_data());
|
207
|
-
unsigned ast_id = data->OsrAstId()->value();
|
208
|
-
|
209
|
-
int bailout_id = LookupBailoutId(data, ast_id);
|
210
|
-
unsigned translation_index = data->TranslationIndex(bailout_id)->value();
|
211
|
-
ByteArray* translations = data->TranslationByteArray();
|
212
|
-
|
213
|
-
TranslationIterator iterator(translations, translation_index);
|
214
|
-
Translation::Opcode opcode =
|
215
|
-
static_cast<Translation::Opcode>(iterator.Next());
|
216
|
-
ASSERT(Translation::BEGIN == opcode);
|
217
|
-
USE(opcode);
|
218
|
-
int count = iterator.Next();
|
219
|
-
ASSERT(count == 1);
|
220
|
-
USE(count);
|
221
|
-
|
222
|
-
opcode = static_cast<Translation::Opcode>(iterator.Next());
|
223
|
-
USE(opcode);
|
224
|
-
ASSERT(Translation::FRAME == opcode);
|
225
|
-
unsigned node_id = iterator.Next();
|
226
|
-
USE(node_id);
|
227
|
-
ASSERT(node_id == ast_id);
|
228
|
-
JSFunction* function = JSFunction::cast(ComputeLiteral(iterator.Next()));
|
229
|
-
USE(function);
|
230
|
-
ASSERT(function == function_);
|
231
|
-
unsigned height = iterator.Next();
|
232
|
-
unsigned height_in_bytes = height * kPointerSize;
|
233
|
-
USE(height_in_bytes);
|
234
|
-
|
235
|
-
unsigned fixed_size = ComputeFixedSize(function_);
|
236
|
-
unsigned input_frame_size = input_->GetFrameSize();
|
237
|
-
ASSERT(fixed_size + height_in_bytes == input_frame_size);
|
238
|
-
|
239
|
-
unsigned stack_slot_size = optimized_code_->stack_slots() * kPointerSize;
|
240
|
-
unsigned outgoing_height = data->ArgumentsStackHeight(bailout_id)->value();
|
241
|
-
unsigned outgoing_size = outgoing_height * kPointerSize;
|
242
|
-
unsigned output_frame_size = fixed_size + stack_slot_size + outgoing_size;
|
243
|
-
ASSERT(outgoing_size == 0); // OSR does not happen in the middle of a call.
|
244
|
-
|
245
|
-
if (FLAG_trace_osr) {
|
246
|
-
PrintF("[on-stack replacement: begin 0x%08" V8PRIxPTR " ",
|
247
|
-
reinterpret_cast<intptr_t>(function_));
|
248
|
-
function_->PrintName();
|
249
|
-
PrintF(" => node=%u, frame=%d->%d]\n",
|
250
|
-
ast_id,
|
251
|
-
input_frame_size,
|
252
|
-
output_frame_size);
|
253
|
-
}
|
254
|
-
|
255
|
-
// There's only one output frame in the OSR case.
|
256
|
-
output_count_ = 1;
|
257
|
-
output_ = new FrameDescription*[1];
|
258
|
-
output_[0] = new(output_frame_size) FrameDescription(
|
259
|
-
output_frame_size, function_);
|
260
|
-
|
261
|
-
// Clear the incoming parameters in the optimized frame to avoid
|
262
|
-
// confusing the garbage collector.
|
263
|
-
unsigned output_offset = output_frame_size - kPointerSize;
|
264
|
-
int parameter_count = function_->shared()->formal_parameter_count() + 1;
|
265
|
-
for (int i = 0; i < parameter_count; ++i) {
|
266
|
-
output_[0]->SetFrameSlot(output_offset, 0);
|
267
|
-
output_offset -= kPointerSize;
|
268
|
-
}
|
269
|
-
|
270
|
-
// Translate the incoming parameters. This may overwrite some of the
|
271
|
-
// incoming argument slots we've just cleared.
|
272
|
-
int input_offset = input_frame_size - kPointerSize;
|
273
|
-
bool ok = true;
|
274
|
-
int limit = input_offset - (parameter_count * kPointerSize);
|
275
|
-
while (ok && input_offset > limit) {
|
276
|
-
ok = DoOsrTranslateCommand(&iterator, &input_offset);
|
277
|
-
}
|
278
|
-
|
279
|
-
// There are no translation commands for the caller's pc and fp, the
|
280
|
-
// context, and the function. Set them up explicitly.
|
281
|
-
for (int i = 0; ok && i < 4; i++) {
|
282
|
-
uint32_t input_value = input_->GetFrameSlot(input_offset);
|
283
|
-
if (FLAG_trace_osr) {
|
284
|
-
PrintF(" [sp + %d] <- 0x%08x ; [sp + %d] (fixed part)\n",
|
285
|
-
output_offset,
|
286
|
-
input_value,
|
287
|
-
input_offset);
|
288
|
-
}
|
289
|
-
output_[0]->SetFrameSlot(output_offset, input_->GetFrameSlot(input_offset));
|
290
|
-
input_offset -= kPointerSize;
|
291
|
-
output_offset -= kPointerSize;
|
292
|
-
}
|
293
|
-
|
294
|
-
// Translate the rest of the frame.
|
295
|
-
while (ok && input_offset >= 0) {
|
296
|
-
ok = DoOsrTranslateCommand(&iterator, &input_offset);
|
297
|
-
}
|
298
|
-
|
299
|
-
// If translation of any command failed, continue using the input frame.
|
300
|
-
if (!ok) {
|
301
|
-
delete output_[0];
|
302
|
-
output_[0] = input_;
|
303
|
-
output_[0]->SetPc(reinterpret_cast<uint32_t>(from_));
|
304
|
-
} else {
|
305
|
-
// Setup the frame pointer and the context pointer.
|
306
|
-
output_[0]->SetRegister(fp.code(), input_->GetRegister(fp.code()));
|
307
|
-
output_[0]->SetRegister(cp.code(), input_->GetRegister(cp.code()));
|
308
|
-
|
309
|
-
unsigned pc_offset = data->OsrPcOffset()->value();
|
310
|
-
uint32_t pc = reinterpret_cast<uint32_t>(
|
311
|
-
optimized_code_->entry() + pc_offset);
|
312
|
-
output_[0]->SetPc(pc);
|
313
|
-
}
|
314
|
-
Code* continuation = Builtins::builtin(Builtins::NotifyOSR);
|
315
|
-
output_[0]->SetContinuation(
|
316
|
-
reinterpret_cast<uint32_t>(continuation->entry()));
|
317
|
-
|
318
|
-
if (FLAG_trace_osr) {
|
319
|
-
PrintF("[on-stack replacement translation %s: 0x%08" V8PRIxPTR " ",
|
320
|
-
ok ? "finished" : "aborted",
|
321
|
-
reinterpret_cast<intptr_t>(function));
|
322
|
-
function->PrintName();
|
323
|
-
PrintF(" => pc=0x%0x]\n", output_[0]->GetPc());
|
324
|
-
}
|
325
|
-
}
|
326
|
-
|
327
|
-
|
328
|
-
// This code is very similar to ia32 code, but relies on register names (fp, sp)
|
329
|
-
// and how the frame is laid out.
|
330
|
-
void Deoptimizer::DoComputeFrame(TranslationIterator* iterator,
|
331
|
-
int frame_index) {
|
332
|
-
// Read the ast node id, function, and frame height for this output frame.
|
333
|
-
Translation::Opcode opcode =
|
334
|
-
static_cast<Translation::Opcode>(iterator->Next());
|
335
|
-
USE(opcode);
|
336
|
-
ASSERT(Translation::FRAME == opcode);
|
337
|
-
int node_id = iterator->Next();
|
338
|
-
JSFunction* function = JSFunction::cast(ComputeLiteral(iterator->Next()));
|
339
|
-
unsigned height = iterator->Next();
|
340
|
-
unsigned height_in_bytes = height * kPointerSize;
|
341
|
-
if (FLAG_trace_deopt) {
|
342
|
-
PrintF(" translating ");
|
343
|
-
function->PrintName();
|
344
|
-
PrintF(" => node=%d, height=%d\n", node_id, height_in_bytes);
|
345
|
-
}
|
346
|
-
|
347
|
-
// The 'fixed' part of the frame consists of the incoming parameters and
|
348
|
-
// the part described by JavaScriptFrameConstants.
|
349
|
-
unsigned fixed_frame_size = ComputeFixedSize(function);
|
350
|
-
unsigned input_frame_size = input_->GetFrameSize();
|
351
|
-
unsigned output_frame_size = height_in_bytes + fixed_frame_size;
|
352
|
-
|
353
|
-
// Allocate and store the output frame description.
|
354
|
-
FrameDescription* output_frame =
|
355
|
-
new(output_frame_size) FrameDescription(output_frame_size, function);
|
356
|
-
|
357
|
-
bool is_bottommost = (0 == frame_index);
|
358
|
-
bool is_topmost = (output_count_ - 1 == frame_index);
|
359
|
-
ASSERT(frame_index >= 0 && frame_index < output_count_);
|
360
|
-
ASSERT(output_[frame_index] == NULL);
|
361
|
-
output_[frame_index] = output_frame;
|
362
|
-
|
363
|
-
// The top address for the bottommost output frame can be computed from
|
364
|
-
// the input frame pointer and the output frame's height. For all
|
365
|
-
// subsequent output frames, it can be computed from the previous one's
|
366
|
-
// top address and the current frame's size.
|
367
|
-
uint32_t top_address;
|
368
|
-
if (is_bottommost) {
|
369
|
-
// 2 = context and function in the frame.
|
370
|
-
top_address =
|
371
|
-
input_->GetRegister(fp.code()) - (2 * kPointerSize) - height_in_bytes;
|
372
|
-
} else {
|
373
|
-
top_address = output_[frame_index - 1]->GetTop() - output_frame_size;
|
374
|
-
}
|
375
|
-
output_frame->SetTop(top_address);
|
376
|
-
|
377
|
-
// Compute the incoming parameter translation.
|
378
|
-
int parameter_count = function->shared()->formal_parameter_count() + 1;
|
379
|
-
unsigned output_offset = output_frame_size;
|
380
|
-
unsigned input_offset = input_frame_size;
|
381
|
-
for (int i = 0; i < parameter_count; ++i) {
|
382
|
-
output_offset -= kPointerSize;
|
383
|
-
DoTranslateCommand(iterator, frame_index, output_offset);
|
384
|
-
}
|
385
|
-
input_offset -= (parameter_count * kPointerSize);
|
386
|
-
|
387
|
-
// There are no translation commands for the caller's pc and fp, the
|
388
|
-
// context, and the function. Synthesize their values and set them up
|
389
|
-
// explicitly.
|
390
|
-
//
|
391
|
-
// The caller's pc for the bottommost output frame is the same as in the
|
392
|
-
// input frame. For all subsequent output frames, it can be read from the
|
393
|
-
// previous one. This frame's pc can be computed from the non-optimized
|
394
|
-
// function code and AST id of the bailout.
|
395
|
-
output_offset -= kPointerSize;
|
396
|
-
input_offset -= kPointerSize;
|
397
|
-
intptr_t value;
|
398
|
-
if (is_bottommost) {
|
399
|
-
value = input_->GetFrameSlot(input_offset);
|
400
|
-
} else {
|
401
|
-
value = output_[frame_index - 1]->GetPc();
|
402
|
-
}
|
403
|
-
output_frame->SetFrameSlot(output_offset, value);
|
404
|
-
if (FLAG_trace_deopt) {
|
405
|
-
PrintF(" 0x%08x: [top + %d] <- 0x%08x ; caller's pc\n",
|
406
|
-
top_address + output_offset, output_offset, value);
|
407
|
-
}
|
408
|
-
|
409
|
-
// The caller's frame pointer for the bottommost output frame is the same
|
410
|
-
// as in the input frame. For all subsequent output frames, it can be
|
411
|
-
// read from the previous one. Also compute and set this frame's frame
|
412
|
-
// pointer.
|
413
|
-
output_offset -= kPointerSize;
|
414
|
-
input_offset -= kPointerSize;
|
415
|
-
if (is_bottommost) {
|
416
|
-
value = input_->GetFrameSlot(input_offset);
|
417
|
-
} else {
|
418
|
-
value = output_[frame_index - 1]->GetFp();
|
419
|
-
}
|
420
|
-
output_frame->SetFrameSlot(output_offset, value);
|
421
|
-
intptr_t fp_value = top_address + output_offset;
|
422
|
-
ASSERT(!is_bottommost || input_->GetRegister(fp.code()) == fp_value);
|
423
|
-
output_frame->SetFp(fp_value);
|
424
|
-
if (is_topmost) {
|
425
|
-
output_frame->SetRegister(fp.code(), fp_value);
|
426
|
-
}
|
427
|
-
if (FLAG_trace_deopt) {
|
428
|
-
PrintF(" 0x%08x: [top + %d] <- 0x%08x ; caller's fp\n",
|
429
|
-
fp_value, output_offset, value);
|
430
|
-
}
|
431
|
-
|
432
|
-
// For the bottommost output frame the context can be gotten from the input
|
433
|
-
// frame. For all subsequent output frames it can be gotten from the function
|
434
|
-
// so long as we don't inline functions that need local contexts.
|
435
|
-
output_offset -= kPointerSize;
|
436
|
-
input_offset -= kPointerSize;
|
437
|
-
if (is_bottommost) {
|
438
|
-
value = input_->GetFrameSlot(input_offset);
|
439
|
-
} else {
|
440
|
-
value = reinterpret_cast<intptr_t>(function->context());
|
441
|
-
}
|
442
|
-
output_frame->SetFrameSlot(output_offset, value);
|
443
|
-
if (is_topmost) {
|
444
|
-
output_frame->SetRegister(cp.code(), value);
|
445
|
-
}
|
446
|
-
if (FLAG_trace_deopt) {
|
447
|
-
PrintF(" 0x%08x: [top + %d] <- 0x%08x ; context\n",
|
448
|
-
top_address + output_offset, output_offset, value);
|
449
|
-
}
|
450
|
-
|
451
|
-
// The function was mentioned explicitly in the BEGIN_FRAME.
|
452
|
-
output_offset -= kPointerSize;
|
453
|
-
input_offset -= kPointerSize;
|
454
|
-
value = reinterpret_cast<uint32_t>(function);
|
455
|
-
// The function for the bottommost output frame should also agree with the
|
456
|
-
// input frame.
|
457
|
-
ASSERT(!is_bottommost || input_->GetFrameSlot(input_offset) == value);
|
458
|
-
output_frame->SetFrameSlot(output_offset, value);
|
459
|
-
if (FLAG_trace_deopt) {
|
460
|
-
PrintF(" 0x%08x: [top + %d] <- 0x%08x ; function\n",
|
461
|
-
top_address + output_offset, output_offset, value);
|
462
|
-
}
|
463
|
-
|
464
|
-
// Translate the rest of the frame.
|
465
|
-
for (unsigned i = 0; i < height; ++i) {
|
466
|
-
output_offset -= kPointerSize;
|
467
|
-
DoTranslateCommand(iterator, frame_index, output_offset);
|
468
|
-
}
|
469
|
-
ASSERT(0 == output_offset);
|
470
|
-
|
471
|
-
// Compute this frame's PC, state, and continuation.
|
472
|
-
Code* non_optimized_code = function->shared()->code();
|
473
|
-
FixedArray* raw_data = non_optimized_code->deoptimization_data();
|
474
|
-
DeoptimizationOutputData* data = DeoptimizationOutputData::cast(raw_data);
|
475
|
-
Address start = non_optimized_code->instruction_start();
|
476
|
-
unsigned pc_and_state = GetOutputInfo(data, node_id, function->shared());
|
477
|
-
unsigned pc_offset = FullCodeGenerator::PcField::decode(pc_and_state);
|
478
|
-
uint32_t pc_value = reinterpret_cast<uint32_t>(start + pc_offset);
|
479
|
-
output_frame->SetPc(pc_value);
|
480
|
-
if (is_topmost) {
|
481
|
-
output_frame->SetRegister(pc.code(), pc_value);
|
482
|
-
}
|
483
|
-
|
484
|
-
FullCodeGenerator::State state =
|
485
|
-
FullCodeGenerator::StateField::decode(pc_and_state);
|
486
|
-
output_frame->SetState(Smi::FromInt(state));
|
487
|
-
|
488
|
-
// Set the continuation for the topmost frame.
|
489
|
-
if (is_topmost) {
|
490
|
-
Code* continuation = (bailout_type_ == EAGER)
|
491
|
-
? Builtins::builtin(Builtins::NotifyDeoptimized)
|
492
|
-
: Builtins::builtin(Builtins::NotifyLazyDeoptimized);
|
493
|
-
output_frame->SetContinuation(
|
494
|
-
reinterpret_cast<uint32_t>(continuation->entry()));
|
495
|
-
}
|
496
|
-
|
497
|
-
if (output_count_ - 1 == frame_index) iterator->Done();
|
498
|
-
}
|
499
|
-
|
500
|
-
|
501
|
-
#define __ masm()->
|
502
|
-
|
503
|
-
|
504
|
-
// This code tries to be close to ia32 code so that any changes can be
|
505
|
-
// easily ported.
|
506
|
-
void Deoptimizer::EntryGenerator::Generate() {
|
507
|
-
GeneratePrologue();
|
508
|
-
CpuFeatures::Scope scope(VFP3);
|
509
|
-
// Save all general purpose registers before messing with them.
|
510
|
-
const int kNumberOfRegisters = Register::kNumRegisters;
|
511
|
-
|
512
|
-
// Everything but pc, lr and ip which will be saved but not restored.
|
513
|
-
RegList restored_regs = kJSCallerSaved | kCalleeSaved | ip.bit();
|
514
|
-
|
515
|
-
const int kDoubleRegsSize =
|
516
|
-
kDoubleSize * DwVfpRegister::kNumAllocatableRegisters;
|
517
|
-
|
518
|
-
// Save all general purpose registers before messing with them.
|
519
|
-
__ sub(sp, sp, Operand(kDoubleRegsSize));
|
520
|
-
for (int i = 0; i < DwVfpRegister::kNumAllocatableRegisters; ++i) {
|
521
|
-
DwVfpRegister vfp_reg = DwVfpRegister::FromAllocationIndex(i);
|
522
|
-
int offset = i * kDoubleSize;
|
523
|
-
__ vstr(vfp_reg, sp, offset);
|
524
|
-
}
|
525
|
-
|
526
|
-
// Push all 16 registers (needed to populate FrameDescription::registers_).
|
527
|
-
__ stm(db_w, sp, restored_regs | sp.bit() | lr.bit() | pc.bit());
|
528
|
-
|
529
|
-
const int kSavedRegistersAreaSize =
|
530
|
-
(kNumberOfRegisters * kPointerSize) + kDoubleRegsSize;
|
531
|
-
|
532
|
-
// Get the bailout id from the stack.
|
533
|
-
__ ldr(r2, MemOperand(sp, kSavedRegistersAreaSize));
|
534
|
-
|
535
|
-
// Get the address of the location in the code object if possible (r3) (return
|
536
|
-
// address for lazy deoptimization) and compute the fp-to-sp delta in
|
537
|
-
// register r4.
|
538
|
-
if (type() == EAGER) {
|
539
|
-
__ mov(r3, Operand(0));
|
540
|
-
// Correct one word for bailout id.
|
541
|
-
__ add(r4, sp, Operand(kSavedRegistersAreaSize + (1 * kPointerSize)));
|
542
|
-
} else if (type() == OSR) {
|
543
|
-
__ mov(r3, lr);
|
544
|
-
// Correct one word for bailout id.
|
545
|
-
__ add(r4, sp, Operand(kSavedRegistersAreaSize + (1 * kPointerSize)));
|
546
|
-
} else {
|
547
|
-
__ mov(r3, lr);
|
548
|
-
// Correct two words for bailout id and return address.
|
549
|
-
__ add(r4, sp, Operand(kSavedRegistersAreaSize + (2 * kPointerSize)));
|
550
|
-
}
|
551
|
-
__ sub(r4, fp, r4);
|
552
|
-
|
553
|
-
// Allocate a new deoptimizer object.
|
554
|
-
// Pass four arguments in r0 to r3 and fifth argument on stack.
|
555
|
-
__ PrepareCallCFunction(5, r5);
|
556
|
-
__ ldr(r0, MemOperand(fp, JavaScriptFrameConstants::kFunctionOffset));
|
557
|
-
__ mov(r1, Operand(type())); // bailout type,
|
558
|
-
// r2: bailout id already loaded.
|
559
|
-
// r3: code address or 0 already loaded.
|
560
|
-
__ str(r4, MemOperand(sp, 0 * kPointerSize)); // Fp-to-sp delta.
|
561
|
-
// Call Deoptimizer::New().
|
562
|
-
__ CallCFunction(ExternalReference::new_deoptimizer_function(), 5);
|
563
|
-
|
564
|
-
// Preserve "deoptimizer" object in register r0 and get the input
|
565
|
-
// frame descriptor pointer to r1 (deoptimizer->input_);
|
566
|
-
__ ldr(r1, MemOperand(r0, Deoptimizer::input_offset()));
|
567
|
-
|
568
|
-
// Copy core registers into FrameDescription::registers_[kNumRegisters].
|
569
|
-
ASSERT(Register::kNumRegisters == kNumberOfRegisters);
|
570
|
-
for (int i = 0; i < kNumberOfRegisters; i++) {
|
571
|
-
int offset = (i * kPointerSize) + FrameDescription::registers_offset();
|
572
|
-
__ ldr(r2, MemOperand(sp, i * kPointerSize));
|
573
|
-
__ str(r2, MemOperand(r1, offset));
|
574
|
-
}
|
575
|
-
|
576
|
-
// Copy VFP registers to
|
577
|
-
// double_registers_[DoubleRegister::kNumAllocatableRegisters]
|
578
|
-
int double_regs_offset = FrameDescription::double_registers_offset();
|
579
|
-
for (int i = 0; i < DwVfpRegister::kNumAllocatableRegisters; ++i) {
|
580
|
-
int dst_offset = i * kDoubleSize + double_regs_offset;
|
581
|
-
int src_offset = i * kDoubleSize + kNumberOfRegisters * kPointerSize;
|
582
|
-
__ vldr(d0, sp, src_offset);
|
583
|
-
__ vstr(d0, r1, dst_offset);
|
584
|
-
}
|
585
|
-
|
586
|
-
// Remove the bailout id, eventually return address, and the saved registers
|
587
|
-
// from the stack.
|
588
|
-
if (type() == EAGER || type() == OSR) {
|
589
|
-
__ add(sp, sp, Operand(kSavedRegistersAreaSize + (1 * kPointerSize)));
|
590
|
-
} else {
|
591
|
-
__ add(sp, sp, Operand(kSavedRegistersAreaSize + (2 * kPointerSize)));
|
592
|
-
}
|
593
|
-
|
594
|
-
// Compute a pointer to the unwinding limit in register r2; that is
|
595
|
-
// the first stack slot not part of the input frame.
|
596
|
-
__ ldr(r2, MemOperand(r1, FrameDescription::frame_size_offset()));
|
597
|
-
__ add(r2, r2, sp);
|
598
|
-
|
599
|
-
// Unwind the stack down to - but not including - the unwinding
|
600
|
-
// limit and copy the contents of the activation frame to the input
|
601
|
-
// frame description.
|
602
|
-
__ add(r3, r1, Operand(FrameDescription::frame_content_offset()));
|
603
|
-
Label pop_loop;
|
604
|
-
__ bind(&pop_loop);
|
605
|
-
__ pop(r4);
|
606
|
-
__ str(r4, MemOperand(r3, 0));
|
607
|
-
__ add(r3, r3, Operand(sizeof(uint32_t)));
|
608
|
-
__ cmp(r2, sp);
|
609
|
-
__ b(ne, &pop_loop);
|
610
|
-
|
611
|
-
// Compute the output frame in the deoptimizer.
|
612
|
-
__ push(r0); // Preserve deoptimizer object across call.
|
613
|
-
// r0: deoptimizer object; r1: scratch.
|
614
|
-
__ PrepareCallCFunction(1, r1);
|
615
|
-
// Call Deoptimizer::ComputeOutputFrames().
|
616
|
-
__ CallCFunction(ExternalReference::compute_output_frames_function(), 1);
|
617
|
-
__ pop(r0); // Restore deoptimizer object (class Deoptimizer).
|
618
|
-
|
619
|
-
// Replace the current (input) frame with the output frames.
|
620
|
-
Label outer_push_loop, inner_push_loop;
|
621
|
-
// Outer loop state: r0 = current "FrameDescription** output_",
|
622
|
-
// r1 = one past the last FrameDescription**.
|
623
|
-
__ ldr(r1, MemOperand(r0, Deoptimizer::output_count_offset()));
|
624
|
-
__ ldr(r0, MemOperand(r0, Deoptimizer::output_offset())); // r0 is output_.
|
625
|
-
__ add(r1, r0, Operand(r1, LSL, 2));
|
626
|
-
__ bind(&outer_push_loop);
|
627
|
-
// Inner loop state: r2 = current FrameDescription*, r3 = loop index.
|
628
|
-
__ ldr(r2, MemOperand(r0, 0)); // output_[ix]
|
629
|
-
__ ldr(r3, MemOperand(r2, FrameDescription::frame_size_offset()));
|
630
|
-
__ bind(&inner_push_loop);
|
631
|
-
__ sub(r3, r3, Operand(sizeof(uint32_t)));
|
632
|
-
// __ add(r6, r2, Operand(r3, LSL, 1));
|
633
|
-
__ add(r6, r2, Operand(r3));
|
634
|
-
__ ldr(r7, MemOperand(r6, FrameDescription::frame_content_offset()));
|
635
|
-
__ push(r7);
|
636
|
-
__ cmp(r3, Operand(0));
|
637
|
-
__ b(ne, &inner_push_loop); // test for gt?
|
638
|
-
__ add(r0, r0, Operand(kPointerSize));
|
639
|
-
__ cmp(r0, r1);
|
640
|
-
__ b(lt, &outer_push_loop);
|
641
|
-
|
642
|
-
// Push state, pc, and continuation from the last output frame.
|
643
|
-
if (type() != OSR) {
|
644
|
-
__ ldr(r6, MemOperand(r2, FrameDescription::state_offset()));
|
645
|
-
__ push(r6);
|
646
|
-
}
|
647
|
-
|
648
|
-
__ ldr(r6, MemOperand(r2, FrameDescription::pc_offset()));
|
649
|
-
__ push(r6);
|
650
|
-
__ ldr(r6, MemOperand(r2, FrameDescription::continuation_offset()));
|
651
|
-
__ push(r6);
|
652
|
-
|
653
|
-
// Push the registers from the last output frame.
|
654
|
-
for (int i = kNumberOfRegisters - 1; i >= 0; i--) {
|
655
|
-
int offset = (i * kPointerSize) + FrameDescription::registers_offset();
|
656
|
-
__ ldr(r6, MemOperand(r2, offset));
|
657
|
-
__ push(r6);
|
658
|
-
}
|
659
|
-
|
660
|
-
// Restore the registers from the stack.
|
661
|
-
__ ldm(ia_w, sp, restored_regs); // all but pc registers.
|
662
|
-
__ pop(ip); // remove sp
|
663
|
-
__ pop(ip); // remove lr
|
664
|
-
|
665
|
-
// Set up the roots register.
|
666
|
-
ExternalReference roots_address = ExternalReference::roots_address();
|
667
|
-
__ mov(r10, Operand(roots_address));
|
668
|
-
|
669
|
-
__ pop(ip); // remove pc
|
670
|
-
__ pop(r7); // get continuation, leave pc on stack
|
671
|
-
__ pop(lr);
|
672
|
-
__ Jump(r7);
|
673
|
-
__ stop("Unreachable.");
|
674
|
-
}
|
675
|
-
|
676
|
-
|
677
|
-
void Deoptimizer::TableEntryGenerator::GeneratePrologue() {
|
678
|
-
// Create a sequence of deoptimization entries. Note that any
|
679
|
-
// registers may be still live.
|
680
|
-
Label done;
|
681
|
-
for (int i = 0; i < count(); i++) {
|
682
|
-
int start = masm()->pc_offset();
|
683
|
-
USE(start);
|
684
|
-
if (type() == EAGER) {
|
685
|
-
__ nop();
|
686
|
-
} else {
|
687
|
-
// Emulate ia32 like call by pushing return address to stack.
|
688
|
-
__ push(lr);
|
689
|
-
}
|
690
|
-
__ mov(ip, Operand(i));
|
691
|
-
__ push(ip);
|
692
|
-
__ b(&done);
|
693
|
-
ASSERT(masm()->pc_offset() - start == table_entry_size_);
|
694
|
-
}
|
695
|
-
__ bind(&done);
|
696
|
-
}
|
697
|
-
|
698
|
-
#undef __
|
699
|
-
|
700
|
-
} } // namespace v8::internal
|