therubyracer 0.4.9-x86-linux
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/.gitignore +11 -0
- data/.gitmodules +3 -0
- data/Doxyfile +1514 -0
- data/History.txt +43 -0
- data/README.rdoc +157 -0
- data/Rakefile +51 -0
- data/docs/data_conversion.txt +18 -0
- data/ext/v8/callbacks.cpp +160 -0
- data/ext/v8/callbacks.h +14 -0
- data/ext/v8/convert_ruby.cpp +8 -0
- data/ext/v8/convert_ruby.h +99 -0
- data/ext/v8/convert_string.cpp +10 -0
- data/ext/v8/convert_string.h +73 -0
- data/ext/v8/convert_v8.cpp +9 -0
- data/ext/v8/convert_v8.h +121 -0
- data/ext/v8/converters.cpp +83 -0
- data/ext/v8/converters.h +23 -0
- data/ext/v8/extconf.rb +36 -0
- data/ext/v8/upstream/2.0.6/.gitignore +26 -0
- data/ext/v8/upstream/2.0.6/AUTHORS +23 -0
- data/ext/v8/upstream/2.0.6/ChangeLog +1479 -0
- data/ext/v8/upstream/2.0.6/LICENSE +55 -0
- data/ext/v8/upstream/2.0.6/SConstruct +1028 -0
- data/ext/v8/upstream/2.0.6/include/v8-debug.h +275 -0
- data/ext/v8/upstream/2.0.6/include/v8.h +3236 -0
- data/ext/v8/upstream/2.0.6/src/SConscript +283 -0
- data/ext/v8/upstream/2.0.6/src/accessors.cc +695 -0
- data/ext/v8/upstream/2.0.6/src/accessors.h +114 -0
- data/ext/v8/upstream/2.0.6/src/allocation.cc +198 -0
- data/ext/v8/upstream/2.0.6/src/allocation.h +169 -0
- data/ext/v8/upstream/2.0.6/src/api.cc +3831 -0
- data/ext/v8/upstream/2.0.6/src/api.h +479 -0
- data/ext/v8/upstream/2.0.6/src/apinatives.js +110 -0
- data/ext/v8/upstream/2.0.6/src/apiutils.h +69 -0
- data/ext/v8/upstream/2.0.6/src/arguments.h +97 -0
- data/ext/v8/upstream/2.0.6/src/arm/assembler-arm-inl.h +277 -0
- data/ext/v8/upstream/2.0.6/src/arm/assembler-arm.cc +1821 -0
- data/ext/v8/upstream/2.0.6/src/arm/assembler-arm.h +1027 -0
- data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2-inl.h +267 -0
- data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2.cc +1821 -0
- data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2.h +1027 -0
- data/ext/v8/upstream/2.0.6/src/arm/builtins-arm.cc +1271 -0
- data/ext/v8/upstream/2.0.6/src/arm/codegen-arm-inl.h +74 -0
- data/ext/v8/upstream/2.0.6/src/arm/codegen-arm.cc +6682 -0
- data/ext/v8/upstream/2.0.6/src/arm/codegen-arm.h +535 -0
- data/ext/v8/upstream/2.0.6/src/arm/constants-arm.cc +112 -0
- data/ext/v8/upstream/2.0.6/src/arm/constants-arm.h +347 -0
- data/ext/v8/upstream/2.0.6/src/arm/cpu-arm.cc +132 -0
- data/ext/v8/upstream/2.0.6/src/arm/debug-arm.cc +213 -0
- data/ext/v8/upstream/2.0.6/src/arm/disasm-arm.cc +1166 -0
- data/ext/v8/upstream/2.0.6/src/arm/fast-codegen-arm.cc +1698 -0
- data/ext/v8/upstream/2.0.6/src/arm/frames-arm.cc +123 -0
- data/ext/v8/upstream/2.0.6/src/arm/frames-arm.h +162 -0
- data/ext/v8/upstream/2.0.6/src/arm/ic-arm.cc +849 -0
- data/ext/v8/upstream/2.0.6/src/arm/jump-target-arm.cc +238 -0
- data/ext/v8/upstream/2.0.6/src/arm/macro-assembler-arm.cc +1259 -0
- data/ext/v8/upstream/2.0.6/src/arm/macro-assembler-arm.h +423 -0
- data/ext/v8/upstream/2.0.6/src/arm/regexp-macro-assembler-arm.cc +1266 -0
- data/ext/v8/upstream/2.0.6/src/arm/regexp-macro-assembler-arm.h +282 -0
- data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm-inl.h +103 -0
- data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm.cc +59 -0
- data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm.h +43 -0
- data/ext/v8/upstream/2.0.6/src/arm/simulator-arm.cc +2264 -0
- data/ext/v8/upstream/2.0.6/src/arm/simulator-arm.h +306 -0
- data/ext/v8/upstream/2.0.6/src/arm/stub-cache-arm.cc +1516 -0
- data/ext/v8/upstream/2.0.6/src/arm/virtual-frame-arm.cc +412 -0
- data/ext/v8/upstream/2.0.6/src/arm/virtual-frame-arm.h +532 -0
- data/ext/v8/upstream/2.0.6/src/array.js +1154 -0
- data/ext/v8/upstream/2.0.6/src/assembler.cc +772 -0
- data/ext/v8/upstream/2.0.6/src/assembler.h +525 -0
- data/ext/v8/upstream/2.0.6/src/ast.cc +512 -0
- data/ext/v8/upstream/2.0.6/src/ast.h +1820 -0
- data/ext/v8/upstream/2.0.6/src/bootstrapper.cc +1680 -0
- data/ext/v8/upstream/2.0.6/src/bootstrapper.h +103 -0
- data/ext/v8/upstream/2.0.6/src/builtins.cc +851 -0
- data/ext/v8/upstream/2.0.6/src/builtins.h +245 -0
- data/ext/v8/upstream/2.0.6/src/bytecodes-irregexp.h +104 -0
- data/ext/v8/upstream/2.0.6/src/char-predicates-inl.h +86 -0
- data/ext/v8/upstream/2.0.6/src/char-predicates.h +65 -0
- data/ext/v8/upstream/2.0.6/src/checks.cc +100 -0
- data/ext/v8/upstream/2.0.6/src/checks.h +284 -0
- data/ext/v8/upstream/2.0.6/src/code-stubs.cc +164 -0
- data/ext/v8/upstream/2.0.6/src/code-stubs.h +164 -0
- data/ext/v8/upstream/2.0.6/src/code.h +68 -0
- data/ext/v8/upstream/2.0.6/src/codegen-inl.h +88 -0
- data/ext/v8/upstream/2.0.6/src/codegen.cc +504 -0
- data/ext/v8/upstream/2.0.6/src/codegen.h +522 -0
- data/ext/v8/upstream/2.0.6/src/compilation-cache.cc +490 -0
- data/ext/v8/upstream/2.0.6/src/compilation-cache.h +98 -0
- data/ext/v8/upstream/2.0.6/src/compiler.cc +1132 -0
- data/ext/v8/upstream/2.0.6/src/compiler.h +107 -0
- data/ext/v8/upstream/2.0.6/src/contexts.cc +256 -0
- data/ext/v8/upstream/2.0.6/src/contexts.h +345 -0
- data/ext/v8/upstream/2.0.6/src/conversions-inl.h +95 -0
- data/ext/v8/upstream/2.0.6/src/conversions.cc +709 -0
- data/ext/v8/upstream/2.0.6/src/conversions.h +118 -0
- data/ext/v8/upstream/2.0.6/src/counters.cc +78 -0
- data/ext/v8/upstream/2.0.6/src/counters.h +239 -0
- data/ext/v8/upstream/2.0.6/src/cpu.h +65 -0
- data/ext/v8/upstream/2.0.6/src/d8-debug.cc +345 -0
- data/ext/v8/upstream/2.0.6/src/d8-debug.h +155 -0
- data/ext/v8/upstream/2.0.6/src/d8-posix.cc +675 -0
- data/ext/v8/upstream/2.0.6/src/d8-readline.cc +128 -0
- data/ext/v8/upstream/2.0.6/src/d8-windows.cc +42 -0
- data/ext/v8/upstream/2.0.6/src/d8.cc +776 -0
- data/ext/v8/upstream/2.0.6/src/d8.h +225 -0
- data/ext/v8/upstream/2.0.6/src/d8.js +1625 -0
- data/ext/v8/upstream/2.0.6/src/date-delay.js +1138 -0
- data/ext/v8/upstream/2.0.6/src/dateparser-inl.h +114 -0
- data/ext/v8/upstream/2.0.6/src/dateparser.cc +186 -0
- data/ext/v8/upstream/2.0.6/src/dateparser.h +240 -0
- data/ext/v8/upstream/2.0.6/src/debug-agent.cc +425 -0
- data/ext/v8/upstream/2.0.6/src/debug-agent.h +129 -0
- data/ext/v8/upstream/2.0.6/src/debug-delay.js +2073 -0
- data/ext/v8/upstream/2.0.6/src/debug.cc +2751 -0
- data/ext/v8/upstream/2.0.6/src/debug.h +866 -0
- data/ext/v8/upstream/2.0.6/src/disasm.h +77 -0
- data/ext/v8/upstream/2.0.6/src/disassembler.cc +318 -0
- data/ext/v8/upstream/2.0.6/src/disassembler.h +56 -0
- data/ext/v8/upstream/2.0.6/src/dtoa-config.c +91 -0
- data/ext/v8/upstream/2.0.6/src/execution.cc +701 -0
- data/ext/v8/upstream/2.0.6/src/execution.h +312 -0
- data/ext/v8/upstream/2.0.6/src/factory.cc +957 -0
- data/ext/v8/upstream/2.0.6/src/factory.h +393 -0
- data/ext/v8/upstream/2.0.6/src/fast-codegen.cc +725 -0
- data/ext/v8/upstream/2.0.6/src/fast-codegen.h +371 -0
- data/ext/v8/upstream/2.0.6/src/flag-definitions.h +426 -0
- data/ext/v8/upstream/2.0.6/src/flags.cc +555 -0
- data/ext/v8/upstream/2.0.6/src/flags.h +81 -0
- data/ext/v8/upstream/2.0.6/src/frame-element.cc +45 -0
- data/ext/v8/upstream/2.0.6/src/frame-element.h +235 -0
- data/ext/v8/upstream/2.0.6/src/frames-inl.h +215 -0
- data/ext/v8/upstream/2.0.6/src/frames.cc +749 -0
- data/ext/v8/upstream/2.0.6/src/frames.h +659 -0
- data/ext/v8/upstream/2.0.6/src/func-name-inferrer.cc +76 -0
- data/ext/v8/upstream/2.0.6/src/func-name-inferrer.h +135 -0
- data/ext/v8/upstream/2.0.6/src/global-handles.cc +516 -0
- data/ext/v8/upstream/2.0.6/src/global-handles.h +180 -0
- data/ext/v8/upstream/2.0.6/src/globals.h +608 -0
- data/ext/v8/upstream/2.0.6/src/handles-inl.h +76 -0
- data/ext/v8/upstream/2.0.6/src/handles.cc +811 -0
- data/ext/v8/upstream/2.0.6/src/handles.h +367 -0
- data/ext/v8/upstream/2.0.6/src/hashmap.cc +226 -0
- data/ext/v8/upstream/2.0.6/src/hashmap.h +120 -0
- data/ext/v8/upstream/2.0.6/src/heap-inl.h +407 -0
- data/ext/v8/upstream/2.0.6/src/heap-profiler.cc +695 -0
- data/ext/v8/upstream/2.0.6/src/heap-profiler.h +277 -0
- data/ext/v8/upstream/2.0.6/src/heap.cc +4204 -0
- data/ext/v8/upstream/2.0.6/src/heap.h +1704 -0
- data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32-inl.h +325 -0
- data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32.cc +2375 -0
- data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32.h +914 -0
- data/ext/v8/upstream/2.0.6/src/ia32/builtins-ia32.cc +1222 -0
- data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32-inl.h +46 -0
- data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32.cc +9770 -0
- data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32.h +834 -0
- data/ext/v8/upstream/2.0.6/src/ia32/cpu-ia32.cc +79 -0
- data/ext/v8/upstream/2.0.6/src/ia32/debug-ia32.cc +208 -0
- data/ext/v8/upstream/2.0.6/src/ia32/disasm-ia32.cc +1357 -0
- data/ext/v8/upstream/2.0.6/src/ia32/fast-codegen-ia32.cc +1813 -0
- data/ext/v8/upstream/2.0.6/src/ia32/frames-ia32.cc +111 -0
- data/ext/v8/upstream/2.0.6/src/ia32/frames-ia32.h +135 -0
- data/ext/v8/upstream/2.0.6/src/ia32/ic-ia32.cc +1490 -0
- data/ext/v8/upstream/2.0.6/src/ia32/jump-target-ia32.cc +432 -0
- data/ext/v8/upstream/2.0.6/src/ia32/macro-assembler-ia32.cc +1517 -0
- data/ext/v8/upstream/2.0.6/src/ia32/macro-assembler-ia32.h +528 -0
- data/ext/v8/upstream/2.0.6/src/ia32/regexp-macro-assembler-ia32.cc +1219 -0
- data/ext/v8/upstream/2.0.6/src/ia32/regexp-macro-assembler-ia32.h +230 -0
- data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32-inl.h +82 -0
- data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32.cc +99 -0
- data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32.h +43 -0
- data/ext/v8/upstream/2.0.6/src/ia32/simulator-ia32.cc +30 -0
- data/ext/v8/upstream/2.0.6/src/ia32/simulator-ia32.h +62 -0
- data/ext/v8/upstream/2.0.6/src/ia32/stub-cache-ia32.cc +1961 -0
- data/ext/v8/upstream/2.0.6/src/ia32/virtual-frame-ia32.cc +1105 -0
- data/ext/v8/upstream/2.0.6/src/ia32/virtual-frame-ia32.h +580 -0
- data/ext/v8/upstream/2.0.6/src/ic-inl.h +93 -0
- data/ext/v8/upstream/2.0.6/src/ic.cc +1426 -0
- data/ext/v8/upstream/2.0.6/src/ic.h +443 -0
- data/ext/v8/upstream/2.0.6/src/interpreter-irregexp.cc +646 -0
- data/ext/v8/upstream/2.0.6/src/interpreter-irregexp.h +48 -0
- data/ext/v8/upstream/2.0.6/src/json-delay.js +254 -0
- data/ext/v8/upstream/2.0.6/src/jsregexp.cc +5234 -0
- data/ext/v8/upstream/2.0.6/src/jsregexp.h +1439 -0
- data/ext/v8/upstream/2.0.6/src/jump-target-inl.h +49 -0
- data/ext/v8/upstream/2.0.6/src/jump-target.cc +383 -0
- data/ext/v8/upstream/2.0.6/src/jump-target.h +280 -0
- data/ext/v8/upstream/2.0.6/src/list-inl.h +166 -0
- data/ext/v8/upstream/2.0.6/src/list.h +158 -0
- data/ext/v8/upstream/2.0.6/src/log-inl.h +126 -0
- data/ext/v8/upstream/2.0.6/src/log-utils.cc +503 -0
- data/ext/v8/upstream/2.0.6/src/log-utils.h +292 -0
- data/ext/v8/upstream/2.0.6/src/log.cc +1457 -0
- data/ext/v8/upstream/2.0.6/src/log.h +371 -0
- data/ext/v8/upstream/2.0.6/src/macro-assembler.h +93 -0
- data/ext/v8/upstream/2.0.6/src/macros.py +137 -0
- data/ext/v8/upstream/2.0.6/src/mark-compact.cc +2007 -0
- data/ext/v8/upstream/2.0.6/src/mark-compact.h +442 -0
- data/ext/v8/upstream/2.0.6/src/math.js +263 -0
- data/ext/v8/upstream/2.0.6/src/memory.h +74 -0
- data/ext/v8/upstream/2.0.6/src/messages.cc +177 -0
- data/ext/v8/upstream/2.0.6/src/messages.h +112 -0
- data/ext/v8/upstream/2.0.6/src/messages.js +937 -0
- data/ext/v8/upstream/2.0.6/src/mirror-delay.js +2332 -0
- data/ext/v8/upstream/2.0.6/src/mksnapshot.cc +169 -0
- data/ext/v8/upstream/2.0.6/src/natives.h +63 -0
- data/ext/v8/upstream/2.0.6/src/objects-debug.cc +1317 -0
- data/ext/v8/upstream/2.0.6/src/objects-inl.h +3044 -0
- data/ext/v8/upstream/2.0.6/src/objects.cc +8306 -0
- data/ext/v8/upstream/2.0.6/src/objects.h +4960 -0
- data/ext/v8/upstream/2.0.6/src/oprofile-agent.cc +116 -0
- data/ext/v8/upstream/2.0.6/src/oprofile-agent.h +69 -0
- data/ext/v8/upstream/2.0.6/src/parser.cc +4810 -0
- data/ext/v8/upstream/2.0.6/src/parser.h +195 -0
- data/ext/v8/upstream/2.0.6/src/platform-freebsd.cc +645 -0
- data/ext/v8/upstream/2.0.6/src/platform-linux.cc +808 -0
- data/ext/v8/upstream/2.0.6/src/platform-macos.cc +643 -0
- data/ext/v8/upstream/2.0.6/src/platform-nullos.cc +454 -0
- data/ext/v8/upstream/2.0.6/src/platform-openbsd.cc +597 -0
- data/ext/v8/upstream/2.0.6/src/platform-posix.cc +380 -0
- data/ext/v8/upstream/2.0.6/src/platform-win32.cc +1908 -0
- data/ext/v8/upstream/2.0.6/src/platform.h +556 -0
- data/ext/v8/upstream/2.0.6/src/prettyprinter.cc +1511 -0
- data/ext/v8/upstream/2.0.6/src/prettyprinter.h +219 -0
- data/ext/v8/upstream/2.0.6/src/property.cc +96 -0
- data/ext/v8/upstream/2.0.6/src/property.h +327 -0
- data/ext/v8/upstream/2.0.6/src/regexp-delay.js +406 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp-inl.h +78 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp.cc +464 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp.h +141 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-tracer.cc +356 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-tracer.h +103 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler.cc +240 -0
- data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler.h +220 -0
- data/ext/v8/upstream/2.0.6/src/regexp-stack.cc +103 -0
- data/ext/v8/upstream/2.0.6/src/regexp-stack.h +123 -0
- data/ext/v8/upstream/2.0.6/src/register-allocator-inl.h +74 -0
- data/ext/v8/upstream/2.0.6/src/register-allocator.cc +100 -0
- data/ext/v8/upstream/2.0.6/src/register-allocator.h +295 -0
- data/ext/v8/upstream/2.0.6/src/rewriter.cc +855 -0
- data/ext/v8/upstream/2.0.6/src/rewriter.h +54 -0
- data/ext/v8/upstream/2.0.6/src/runtime.cc +8163 -0
- data/ext/v8/upstream/2.0.6/src/runtime.h +432 -0
- data/ext/v8/upstream/2.0.6/src/runtime.js +626 -0
- data/ext/v8/upstream/2.0.6/src/scanner.cc +1098 -0
- data/ext/v8/upstream/2.0.6/src/scanner.h +425 -0
- data/ext/v8/upstream/2.0.6/src/scopeinfo.cc +649 -0
- data/ext/v8/upstream/2.0.6/src/scopeinfo.h +236 -0
- data/ext/v8/upstream/2.0.6/src/scopes.cc +963 -0
- data/ext/v8/upstream/2.0.6/src/scopes.h +401 -0
- data/ext/v8/upstream/2.0.6/src/serialize.cc +1260 -0
- data/ext/v8/upstream/2.0.6/src/serialize.h +404 -0
- data/ext/v8/upstream/2.0.6/src/shell.h +55 -0
- data/ext/v8/upstream/2.0.6/src/simulator.h +41 -0
- data/ext/v8/upstream/2.0.6/src/smart-pointer.h +109 -0
- data/ext/v8/upstream/2.0.6/src/snapshot-common.cc +97 -0
- data/ext/v8/upstream/2.0.6/src/snapshot-empty.cc +40 -0
- data/ext/v8/upstream/2.0.6/src/snapshot.h +59 -0
- data/ext/v8/upstream/2.0.6/src/spaces-inl.h +372 -0
- data/ext/v8/upstream/2.0.6/src/spaces.cc +2864 -0
- data/ext/v8/upstream/2.0.6/src/spaces.h +2072 -0
- data/ext/v8/upstream/2.0.6/src/string-stream.cc +584 -0
- data/ext/v8/upstream/2.0.6/src/string-stream.h +189 -0
- data/ext/v8/upstream/2.0.6/src/string.js +901 -0
- data/ext/v8/upstream/2.0.6/src/stub-cache.cc +1108 -0
- data/ext/v8/upstream/2.0.6/src/stub-cache.h +578 -0
- data/ext/v8/upstream/2.0.6/src/third_party/dtoa/COPYING +15 -0
- data/ext/v8/upstream/2.0.6/src/third_party/dtoa/dtoa.c +3330 -0
- data/ext/v8/upstream/2.0.6/src/third_party/valgrind/valgrind.h +3925 -0
- data/ext/v8/upstream/2.0.6/src/token.cc +56 -0
- data/ext/v8/upstream/2.0.6/src/token.h +270 -0
- data/ext/v8/upstream/2.0.6/src/top.cc +991 -0
- data/ext/v8/upstream/2.0.6/src/top.h +459 -0
- data/ext/v8/upstream/2.0.6/src/unicode-inl.h +238 -0
- data/ext/v8/upstream/2.0.6/src/unicode.cc +749 -0
- data/ext/v8/upstream/2.0.6/src/unicode.h +279 -0
- data/ext/v8/upstream/2.0.6/src/uri.js +415 -0
- data/ext/v8/upstream/2.0.6/src/usage-analyzer.cc +426 -0
- data/ext/v8/upstream/2.0.6/src/usage-analyzer.h +40 -0
- data/ext/v8/upstream/2.0.6/src/utils.cc +322 -0
- data/ext/v8/upstream/2.0.6/src/utils.h +592 -0
- data/ext/v8/upstream/2.0.6/src/v8-counters.cc +55 -0
- data/ext/v8/upstream/2.0.6/src/v8-counters.h +198 -0
- data/ext/v8/upstream/2.0.6/src/v8.cc +193 -0
- data/ext/v8/upstream/2.0.6/src/v8.h +119 -0
- data/ext/v8/upstream/2.0.6/src/v8natives.js +846 -0
- data/ext/v8/upstream/2.0.6/src/v8threads.cc +450 -0
- data/ext/v8/upstream/2.0.6/src/v8threads.h +144 -0
- data/ext/v8/upstream/2.0.6/src/variables.cc +163 -0
- data/ext/v8/upstream/2.0.6/src/variables.h +235 -0
- data/ext/v8/upstream/2.0.6/src/version.cc +88 -0
- data/ext/v8/upstream/2.0.6/src/version.h +64 -0
- data/ext/v8/upstream/2.0.6/src/virtual-frame.cc +381 -0
- data/ext/v8/upstream/2.0.6/src/virtual-frame.h +44 -0
- data/ext/v8/upstream/2.0.6/src/x64/assembler-x64-inl.h +352 -0
- data/ext/v8/upstream/2.0.6/src/x64/assembler-x64.cc +2539 -0
- data/ext/v8/upstream/2.0.6/src/x64/assembler-x64.h +1399 -0
- data/ext/v8/upstream/2.0.6/src/x64/builtins-x64.cc +1255 -0
- data/ext/v8/upstream/2.0.6/src/x64/codegen-x64-inl.h +46 -0
- data/ext/v8/upstream/2.0.6/src/x64/codegen-x64.cc +8223 -0
- data/ext/v8/upstream/2.0.6/src/x64/codegen-x64.h +785 -0
- data/ext/v8/upstream/2.0.6/src/x64/cpu-x64.cc +79 -0
- data/ext/v8/upstream/2.0.6/src/x64/debug-x64.cc +202 -0
- data/ext/v8/upstream/2.0.6/src/x64/disasm-x64.cc +1596 -0
- data/ext/v8/upstream/2.0.6/src/x64/fast-codegen-x64.cc +1820 -0
- data/ext/v8/upstream/2.0.6/src/x64/frames-x64.cc +109 -0
- data/ext/v8/upstream/2.0.6/src/x64/frames-x64.h +121 -0
- data/ext/v8/upstream/2.0.6/src/x64/ic-x64.cc +1392 -0
- data/ext/v8/upstream/2.0.6/src/x64/jump-target-x64.cc +432 -0
- data/ext/v8/upstream/2.0.6/src/x64/macro-assembler-x64.cc +2409 -0
- data/ext/v8/upstream/2.0.6/src/x64/macro-assembler-x64.h +765 -0
- data/ext/v8/upstream/2.0.6/src/x64/regexp-macro-assembler-x64.cc +1337 -0
- data/ext/v8/upstream/2.0.6/src/x64/regexp-macro-assembler-x64.h +295 -0
- data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64-inl.h +86 -0
- data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64.cc +84 -0
- data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64.h +43 -0
- data/ext/v8/upstream/2.0.6/src/x64/simulator-x64.cc +27 -0
- data/ext/v8/upstream/2.0.6/src/x64/simulator-x64.h +63 -0
- data/ext/v8/upstream/2.0.6/src/x64/stub-cache-x64.cc +1884 -0
- data/ext/v8/upstream/2.0.6/src/x64/virtual-frame-x64.cc +1089 -0
- data/ext/v8/upstream/2.0.6/src/x64/virtual-frame-x64.h +560 -0
- data/ext/v8/upstream/2.0.6/src/zone-inl.h +297 -0
- data/ext/v8/upstream/2.0.6/src/zone.cc +193 -0
- data/ext/v8/upstream/2.0.6/src/zone.h +305 -0
- data/ext/v8/upstream/2.0.6/tools/codemap.js +258 -0
- data/ext/v8/upstream/2.0.6/tools/consarray.js +93 -0
- data/ext/v8/upstream/2.0.6/tools/csvparser.js +98 -0
- data/ext/v8/upstream/2.0.6/tools/gyp/v8.gyp +620 -0
- data/ext/v8/upstream/2.0.6/tools/js2c.py +376 -0
- data/ext/v8/upstream/2.0.6/tools/jsmin.py +280 -0
- data/ext/v8/upstream/2.0.6/tools/linux-tick-processor +24 -0
- data/ext/v8/upstream/2.0.6/tools/linux-tick-processor.py +78 -0
- data/ext/v8/upstream/2.0.6/tools/logreader.js +320 -0
- data/ext/v8/upstream/2.0.6/tools/mac-nm +18 -0
- data/ext/v8/upstream/2.0.6/tools/mac-tick-processor +6 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/annotate +7 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/common +19 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/dump +7 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/report +7 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/reset +7 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/run +14 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/shutdown +7 -0
- data/ext/v8/upstream/2.0.6/tools/oprofile/start +7 -0
- data/ext/v8/upstream/2.0.6/tools/presubmit.py +299 -0
- data/ext/v8/upstream/2.0.6/tools/process-heap-prof.py +120 -0
- data/ext/v8/upstream/2.0.6/tools/profile.js +621 -0
- data/ext/v8/upstream/2.0.6/tools/profile_view.js +224 -0
- data/ext/v8/upstream/2.0.6/tools/run-valgrind.py +77 -0
- data/ext/v8/upstream/2.0.6/tools/splaytree.js +322 -0
- data/ext/v8/upstream/2.0.6/tools/splaytree.py +226 -0
- data/ext/v8/upstream/2.0.6/tools/stats-viewer.py +456 -0
- data/ext/v8/upstream/2.0.6/tools/test.py +1370 -0
- data/ext/v8/upstream/2.0.6/tools/tickprocessor-driver.js +53 -0
- data/ext/v8/upstream/2.0.6/tools/tickprocessor.js +731 -0
- data/ext/v8/upstream/2.0.6/tools/tickprocessor.py +535 -0
- data/ext/v8/upstream/2.0.6/tools/utils.py +82 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/README.txt +71 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/arm.vsprops +14 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/common.vsprops +35 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/d8.vcproj +199 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/d8_arm.vcproj +199 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/d8_x64.vcproj +201 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/d8js2c.cmd +6 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/debug.vsprops +17 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/ia32.vsprops +13 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/js2c.cmd +6 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/release.vsprops +24 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8.sln +101 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8.vcproj +223 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_arm.sln +74 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_arm.vcproj +223 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base.vcproj +971 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base_arm.vcproj +983 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base_x64.vcproj +959 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest.vcproj +255 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest_arm.vcproj +243 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest_x64.vcproj +257 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_mksnapshot.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_mksnapshot_x64.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample_arm.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample_x64.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample_arm.vcproj +151 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample_x64.vcproj +153 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot.vcproj +142 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_cc.vcproj +92 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_cc_x64.vcproj +92 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_x64.vcproj +142 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_x64.sln +101 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_x64.vcproj +223 -0
- data/ext/v8/upstream/2.0.6/tools/visual_studio/x64.vsprops +13 -0
- data/ext/v8/upstream/2.0.6/tools/windows-tick-processor.bat +5 -0
- data/ext/v8/upstream/2.0.6/tools/windows-tick-processor.py +137 -0
- data/ext/v8/upstream/Makefile +31 -0
- data/ext/v8/upstream/no-strict-aliasing.patch +13 -0
- data/ext/v8/upstream/scons/CHANGES.txt +5183 -0
- data/ext/v8/upstream/scons/LICENSE.txt +20 -0
- data/ext/v8/upstream/scons/MANIFEST +202 -0
- data/ext/v8/upstream/scons/PKG-INFO +13 -0
- data/ext/v8/upstream/scons/README.txt +273 -0
- data/ext/v8/upstream/scons/RELEASE.txt +1040 -0
- data/ext/v8/upstream/scons/engine/SCons/Action.py +1256 -0
- data/ext/v8/upstream/scons/engine/SCons/Builder.py +868 -0
- data/ext/v8/upstream/scons/engine/SCons/CacheDir.py +217 -0
- data/ext/v8/upstream/scons/engine/SCons/Conftest.py +794 -0
- data/ext/v8/upstream/scons/engine/SCons/Debug.py +237 -0
- data/ext/v8/upstream/scons/engine/SCons/Defaults.py +485 -0
- data/ext/v8/upstream/scons/engine/SCons/Environment.py +2327 -0
- data/ext/v8/upstream/scons/engine/SCons/Errors.py +207 -0
- data/ext/v8/upstream/scons/engine/SCons/Executor.py +636 -0
- data/ext/v8/upstream/scons/engine/SCons/Job.py +435 -0
- data/ext/v8/upstream/scons/engine/SCons/Memoize.py +292 -0
- data/ext/v8/upstream/scons/engine/SCons/Node/Alias.py +153 -0
- data/ext/v8/upstream/scons/engine/SCons/Node/FS.py +3220 -0
- data/ext/v8/upstream/scons/engine/SCons/Node/Python.py +128 -0
- data/ext/v8/upstream/scons/engine/SCons/Node/__init__.py +1341 -0
- data/ext/v8/upstream/scons/engine/SCons/Options/BoolOption.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Options/EnumOption.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Options/ListOption.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Options/PackageOption.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Options/PathOption.py +76 -0
- data/ext/v8/upstream/scons/engine/SCons/Options/__init__.py +74 -0
- data/ext/v8/upstream/scons/engine/SCons/PathList.py +232 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/__init__.py +236 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/aix.py +70 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/cygwin.py +55 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/darwin.py +46 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/hpux.py +46 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/irix.py +44 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/os2.py +58 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/posix.py +264 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/sunos.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Platform/win32.py +386 -0
- data/ext/v8/upstream/scons/engine/SCons/SConf.py +1038 -0
- data/ext/v8/upstream/scons/engine/SCons/SConsign.py +381 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/C.py +132 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/D.py +74 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/Dir.py +111 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/Fortran.py +320 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/IDL.py +48 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/LaTeX.py +378 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/Prog.py +103 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/RC.py +55 -0
- data/ext/v8/upstream/scons/engine/SCons/Scanner/__init__.py +415 -0
- data/ext/v8/upstream/scons/engine/SCons/Script/Interactive.py +386 -0
- data/ext/v8/upstream/scons/engine/SCons/Script/Main.py +1360 -0
- data/ext/v8/upstream/scons/engine/SCons/Script/SConsOptions.py +944 -0
- data/ext/v8/upstream/scons/engine/SCons/Script/SConscript.py +642 -0
- data/ext/v8/upstream/scons/engine/SCons/Script/__init__.py +414 -0
- data/ext/v8/upstream/scons/engine/SCons/Sig.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Subst.py +911 -0
- data/ext/v8/upstream/scons/engine/SCons/Taskmaster.py +1030 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/386asm.py +61 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/BitKeeper.py +65 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/CVS.py +73 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/FortranCommon.py +247 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/JavaCommon.py +324 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/__init__.py +56 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/arch.py +61 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/common.py +210 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/netframework.py +84 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/sdk.py +321 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vc.py +367 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vs.py +497 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/Perforce.py +104 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/PharLapCommon.py +138 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/RCS.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/SCCS.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/Subversion.py +71 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/__init__.py +675 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/aixc++.py +82 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/aixcc.py +74 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/aixf77.py +80 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/aixlink.py +76 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/applelink.py +71 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/ar.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/as.py +78 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/bcc32.py +82 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/c++.py +99 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/cc.py +114 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/cvf.py +58 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/default.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/dmd.py +224 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/dvi.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/dvipdf.py +125 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/dvips.py +94 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/f77.py +62 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/f90.py +62 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/f95.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/filesystem.py +98 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/fortran.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/g++.py +90 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/g77.py +73 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/gas.py +53 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/gcc.py +80 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/gfortran.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/gnulink.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/gs.py +81 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/hpc++.py +85 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/hpcc.py +53 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/hplink.py +77 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/icc.py +59 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/icl.py +52 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/ifl.py +72 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/ifort.py +90 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/ilink.py +59 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/ilink32.py +60 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/install.py +229 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/intelc.py +490 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/ipkg.py +71 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/jar.py +110 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/javac.py +234 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/javah.py +138 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/latex.py +79 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/lex.py +99 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/link.py +121 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/linkloc.py +112 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/m4.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/masm.py +77 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/midl.py +90 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/mingw.py +159 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/mslib.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/mslink.py +266 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/mssdk.py +50 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/msvc.py +269 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/msvs.py +1439 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/mwcc.py +208 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/mwld.py +107 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/nasm.py +72 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/__init__.py +314 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/ipk.py +185 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/msi.py +526 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/rpm.py +367 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_tarbz2.py +43 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_targz.py +43 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_zip.py +43 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/tarbz2.py +44 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/targz.py +44 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/zip.py +44 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/pdf.py +78 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/pdflatex.py +83 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/pdftex.py +108 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/qt.py +336 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/rmic.py +121 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/rpcgen.py +70 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/rpm.py +132 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sgiar.py +68 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sgic++.py +58 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sgicc.py +53 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sgilink.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunar.py +67 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunc++.py +142 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/suncc.py +58 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunf77.py +63 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunf90.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunf95.py +64 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunlink.py +77 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/swig.py +186 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/tar.py +73 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/tex.py +805 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/textfile.py +175 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/tlib.py +53 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/wix.py +100 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/yacc.py +131 -0
- data/ext/v8/upstream/scons/engine/SCons/Tool/zip.py +100 -0
- data/ext/v8/upstream/scons/engine/SCons/Util.py +1645 -0
- data/ext/v8/upstream/scons/engine/SCons/Variables/BoolVariable.py +91 -0
- data/ext/v8/upstream/scons/engine/SCons/Variables/EnumVariable.py +107 -0
- data/ext/v8/upstream/scons/engine/SCons/Variables/ListVariable.py +139 -0
- data/ext/v8/upstream/scons/engine/SCons/Variables/PackageVariable.py +109 -0
- data/ext/v8/upstream/scons/engine/SCons/Variables/PathVariable.py +147 -0
- data/ext/v8/upstream/scons/engine/SCons/Variables/__init__.py +317 -0
- data/ext/v8/upstream/scons/engine/SCons/Warnings.py +228 -0
- data/ext/v8/upstream/scons/engine/SCons/__init__.py +49 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/__init__.py +302 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_UserString.py +98 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_hashlib.py +91 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_itertools.py +124 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_optparse.py +1725 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets.py +583 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets15.py +176 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_shlex.py +325 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_subprocess.py +1296 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_textwrap.py +382 -0
- data/ext/v8/upstream/scons/engine/SCons/compat/builtins.py +187 -0
- data/ext/v8/upstream/scons/engine/SCons/cpp.py +598 -0
- data/ext/v8/upstream/scons/engine/SCons/dblite.py +248 -0
- data/ext/v8/upstream/scons/engine/SCons/exitfuncs.py +77 -0
- data/ext/v8/upstream/scons/os_spawnv_fix.diff +83 -0
- data/ext/v8/upstream/scons/scons-time.1 +1017 -0
- data/ext/v8/upstream/scons/scons.1 +15179 -0
- data/ext/v8/upstream/scons/sconsign.1 +208 -0
- data/ext/v8/upstream/scons/script/scons +184 -0
- data/ext/v8/upstream/scons/script/scons-time +1529 -0
- data/ext/v8/upstream/scons/script/scons.bat +31 -0
- data/ext/v8/upstream/scons/script/sconsign +508 -0
- data/ext/v8/upstream/scons/setup.cfg +6 -0
- data/ext/v8/upstream/scons/setup.py +427 -0
- data/ext/v8/v8.cpp +89 -0
- data/ext/v8/v8_cxt.cpp +92 -0
- data/ext/v8/v8_cxt.h +20 -0
- data/ext/v8/v8_func.cpp +10 -0
- data/ext/v8/v8_func.h +11 -0
- data/ext/v8/v8_msg.cpp +54 -0
- data/ext/v8/v8_msg.h +18 -0
- data/ext/v8/v8_obj.cpp +52 -0
- data/ext/v8/v8_obj.h +13 -0
- data/ext/v8/v8_ref.cpp +26 -0
- data/ext/v8/v8_ref.h +31 -0
- data/ext/v8/v8_script.cpp +20 -0
- data/ext/v8/v8_script.h +8 -0
- data/ext/v8/v8_standalone.cpp +69 -0
- data/ext/v8/v8_standalone.h +31 -0
- data/ext/v8/v8_str.cpp +17 -0
- data/ext/v8/v8_str.h +9 -0
- data/ext/v8/v8_template.cpp +53 -0
- data/ext/v8/v8_template.h +13 -0
- data/lib/v8.rb +10 -0
- data/lib/v8/context.rb +101 -0
- data/lib/v8/object.rb +38 -0
- data/lib/v8/to.rb +33 -0
- data/lib/v8/v8.so +0 -0
- data/script/console +10 -0
- data/script/destroy +14 -0
- data/script/generate +14 -0
- data/spec/ext/cxt_spec.rb +25 -0
- data/spec/ext/obj_spec.rb +13 -0
- data/spec/redjs/jsapi_spec.rb +405 -0
- data/spec/redjs/tap.rb +8 -0
- data/spec/redjs_helper.rb +3 -0
- data/spec/spec.opts +1 -0
- data/spec/spec_helper.rb +14 -0
- data/spec/v8/to_spec.rb +15 -0
- data/tasks/rspec.rake +21 -0
- data/therubyracer.gemspec +680 -0
- metadata +697 -0
@@ -0,0 +1,1089 @@
|
|
1
|
+
// Copyright 2009 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-inl.h"
|
31
|
+
#include "register-allocator-inl.h"
|
32
|
+
#include "scopes.h"
|
33
|
+
|
34
|
+
namespace v8 {
|
35
|
+
namespace internal {
|
36
|
+
|
37
|
+
#define __ ACCESS_MASM(masm())
|
38
|
+
|
39
|
+
// -------------------------------------------------------------------------
|
40
|
+
// VirtualFrame implementation.
|
41
|
+
|
42
|
+
// On entry to a function, the virtual frame already contains the receiver,
|
43
|
+
// the parameters, and a return address. All frame elements are in memory.
|
44
|
+
VirtualFrame::VirtualFrame()
|
45
|
+
: elements_(parameter_count() + local_count() + kPreallocatedElements),
|
46
|
+
stack_pointer_(parameter_count() + 1) { // 0-based index of TOS.
|
47
|
+
for (int i = 0; i <= stack_pointer_; i++) {
|
48
|
+
elements_.Add(FrameElement::MemoryElement());
|
49
|
+
}
|
50
|
+
for (int i = 0; i < RegisterAllocator::kNumRegisters; i++) {
|
51
|
+
register_locations_[i] = kIllegalIndex;
|
52
|
+
}
|
53
|
+
}
|
54
|
+
|
55
|
+
|
56
|
+
void VirtualFrame::Enter() {
|
57
|
+
// Registers live on entry to a JS frame:
|
58
|
+
// rsp: stack pointer, points to return address from this function.
|
59
|
+
// rbp: base pointer, points to previous JS, ArgumentsAdaptor, or
|
60
|
+
// Trampoline frame.
|
61
|
+
// rsi: context of this function call.
|
62
|
+
// rdi: pointer to this function object.
|
63
|
+
Comment cmnt(masm(), "[ Enter JS frame");
|
64
|
+
|
65
|
+
#ifdef DEBUG
|
66
|
+
if (FLAG_debug_code) {
|
67
|
+
// Verify that rdi contains a JS function. The following code
|
68
|
+
// relies on rax being available for use.
|
69
|
+
Condition not_smi = NegateCondition(masm()->CheckSmi(rdi));
|
70
|
+
__ Check(not_smi,
|
71
|
+
"VirtualFrame::Enter - rdi is not a function (smi check).");
|
72
|
+
__ CmpObjectType(rdi, JS_FUNCTION_TYPE, rax);
|
73
|
+
__ Check(equal,
|
74
|
+
"VirtualFrame::Enter - rdi is not a function (map check).");
|
75
|
+
}
|
76
|
+
#endif
|
77
|
+
|
78
|
+
EmitPush(rbp);
|
79
|
+
|
80
|
+
__ movq(rbp, rsp);
|
81
|
+
|
82
|
+
// Store the context in the frame. The context is kept in rsi and a
|
83
|
+
// copy is stored in the frame. The external reference to rsi
|
84
|
+
// remains.
|
85
|
+
EmitPush(rsi);
|
86
|
+
|
87
|
+
// Store the function in the frame. The frame owns the register
|
88
|
+
// reference now (ie, it can keep it in rdi or spill it later).
|
89
|
+
Push(rdi);
|
90
|
+
SyncElementAt(element_count() - 1);
|
91
|
+
cgen()->allocator()->Unuse(rdi);
|
92
|
+
}
|
93
|
+
|
94
|
+
|
95
|
+
void VirtualFrame::Exit() {
|
96
|
+
Comment cmnt(masm(), "[ Exit JS frame");
|
97
|
+
// Record the location of the JS exit code for patching when setting
|
98
|
+
// break point.
|
99
|
+
__ RecordJSReturn();
|
100
|
+
|
101
|
+
// Avoid using the leave instruction here, because it is too
|
102
|
+
// short. We need the return sequence to be a least the size of a
|
103
|
+
// call instruction to support patching the exit code in the
|
104
|
+
// debugger. See GenerateReturnSequence for the full return sequence.
|
105
|
+
// TODO(X64): A patched call will be very long now. Make sure we
|
106
|
+
// have enough room.
|
107
|
+
__ movq(rsp, rbp);
|
108
|
+
stack_pointer_ = frame_pointer();
|
109
|
+
for (int i = element_count() - 1; i > stack_pointer_; i--) {
|
110
|
+
FrameElement last = elements_.RemoveLast();
|
111
|
+
if (last.is_register()) {
|
112
|
+
Unuse(last.reg());
|
113
|
+
}
|
114
|
+
}
|
115
|
+
|
116
|
+
EmitPop(rbp);
|
117
|
+
}
|
118
|
+
|
119
|
+
|
120
|
+
void VirtualFrame::AllocateStackSlots() {
|
121
|
+
int count = local_count();
|
122
|
+
if (count > 0) {
|
123
|
+
Comment cmnt(masm(), "[ Allocate space for locals");
|
124
|
+
// The locals are initialized to a constant (the undefined value), but
|
125
|
+
// we sync them with the actual frame to allocate space for spilling
|
126
|
+
// them later. First sync everything above the stack pointer so we can
|
127
|
+
// use pushes to allocate and initialize the locals.
|
128
|
+
SyncRange(stack_pointer_ + 1, element_count() - 1);
|
129
|
+
Handle<Object> undefined = Factory::undefined_value();
|
130
|
+
FrameElement initial_value =
|
131
|
+
FrameElement::ConstantElement(undefined, FrameElement::SYNCED);
|
132
|
+
if (count == 1) {
|
133
|
+
__ Push(undefined);
|
134
|
+
} else if (count < kLocalVarBound) {
|
135
|
+
// For less locals the unrolled loop is more compact.
|
136
|
+
__ movq(kScratchRegister, undefined, RelocInfo::EMBEDDED_OBJECT);
|
137
|
+
for (int i = 0; i < count; i++) {
|
138
|
+
__ push(kScratchRegister);
|
139
|
+
}
|
140
|
+
} else {
|
141
|
+
// For more locals a loop in generated code is more compact.
|
142
|
+
Label alloc_locals_loop;
|
143
|
+
Result cnt = cgen()->allocator()->Allocate();
|
144
|
+
ASSERT(cnt.is_valid());
|
145
|
+
__ movq(cnt.reg(), Immediate(count));
|
146
|
+
__ movq(kScratchRegister, undefined, RelocInfo::EMBEDDED_OBJECT);
|
147
|
+
__ bind(&alloc_locals_loop);
|
148
|
+
__ push(kScratchRegister);
|
149
|
+
__ decl(cnt.reg());
|
150
|
+
__ j(not_zero, &alloc_locals_loop);
|
151
|
+
}
|
152
|
+
for (int i = 0; i < count; i++) {
|
153
|
+
elements_.Add(initial_value);
|
154
|
+
stack_pointer_++;
|
155
|
+
}
|
156
|
+
}
|
157
|
+
}
|
158
|
+
|
159
|
+
|
160
|
+
void VirtualFrame::SaveContextRegister() {
|
161
|
+
ASSERT(elements_[context_index()].is_memory());
|
162
|
+
__ movq(Operand(rbp, fp_relative(context_index())), rsi);
|
163
|
+
}
|
164
|
+
|
165
|
+
|
166
|
+
void VirtualFrame::RestoreContextRegister() {
|
167
|
+
ASSERT(elements_[context_index()].is_memory());
|
168
|
+
__ movq(rsi, Operand(rbp, fp_relative(context_index())));
|
169
|
+
}
|
170
|
+
|
171
|
+
|
172
|
+
void VirtualFrame::PushReceiverSlotAddress() {
|
173
|
+
Result temp = cgen()->allocator()->Allocate();
|
174
|
+
ASSERT(temp.is_valid());
|
175
|
+
__ lea(temp.reg(), ParameterAt(-1));
|
176
|
+
Push(&temp);
|
177
|
+
}
|
178
|
+
|
179
|
+
|
180
|
+
void VirtualFrame::EmitPop(Register reg) {
|
181
|
+
ASSERT(stack_pointer_ == element_count() - 1);
|
182
|
+
stack_pointer_--;
|
183
|
+
elements_.RemoveLast();
|
184
|
+
__ pop(reg);
|
185
|
+
}
|
186
|
+
|
187
|
+
|
188
|
+
void VirtualFrame::EmitPop(const Operand& operand) {
|
189
|
+
ASSERT(stack_pointer_ == element_count() - 1);
|
190
|
+
stack_pointer_--;
|
191
|
+
elements_.RemoveLast();
|
192
|
+
__ pop(operand);
|
193
|
+
}
|
194
|
+
|
195
|
+
|
196
|
+
void VirtualFrame::EmitPush(Register reg) {
|
197
|
+
ASSERT(stack_pointer_ == element_count() - 1);
|
198
|
+
elements_.Add(FrameElement::MemoryElement());
|
199
|
+
stack_pointer_++;
|
200
|
+
__ push(reg);
|
201
|
+
}
|
202
|
+
|
203
|
+
|
204
|
+
void VirtualFrame::EmitPush(const Operand& operand) {
|
205
|
+
ASSERT(stack_pointer_ == element_count() - 1);
|
206
|
+
elements_.Add(FrameElement::MemoryElement());
|
207
|
+
stack_pointer_++;
|
208
|
+
__ push(operand);
|
209
|
+
}
|
210
|
+
|
211
|
+
|
212
|
+
void VirtualFrame::EmitPush(Immediate immediate) {
|
213
|
+
ASSERT(stack_pointer_ == element_count() - 1);
|
214
|
+
elements_.Add(FrameElement::MemoryElement());
|
215
|
+
stack_pointer_++;
|
216
|
+
__ push(immediate);
|
217
|
+
}
|
218
|
+
|
219
|
+
|
220
|
+
void VirtualFrame::EmitPush(Smi* smi_value) {
|
221
|
+
ASSERT(stack_pointer_ == element_count() - 1);
|
222
|
+
elements_.Add(FrameElement::MemoryElement());
|
223
|
+
stack_pointer_++;
|
224
|
+
__ Push(smi_value);
|
225
|
+
}
|
226
|
+
|
227
|
+
|
228
|
+
void VirtualFrame::EmitPush(Handle<Object> value) {
|
229
|
+
ASSERT(stack_pointer_ == element_count() - 1);
|
230
|
+
elements_.Add(FrameElement::MemoryElement());
|
231
|
+
stack_pointer_++;
|
232
|
+
__ Push(value);
|
233
|
+
}
|
234
|
+
|
235
|
+
|
236
|
+
void VirtualFrame::EmitPush(Heap::RootListIndex index) {
|
237
|
+
ASSERT(stack_pointer_ == element_count() - 1);
|
238
|
+
elements_.Add(FrameElement::MemoryElement());
|
239
|
+
stack_pointer_++;
|
240
|
+
__ PushRoot(index);
|
241
|
+
}
|
242
|
+
|
243
|
+
|
244
|
+
void VirtualFrame::Drop(int count) {
|
245
|
+
ASSERT(count >= 0);
|
246
|
+
ASSERT(height() >= count);
|
247
|
+
int num_virtual_elements = (element_count() - 1) - stack_pointer_;
|
248
|
+
|
249
|
+
// Emit code to lower the stack pointer if necessary.
|
250
|
+
if (num_virtual_elements < count) {
|
251
|
+
int num_dropped = count - num_virtual_elements;
|
252
|
+
stack_pointer_ -= num_dropped;
|
253
|
+
__ addq(rsp, Immediate(num_dropped * kPointerSize));
|
254
|
+
}
|
255
|
+
|
256
|
+
// Discard elements from the virtual frame and free any registers.
|
257
|
+
for (int i = 0; i < count; i++) {
|
258
|
+
FrameElement dropped = elements_.RemoveLast();
|
259
|
+
if (dropped.is_register()) {
|
260
|
+
Unuse(dropped.reg());
|
261
|
+
}
|
262
|
+
}
|
263
|
+
}
|
264
|
+
|
265
|
+
|
266
|
+
int VirtualFrame::InvalidateFrameSlotAt(int index) {
|
267
|
+
FrameElement original = elements_[index];
|
268
|
+
|
269
|
+
// Is this element the backing store of any copies?
|
270
|
+
int new_backing_index = kIllegalIndex;
|
271
|
+
if (original.is_copied()) {
|
272
|
+
// Verify it is copied, and find first copy.
|
273
|
+
for (int i = index + 1; i < element_count(); i++) {
|
274
|
+
if (elements_[i].is_copy() && elements_[i].index() == index) {
|
275
|
+
new_backing_index = i;
|
276
|
+
break;
|
277
|
+
}
|
278
|
+
}
|
279
|
+
}
|
280
|
+
|
281
|
+
if (new_backing_index == kIllegalIndex) {
|
282
|
+
// No copies found, return kIllegalIndex.
|
283
|
+
if (original.is_register()) {
|
284
|
+
Unuse(original.reg());
|
285
|
+
}
|
286
|
+
elements_[index] = FrameElement::InvalidElement();
|
287
|
+
return kIllegalIndex;
|
288
|
+
}
|
289
|
+
|
290
|
+
// This is the backing store of copies.
|
291
|
+
Register backing_reg;
|
292
|
+
if (original.is_memory()) {
|
293
|
+
Result fresh = cgen()->allocator()->Allocate();
|
294
|
+
ASSERT(fresh.is_valid());
|
295
|
+
Use(fresh.reg(), new_backing_index);
|
296
|
+
backing_reg = fresh.reg();
|
297
|
+
__ movq(backing_reg, Operand(rbp, fp_relative(index)));
|
298
|
+
} else {
|
299
|
+
// The original was in a register.
|
300
|
+
backing_reg = original.reg();
|
301
|
+
set_register_location(backing_reg, new_backing_index);
|
302
|
+
}
|
303
|
+
// Invalidate the element at index.
|
304
|
+
elements_[index] = FrameElement::InvalidElement();
|
305
|
+
// Set the new backing element.
|
306
|
+
if (elements_[new_backing_index].is_synced()) {
|
307
|
+
elements_[new_backing_index] =
|
308
|
+
FrameElement::RegisterElement(backing_reg, FrameElement::SYNCED);
|
309
|
+
} else {
|
310
|
+
elements_[new_backing_index] =
|
311
|
+
FrameElement::RegisterElement(backing_reg, FrameElement::NOT_SYNCED);
|
312
|
+
}
|
313
|
+
// Update the other copies.
|
314
|
+
for (int i = new_backing_index + 1; i < element_count(); i++) {
|
315
|
+
if (elements_[i].is_copy() && elements_[i].index() == index) {
|
316
|
+
elements_[i].set_index(new_backing_index);
|
317
|
+
elements_[new_backing_index].set_copied();
|
318
|
+
}
|
319
|
+
}
|
320
|
+
return new_backing_index;
|
321
|
+
}
|
322
|
+
|
323
|
+
|
324
|
+
void VirtualFrame::TakeFrameSlotAt(int index) {
|
325
|
+
ASSERT(index >= 0);
|
326
|
+
ASSERT(index <= element_count());
|
327
|
+
FrameElement original = elements_[index];
|
328
|
+
int new_backing_store_index = InvalidateFrameSlotAt(index);
|
329
|
+
if (new_backing_store_index != kIllegalIndex) {
|
330
|
+
elements_.Add(CopyElementAt(new_backing_store_index));
|
331
|
+
return;
|
332
|
+
}
|
333
|
+
|
334
|
+
switch (original.type()) {
|
335
|
+
case FrameElement::MEMORY: {
|
336
|
+
// Emit code to load the original element's data into a register.
|
337
|
+
// Push that register as a FrameElement on top of the frame.
|
338
|
+
Result fresh = cgen()->allocator()->Allocate();
|
339
|
+
ASSERT(fresh.is_valid());
|
340
|
+
FrameElement new_element =
|
341
|
+
FrameElement::RegisterElement(fresh.reg(),
|
342
|
+
FrameElement::NOT_SYNCED);
|
343
|
+
Use(fresh.reg(), element_count());
|
344
|
+
elements_.Add(new_element);
|
345
|
+
__ movq(fresh.reg(), Operand(rbp, fp_relative(index)));
|
346
|
+
break;
|
347
|
+
}
|
348
|
+
case FrameElement::REGISTER:
|
349
|
+
Use(original.reg(), element_count());
|
350
|
+
// Fall through.
|
351
|
+
case FrameElement::CONSTANT:
|
352
|
+
case FrameElement::COPY:
|
353
|
+
original.clear_sync();
|
354
|
+
elements_.Add(original);
|
355
|
+
break;
|
356
|
+
case FrameElement::INVALID:
|
357
|
+
UNREACHABLE();
|
358
|
+
break;
|
359
|
+
}
|
360
|
+
}
|
361
|
+
|
362
|
+
|
363
|
+
void VirtualFrame::StoreToFrameSlotAt(int index) {
|
364
|
+
// Store the value on top of the frame to the virtual frame slot at
|
365
|
+
// a given index. The value on top of the frame is left in place.
|
366
|
+
// This is a duplicating operation, so it can create copies.
|
367
|
+
ASSERT(index >= 0);
|
368
|
+
ASSERT(index < element_count());
|
369
|
+
|
370
|
+
int top_index = element_count() - 1;
|
371
|
+
FrameElement top = elements_[top_index];
|
372
|
+
FrameElement original = elements_[index];
|
373
|
+
if (top.is_copy() && top.index() == index) return;
|
374
|
+
ASSERT(top.is_valid());
|
375
|
+
|
376
|
+
InvalidateFrameSlotAt(index);
|
377
|
+
|
378
|
+
// InvalidateFrameSlotAt can potentially change any frame element, due
|
379
|
+
// to spilling registers to allocate temporaries in order to preserve
|
380
|
+
// the copy-on-write semantics of aliased elements. Reload top from
|
381
|
+
// the frame.
|
382
|
+
top = elements_[top_index];
|
383
|
+
|
384
|
+
if (top.is_copy()) {
|
385
|
+
// There are two cases based on the relative positions of the
|
386
|
+
// stored-to slot and the backing slot of the top element.
|
387
|
+
int backing_index = top.index();
|
388
|
+
ASSERT(backing_index != index);
|
389
|
+
if (backing_index < index) {
|
390
|
+
// 1. The top element is a copy of a slot below the stored-to
|
391
|
+
// slot. The stored-to slot becomes an unsynced copy of that
|
392
|
+
// same backing slot.
|
393
|
+
elements_[index] = CopyElementAt(backing_index);
|
394
|
+
} else {
|
395
|
+
// 2. The top element is a copy of a slot above the stored-to
|
396
|
+
// slot. The stored-to slot becomes the new (unsynced) backing
|
397
|
+
// slot and both the top element and the element at the former
|
398
|
+
// backing slot become copies of it. The sync state of the top
|
399
|
+
// and former backing elements is preserved.
|
400
|
+
FrameElement backing_element = elements_[backing_index];
|
401
|
+
ASSERT(backing_element.is_memory() || backing_element.is_register());
|
402
|
+
if (backing_element.is_memory()) {
|
403
|
+
// Because sets of copies are canonicalized to be backed by
|
404
|
+
// their lowest frame element, and because memory frame
|
405
|
+
// elements are backed by the corresponding stack address, we
|
406
|
+
// have to move the actual value down in the stack.
|
407
|
+
//
|
408
|
+
// TODO(209): considering allocating the stored-to slot to the
|
409
|
+
// temp register. Alternatively, allow copies to appear in
|
410
|
+
// any order in the frame and lazily move the value down to
|
411
|
+
// the slot.
|
412
|
+
__ movq(kScratchRegister, Operand(rbp, fp_relative(backing_index)));
|
413
|
+
__ movq(Operand(rbp, fp_relative(index)), kScratchRegister);
|
414
|
+
} else {
|
415
|
+
set_register_location(backing_element.reg(), index);
|
416
|
+
if (backing_element.is_synced()) {
|
417
|
+
// If the element is a register, we will not actually move
|
418
|
+
// anything on the stack but only update the virtual frame
|
419
|
+
// element.
|
420
|
+
backing_element.clear_sync();
|
421
|
+
}
|
422
|
+
}
|
423
|
+
elements_[index] = backing_element;
|
424
|
+
|
425
|
+
// The old backing element becomes a copy of the new backing
|
426
|
+
// element.
|
427
|
+
FrameElement new_element = CopyElementAt(index);
|
428
|
+
elements_[backing_index] = new_element;
|
429
|
+
if (backing_element.is_synced()) {
|
430
|
+
elements_[backing_index].set_sync();
|
431
|
+
}
|
432
|
+
|
433
|
+
// All the copies of the old backing element (including the top
|
434
|
+
// element) become copies of the new backing element.
|
435
|
+
for (int i = backing_index + 1; i < element_count(); i++) {
|
436
|
+
if (elements_[i].is_copy() && elements_[i].index() == backing_index) {
|
437
|
+
elements_[i].set_index(index);
|
438
|
+
}
|
439
|
+
}
|
440
|
+
}
|
441
|
+
return;
|
442
|
+
}
|
443
|
+
|
444
|
+
// Move the top element to the stored-to slot and replace it (the
|
445
|
+
// top element) with a copy.
|
446
|
+
elements_[index] = top;
|
447
|
+
if (top.is_memory()) {
|
448
|
+
// TODO(209): consider allocating the stored-to slot to the temp
|
449
|
+
// register. Alternatively, allow copies to appear in any order
|
450
|
+
// in the frame and lazily move the value down to the slot.
|
451
|
+
FrameElement new_top = CopyElementAt(index);
|
452
|
+
new_top.set_sync();
|
453
|
+
elements_[top_index] = new_top;
|
454
|
+
|
455
|
+
// The sync state of the former top element is correct (synced).
|
456
|
+
// Emit code to move the value down in the frame.
|
457
|
+
__ movq(kScratchRegister, Operand(rsp, 0));
|
458
|
+
__ movq(Operand(rbp, fp_relative(index)), kScratchRegister);
|
459
|
+
} else if (top.is_register()) {
|
460
|
+
set_register_location(top.reg(), index);
|
461
|
+
// The stored-to slot has the (unsynced) register reference and
|
462
|
+
// the top element becomes a copy. The sync state of the top is
|
463
|
+
// preserved.
|
464
|
+
FrameElement new_top = CopyElementAt(index);
|
465
|
+
if (top.is_synced()) {
|
466
|
+
new_top.set_sync();
|
467
|
+
elements_[index].clear_sync();
|
468
|
+
}
|
469
|
+
elements_[top_index] = new_top;
|
470
|
+
} else {
|
471
|
+
// The stored-to slot holds the same value as the top but
|
472
|
+
// unsynced. (We do not have copies of constants yet.)
|
473
|
+
ASSERT(top.is_constant());
|
474
|
+
elements_[index].clear_sync();
|
475
|
+
}
|
476
|
+
}
|
477
|
+
|
478
|
+
|
479
|
+
void VirtualFrame::MakeMergable() {
|
480
|
+
for (int i = 0; i < element_count(); i++) {
|
481
|
+
FrameElement element = elements_[i];
|
482
|
+
|
483
|
+
if (element.is_constant() || element.is_copy()) {
|
484
|
+
if (element.is_synced()) {
|
485
|
+
// Just spill.
|
486
|
+
elements_[i] = FrameElement::MemoryElement();
|
487
|
+
} else {
|
488
|
+
// Allocate to a register.
|
489
|
+
FrameElement backing_element; // Invalid if not a copy.
|
490
|
+
if (element.is_copy()) {
|
491
|
+
backing_element = elements_[element.index()];
|
492
|
+
}
|
493
|
+
Result fresh = cgen()->allocator()->Allocate();
|
494
|
+
ASSERT(fresh.is_valid()); // A register was spilled if all were in use.
|
495
|
+
elements_[i] =
|
496
|
+
FrameElement::RegisterElement(fresh.reg(),
|
497
|
+
FrameElement::NOT_SYNCED);
|
498
|
+
Use(fresh.reg(), i);
|
499
|
+
|
500
|
+
// Emit a move.
|
501
|
+
if (element.is_constant()) {
|
502
|
+
__ Move(fresh.reg(), element.handle());
|
503
|
+
} else {
|
504
|
+
ASSERT(element.is_copy());
|
505
|
+
// Copies are only backed by register or memory locations.
|
506
|
+
if (backing_element.is_register()) {
|
507
|
+
// The backing store may have been spilled by allocating,
|
508
|
+
// but that's OK. If it was, the value is right where we
|
509
|
+
// want it.
|
510
|
+
if (!fresh.reg().is(backing_element.reg())) {
|
511
|
+
__ movq(fresh.reg(), backing_element.reg());
|
512
|
+
}
|
513
|
+
} else {
|
514
|
+
ASSERT(backing_element.is_memory());
|
515
|
+
__ movq(fresh.reg(), Operand(rbp, fp_relative(element.index())));
|
516
|
+
}
|
517
|
+
}
|
518
|
+
}
|
519
|
+
// No need to set the copied flag --- there are no copies.
|
520
|
+
} else {
|
521
|
+
// Clear the copy flag of non-constant, non-copy elements.
|
522
|
+
// They cannot be copied because copies are not allowed.
|
523
|
+
// The copy flag is not relied on before the end of this loop,
|
524
|
+
// including when registers are spilled.
|
525
|
+
elements_[i].clear_copied();
|
526
|
+
}
|
527
|
+
}
|
528
|
+
}
|
529
|
+
|
530
|
+
|
531
|
+
void VirtualFrame::MergeTo(VirtualFrame* expected) {
|
532
|
+
Comment cmnt(masm(), "[ Merge frame");
|
533
|
+
// We should always be merging the code generator's current frame to an
|
534
|
+
// expected frame.
|
535
|
+
ASSERT(cgen()->frame() == this);
|
536
|
+
|
537
|
+
// Adjust the stack pointer upward (toward the top of the virtual
|
538
|
+
// frame) if necessary.
|
539
|
+
if (stack_pointer_ < expected->stack_pointer_) {
|
540
|
+
int difference = expected->stack_pointer_ - stack_pointer_;
|
541
|
+
stack_pointer_ = expected->stack_pointer_;
|
542
|
+
__ subq(rsp, Immediate(difference * kPointerSize));
|
543
|
+
}
|
544
|
+
|
545
|
+
MergeMoveRegistersToMemory(expected);
|
546
|
+
MergeMoveRegistersToRegisters(expected);
|
547
|
+
MergeMoveMemoryToRegisters(expected);
|
548
|
+
|
549
|
+
// Adjust the stack pointer downward if necessary.
|
550
|
+
if (stack_pointer_ > expected->stack_pointer_) {
|
551
|
+
int difference = stack_pointer_ - expected->stack_pointer_;
|
552
|
+
stack_pointer_ = expected->stack_pointer_;
|
553
|
+
__ addq(rsp, Immediate(difference * kPointerSize));
|
554
|
+
}
|
555
|
+
|
556
|
+
// At this point, the frames should be identical.
|
557
|
+
ASSERT(Equals(expected));
|
558
|
+
}
|
559
|
+
|
560
|
+
|
561
|
+
void VirtualFrame::MergeMoveRegistersToMemory(VirtualFrame* expected) {
|
562
|
+
ASSERT(stack_pointer_ >= expected->stack_pointer_);
|
563
|
+
|
564
|
+
// Move registers, constants, and copies to memory. Perform moves
|
565
|
+
// from the top downward in the frame in order to leave the backing
|
566
|
+
// stores of copies in registers.
|
567
|
+
for (int i = element_count() - 1; i >= 0; i--) {
|
568
|
+
FrameElement target = expected->elements_[i];
|
569
|
+
if (target.is_register()) continue; // Handle registers later.
|
570
|
+
if (target.is_memory()) {
|
571
|
+
FrameElement source = elements_[i];
|
572
|
+
switch (source.type()) {
|
573
|
+
case FrameElement::INVALID:
|
574
|
+
// Not a legal merge move.
|
575
|
+
UNREACHABLE();
|
576
|
+
break;
|
577
|
+
|
578
|
+
case FrameElement::MEMORY:
|
579
|
+
// Already in place.
|
580
|
+
break;
|
581
|
+
|
582
|
+
case FrameElement::REGISTER:
|
583
|
+
Unuse(source.reg());
|
584
|
+
if (!source.is_synced()) {
|
585
|
+
__ movq(Operand(rbp, fp_relative(i)), source.reg());
|
586
|
+
}
|
587
|
+
break;
|
588
|
+
|
589
|
+
case FrameElement::CONSTANT:
|
590
|
+
if (!source.is_synced()) {
|
591
|
+
__ Move(Operand(rbp, fp_relative(i)), source.handle());
|
592
|
+
}
|
593
|
+
break;
|
594
|
+
|
595
|
+
case FrameElement::COPY:
|
596
|
+
if (!source.is_synced()) {
|
597
|
+
int backing_index = source.index();
|
598
|
+
FrameElement backing_element = elements_[backing_index];
|
599
|
+
if (backing_element.is_memory()) {
|
600
|
+
__ movq(kScratchRegister,
|
601
|
+
Operand(rbp, fp_relative(backing_index)));
|
602
|
+
__ movq(Operand(rbp, fp_relative(i)), kScratchRegister);
|
603
|
+
} else {
|
604
|
+
ASSERT(backing_element.is_register());
|
605
|
+
__ movq(Operand(rbp, fp_relative(i)), backing_element.reg());
|
606
|
+
}
|
607
|
+
}
|
608
|
+
break;
|
609
|
+
}
|
610
|
+
}
|
611
|
+
elements_[i] = target;
|
612
|
+
}
|
613
|
+
}
|
614
|
+
|
615
|
+
|
616
|
+
void VirtualFrame::MergeMoveRegistersToRegisters(VirtualFrame* expected) {
|
617
|
+
// We have already done X-to-memory moves.
|
618
|
+
ASSERT(stack_pointer_ >= expected->stack_pointer_);
|
619
|
+
|
620
|
+
for (int i = 0; i < RegisterAllocator::kNumRegisters; i++) {
|
621
|
+
// Move the right value into register i if it is currently in a register.
|
622
|
+
int index = expected->register_location(i);
|
623
|
+
int use_index = register_location(i);
|
624
|
+
// Skip if register i is unused in the target or else if source is
|
625
|
+
// not a register (this is not a register-to-register move).
|
626
|
+
if (index == kIllegalIndex || !elements_[index].is_register()) continue;
|
627
|
+
|
628
|
+
Register target = RegisterAllocator::ToRegister(i);
|
629
|
+
Register source = elements_[index].reg();
|
630
|
+
if (index != use_index) {
|
631
|
+
if (use_index == kIllegalIndex) { // Target is currently unused.
|
632
|
+
// Copy contents of source from source to target.
|
633
|
+
// Set frame element register to target.
|
634
|
+
Use(target, index);
|
635
|
+
Unuse(source);
|
636
|
+
__ movq(target, source);
|
637
|
+
} else {
|
638
|
+
// Exchange contents of registers source and target.
|
639
|
+
// Nothing except the register backing use_index has changed.
|
640
|
+
elements_[use_index].set_reg(source);
|
641
|
+
set_register_location(target, index);
|
642
|
+
set_register_location(source, use_index);
|
643
|
+
__ xchg(source, target);
|
644
|
+
}
|
645
|
+
}
|
646
|
+
|
647
|
+
if (!elements_[index].is_synced() &&
|
648
|
+
expected->elements_[index].is_synced()) {
|
649
|
+
__ movq(Operand(rbp, fp_relative(index)), target);
|
650
|
+
}
|
651
|
+
elements_[index] = expected->elements_[index];
|
652
|
+
}
|
653
|
+
}
|
654
|
+
|
655
|
+
|
656
|
+
void VirtualFrame::MergeMoveMemoryToRegisters(VirtualFrame* expected) {
|
657
|
+
// Move memory, constants, and copies to registers. This is the
|
658
|
+
// final step and since it is not done from the bottom up, but in
|
659
|
+
// register code order, we have special code to ensure that the backing
|
660
|
+
// elements of copies are in their correct locations when we
|
661
|
+
// encounter the copies.
|
662
|
+
for (int i = 0; i < RegisterAllocator::kNumRegisters; i++) {
|
663
|
+
int index = expected->register_location(i);
|
664
|
+
if (index != kIllegalIndex) {
|
665
|
+
FrameElement source = elements_[index];
|
666
|
+
FrameElement target = expected->elements_[index];
|
667
|
+
Register target_reg = RegisterAllocator::ToRegister(i);
|
668
|
+
ASSERT(target.reg().is(target_reg));
|
669
|
+
switch (source.type()) {
|
670
|
+
case FrameElement::INVALID: // Fall through.
|
671
|
+
UNREACHABLE();
|
672
|
+
break;
|
673
|
+
case FrameElement::REGISTER:
|
674
|
+
ASSERT(source.Equals(target));
|
675
|
+
// Go to next iteration. Skips Use(target_reg) and syncing
|
676
|
+
// below. It is safe to skip syncing because a target
|
677
|
+
// register frame element would only be synced if all source
|
678
|
+
// elements were.
|
679
|
+
continue;
|
680
|
+
break;
|
681
|
+
case FrameElement::MEMORY:
|
682
|
+
ASSERT(index <= stack_pointer_);
|
683
|
+
__ movq(target_reg, Operand(rbp, fp_relative(index)));
|
684
|
+
break;
|
685
|
+
|
686
|
+
case FrameElement::CONSTANT:
|
687
|
+
__ Move(target_reg, source.handle());
|
688
|
+
break;
|
689
|
+
|
690
|
+
case FrameElement::COPY: {
|
691
|
+
int backing_index = source.index();
|
692
|
+
FrameElement backing = elements_[backing_index];
|
693
|
+
ASSERT(backing.is_memory() || backing.is_register());
|
694
|
+
if (backing.is_memory()) {
|
695
|
+
ASSERT(backing_index <= stack_pointer_);
|
696
|
+
// Code optimization if backing store should also move
|
697
|
+
// to a register: move backing store to its register first.
|
698
|
+
if (expected->elements_[backing_index].is_register()) {
|
699
|
+
FrameElement new_backing = expected->elements_[backing_index];
|
700
|
+
Register new_backing_reg = new_backing.reg();
|
701
|
+
ASSERT(!is_used(new_backing_reg));
|
702
|
+
elements_[backing_index] = new_backing;
|
703
|
+
Use(new_backing_reg, backing_index);
|
704
|
+
__ movq(new_backing_reg,
|
705
|
+
Operand(rbp, fp_relative(backing_index)));
|
706
|
+
__ movq(target_reg, new_backing_reg);
|
707
|
+
} else {
|
708
|
+
__ movq(target_reg, Operand(rbp, fp_relative(backing_index)));
|
709
|
+
}
|
710
|
+
} else {
|
711
|
+
__ movq(target_reg, backing.reg());
|
712
|
+
}
|
713
|
+
}
|
714
|
+
}
|
715
|
+
// Ensure the proper sync state.
|
716
|
+
if (target.is_synced() && !source.is_synced()) {
|
717
|
+
__ movq(Operand(rbp, fp_relative(index)), target_reg);
|
718
|
+
}
|
719
|
+
Use(target_reg, index);
|
720
|
+
elements_[index] = target;
|
721
|
+
}
|
722
|
+
}
|
723
|
+
}
|
724
|
+
|
725
|
+
|
726
|
+
Result VirtualFrame::Pop() {
|
727
|
+
FrameElement element = elements_.RemoveLast();
|
728
|
+
int index = element_count();
|
729
|
+
ASSERT(element.is_valid());
|
730
|
+
|
731
|
+
bool pop_needed = (stack_pointer_ == index);
|
732
|
+
if (pop_needed) {
|
733
|
+
stack_pointer_--;
|
734
|
+
if (element.is_memory()) {
|
735
|
+
Result temp = cgen()->allocator()->Allocate();
|
736
|
+
ASSERT(temp.is_valid());
|
737
|
+
__ pop(temp.reg());
|
738
|
+
return temp;
|
739
|
+
}
|
740
|
+
|
741
|
+
__ addq(rsp, Immediate(kPointerSize));
|
742
|
+
}
|
743
|
+
ASSERT(!element.is_memory());
|
744
|
+
|
745
|
+
// The top element is a register, constant, or a copy. Unuse
|
746
|
+
// registers and follow copies to their backing store.
|
747
|
+
if (element.is_register()) {
|
748
|
+
Unuse(element.reg());
|
749
|
+
} else if (element.is_copy()) {
|
750
|
+
ASSERT(element.index() < index);
|
751
|
+
index = element.index();
|
752
|
+
element = elements_[index];
|
753
|
+
}
|
754
|
+
ASSERT(!element.is_copy());
|
755
|
+
|
756
|
+
// The element is memory, a register, or a constant.
|
757
|
+
if (element.is_memory()) {
|
758
|
+
// Memory elements could only be the backing store of a copy.
|
759
|
+
// Allocate the original to a register.
|
760
|
+
ASSERT(index <= stack_pointer_);
|
761
|
+
Result temp = cgen()->allocator()->Allocate();
|
762
|
+
ASSERT(temp.is_valid());
|
763
|
+
Use(temp.reg(), index);
|
764
|
+
FrameElement new_element =
|
765
|
+
FrameElement::RegisterElement(temp.reg(), FrameElement::SYNCED);
|
766
|
+
// Preserve the copy flag on the element.
|
767
|
+
if (element.is_copied()) new_element.set_copied();
|
768
|
+
elements_[index] = new_element;
|
769
|
+
__ movq(temp.reg(), Operand(rbp, fp_relative(index)));
|
770
|
+
return Result(temp.reg());
|
771
|
+
} else if (element.is_register()) {
|
772
|
+
return Result(element.reg());
|
773
|
+
} else {
|
774
|
+
ASSERT(element.is_constant());
|
775
|
+
return Result(element.handle());
|
776
|
+
}
|
777
|
+
}
|
778
|
+
|
779
|
+
|
780
|
+
Result VirtualFrame::RawCallStub(CodeStub* stub) {
|
781
|
+
ASSERT(cgen()->HasValidEntryRegisters());
|
782
|
+
__ CallStub(stub);
|
783
|
+
Result result = cgen()->allocator()->Allocate(rax);
|
784
|
+
ASSERT(result.is_valid());
|
785
|
+
return result;
|
786
|
+
}
|
787
|
+
|
788
|
+
|
789
|
+
Result VirtualFrame::CallStub(CodeStub* stub, Result* arg) {
|
790
|
+
PrepareForCall(0, 0);
|
791
|
+
arg->ToRegister(rax);
|
792
|
+
arg->Unuse();
|
793
|
+
return RawCallStub(stub);
|
794
|
+
}
|
795
|
+
|
796
|
+
|
797
|
+
Result VirtualFrame::CallStub(CodeStub* stub, Result* arg0, Result* arg1) {
|
798
|
+
PrepareForCall(0, 0);
|
799
|
+
|
800
|
+
if (arg0->is_register() && arg0->reg().is(rax)) {
|
801
|
+
if (arg1->is_register() && arg1->reg().is(rdx)) {
|
802
|
+
// Wrong registers.
|
803
|
+
__ xchg(rax, rdx);
|
804
|
+
} else {
|
805
|
+
// Register rdx is free for arg0, which frees rax for arg1.
|
806
|
+
arg0->ToRegister(rdx);
|
807
|
+
arg1->ToRegister(rax);
|
808
|
+
}
|
809
|
+
} else {
|
810
|
+
// Register rax is free for arg1, which guarantees rdx is free for
|
811
|
+
// arg0.
|
812
|
+
arg1->ToRegister(rax);
|
813
|
+
arg0->ToRegister(rdx);
|
814
|
+
}
|
815
|
+
|
816
|
+
arg0->Unuse();
|
817
|
+
arg1->Unuse();
|
818
|
+
return RawCallStub(stub);
|
819
|
+
}
|
820
|
+
|
821
|
+
|
822
|
+
void VirtualFrame::SyncElementBelowStackPointer(int index) {
|
823
|
+
// Emit code to write elements below the stack pointer to their
|
824
|
+
// (already allocated) stack address.
|
825
|
+
ASSERT(index <= stack_pointer_);
|
826
|
+
FrameElement element = elements_[index];
|
827
|
+
ASSERT(!element.is_synced());
|
828
|
+
switch (element.type()) {
|
829
|
+
case FrameElement::INVALID:
|
830
|
+
break;
|
831
|
+
|
832
|
+
case FrameElement::MEMORY:
|
833
|
+
// This function should not be called with synced elements.
|
834
|
+
// (memory elements are always synced).
|
835
|
+
UNREACHABLE();
|
836
|
+
break;
|
837
|
+
|
838
|
+
case FrameElement::REGISTER:
|
839
|
+
__ movq(Operand(rbp, fp_relative(index)), element.reg());
|
840
|
+
break;
|
841
|
+
|
842
|
+
case FrameElement::CONSTANT:
|
843
|
+
__ Move(Operand(rbp, fp_relative(index)), element.handle());
|
844
|
+
break;
|
845
|
+
|
846
|
+
case FrameElement::COPY: {
|
847
|
+
int backing_index = element.index();
|
848
|
+
FrameElement backing_element = elements_[backing_index];
|
849
|
+
if (backing_element.is_memory()) {
|
850
|
+
__ movq(kScratchRegister, Operand(rbp, fp_relative(backing_index)));
|
851
|
+
__ movq(Operand(rbp, fp_relative(index)), kScratchRegister);
|
852
|
+
} else {
|
853
|
+
ASSERT(backing_element.is_register());
|
854
|
+
__ movq(Operand(rbp, fp_relative(index)), backing_element.reg());
|
855
|
+
}
|
856
|
+
break;
|
857
|
+
}
|
858
|
+
}
|
859
|
+
elements_[index].set_sync();
|
860
|
+
}
|
861
|
+
|
862
|
+
|
863
|
+
void VirtualFrame::SyncElementByPushing(int index) {
|
864
|
+
// Sync an element of the frame that is just above the stack pointer
|
865
|
+
// by pushing it.
|
866
|
+
ASSERT(index == stack_pointer_ + 1);
|
867
|
+
stack_pointer_++;
|
868
|
+
FrameElement element = elements_[index];
|
869
|
+
|
870
|
+
switch (element.type()) {
|
871
|
+
case FrameElement::INVALID:
|
872
|
+
__ Push(Smi::FromInt(0));
|
873
|
+
break;
|
874
|
+
|
875
|
+
case FrameElement::MEMORY:
|
876
|
+
// No memory elements exist above the stack pointer.
|
877
|
+
UNREACHABLE();
|
878
|
+
break;
|
879
|
+
|
880
|
+
case FrameElement::REGISTER:
|
881
|
+
__ push(element.reg());
|
882
|
+
break;
|
883
|
+
|
884
|
+
case FrameElement::CONSTANT:
|
885
|
+
__ Move(kScratchRegister, element.handle());
|
886
|
+
__ push(kScratchRegister);
|
887
|
+
break;
|
888
|
+
|
889
|
+
case FrameElement::COPY: {
|
890
|
+
int backing_index = element.index();
|
891
|
+
FrameElement backing = elements_[backing_index];
|
892
|
+
ASSERT(backing.is_memory() || backing.is_register());
|
893
|
+
if (backing.is_memory()) {
|
894
|
+
__ push(Operand(rbp, fp_relative(backing_index)));
|
895
|
+
} else {
|
896
|
+
__ push(backing.reg());
|
897
|
+
}
|
898
|
+
break;
|
899
|
+
}
|
900
|
+
}
|
901
|
+
elements_[index].set_sync();
|
902
|
+
}
|
903
|
+
|
904
|
+
|
905
|
+
// Clear the dirty bits for the range of elements in
|
906
|
+
// [min(stack_pointer_ + 1,begin), end].
|
907
|
+
void VirtualFrame::SyncRange(int begin, int end) {
|
908
|
+
ASSERT(begin >= 0);
|
909
|
+
ASSERT(end < element_count());
|
910
|
+
// Sync elements below the range if they have not been materialized
|
911
|
+
// on the stack.
|
912
|
+
int start = Min(begin, stack_pointer_ + 1);
|
913
|
+
|
914
|
+
// If positive we have to adjust the stack pointer.
|
915
|
+
int delta = end - stack_pointer_;
|
916
|
+
if (delta > 0) {
|
917
|
+
stack_pointer_ = end;
|
918
|
+
__ subq(rsp, Immediate(delta * kPointerSize));
|
919
|
+
}
|
920
|
+
|
921
|
+
for (int i = start; i <= end; i++) {
|
922
|
+
if (!elements_[i].is_synced()) SyncElementBelowStackPointer(i);
|
923
|
+
}
|
924
|
+
}
|
925
|
+
|
926
|
+
|
927
|
+
Result VirtualFrame::InvokeBuiltin(Builtins::JavaScript id,
|
928
|
+
InvokeFlag flag,
|
929
|
+
int arg_count) {
|
930
|
+
PrepareForCall(arg_count, arg_count);
|
931
|
+
ASSERT(cgen()->HasValidEntryRegisters());
|
932
|
+
__ InvokeBuiltin(id, flag);
|
933
|
+
Result result = cgen()->allocator()->Allocate(rax);
|
934
|
+
ASSERT(result.is_valid());
|
935
|
+
return result;
|
936
|
+
}
|
937
|
+
|
938
|
+
|
939
|
+
//------------------------------------------------------------------------------
|
940
|
+
// Virtual frame stub and IC calling functions.
|
941
|
+
|
942
|
+
Result VirtualFrame::RawCallCodeObject(Handle<Code> code,
|
943
|
+
RelocInfo::Mode rmode) {
|
944
|
+
ASSERT(cgen()->HasValidEntryRegisters());
|
945
|
+
__ Call(code, rmode);
|
946
|
+
Result result = cgen()->allocator()->Allocate(rax);
|
947
|
+
ASSERT(result.is_valid());
|
948
|
+
return result;
|
949
|
+
}
|
950
|
+
|
951
|
+
|
952
|
+
Result VirtualFrame::CallRuntime(Runtime::Function* f, int arg_count) {
|
953
|
+
PrepareForCall(arg_count, arg_count);
|
954
|
+
ASSERT(cgen()->HasValidEntryRegisters());
|
955
|
+
__ CallRuntime(f, arg_count);
|
956
|
+
Result result = cgen()->allocator()->Allocate(rax);
|
957
|
+
ASSERT(result.is_valid());
|
958
|
+
return result;
|
959
|
+
}
|
960
|
+
|
961
|
+
|
962
|
+
Result VirtualFrame::CallRuntime(Runtime::FunctionId id, int arg_count) {
|
963
|
+
PrepareForCall(arg_count, arg_count);
|
964
|
+
ASSERT(cgen()->HasValidEntryRegisters());
|
965
|
+
__ CallRuntime(id, arg_count);
|
966
|
+
Result result = cgen()->allocator()->Allocate(rax);
|
967
|
+
ASSERT(result.is_valid());
|
968
|
+
return result;
|
969
|
+
}
|
970
|
+
|
971
|
+
|
972
|
+
Result VirtualFrame::CallLoadIC(RelocInfo::Mode mode) {
|
973
|
+
// Name and receiver are on the top of the frame. The IC expects
|
974
|
+
// name in rcx and receiver on the stack. It does not drop the
|
975
|
+
// receiver.
|
976
|
+
Handle<Code> ic(Builtins::builtin(Builtins::LoadIC_Initialize));
|
977
|
+
Result name = Pop();
|
978
|
+
PrepareForCall(1, 0); // One stack arg, not callee-dropped.
|
979
|
+
name.ToRegister(rcx);
|
980
|
+
name.Unuse();
|
981
|
+
return RawCallCodeObject(ic, mode);
|
982
|
+
}
|
983
|
+
|
984
|
+
|
985
|
+
Result VirtualFrame::CallKeyedLoadIC(RelocInfo::Mode mode) {
|
986
|
+
// Key and receiver are on top of the frame. The IC expects them on
|
987
|
+
// the stack. It does not drop them.
|
988
|
+
Handle<Code> ic(Builtins::builtin(Builtins::KeyedLoadIC_Initialize));
|
989
|
+
PrepareForCall(2, 0); // Two stack args, neither callee-dropped.
|
990
|
+
return RawCallCodeObject(ic, mode);
|
991
|
+
}
|
992
|
+
|
993
|
+
|
994
|
+
Result VirtualFrame::CallKeyedStoreIC() {
|
995
|
+
// Value, key, and receiver are on the top of the frame. The IC
|
996
|
+
// expects value in rax and key and receiver on the stack. It does
|
997
|
+
// not drop the key and receiver.
|
998
|
+
Handle<Code> ic(Builtins::builtin(Builtins::KeyedStoreIC_Initialize));
|
999
|
+
// TODO(1222589): Make the IC grab the values from the stack.
|
1000
|
+
Result value = Pop();
|
1001
|
+
PrepareForCall(2, 0); // Two stack args, neither callee-dropped.
|
1002
|
+
value.ToRegister(rax);
|
1003
|
+
value.Unuse();
|
1004
|
+
return RawCallCodeObject(ic, RelocInfo::CODE_TARGET);
|
1005
|
+
}
|
1006
|
+
|
1007
|
+
|
1008
|
+
Result VirtualFrame::CallCallIC(RelocInfo::Mode mode,
|
1009
|
+
int arg_count,
|
1010
|
+
int loop_nesting) {
|
1011
|
+
// Arguments, receiver, and function name are on top of the frame.
|
1012
|
+
// The IC expects them on the stack. It does not drop the function
|
1013
|
+
// name slot (but it does drop the rest).
|
1014
|
+
InLoopFlag in_loop = loop_nesting > 0 ? IN_LOOP : NOT_IN_LOOP;
|
1015
|
+
Handle<Code> ic = cgen()->ComputeCallInitialize(arg_count, in_loop);
|
1016
|
+
// Spill args, receiver, and function. The call will drop args and
|
1017
|
+
// receiver.
|
1018
|
+
PrepareForCall(arg_count + 2, arg_count + 1);
|
1019
|
+
return RawCallCodeObject(ic, mode);
|
1020
|
+
}
|
1021
|
+
|
1022
|
+
|
1023
|
+
Result VirtualFrame::CallConstructor(int arg_count) {
|
1024
|
+
// Arguments, receiver, and function are on top of the frame. The
|
1025
|
+
// IC expects arg count in rax, function in rdi, and the arguments
|
1026
|
+
// and receiver on the stack.
|
1027
|
+
Handle<Code> ic(Builtins::builtin(Builtins::JSConstructCall));
|
1028
|
+
// Duplicate the function before preparing the frame.
|
1029
|
+
PushElementAt(arg_count + 1);
|
1030
|
+
Result function = Pop();
|
1031
|
+
PrepareForCall(arg_count + 1, arg_count + 1); // Spill args and receiver.
|
1032
|
+
function.ToRegister(rdi);
|
1033
|
+
|
1034
|
+
// Constructors are called with the number of arguments in register
|
1035
|
+
// rax for now. Another option would be to have separate construct
|
1036
|
+
// call trampolines per different arguments counts encountered.
|
1037
|
+
Result num_args = cgen()->allocator()->Allocate(rax);
|
1038
|
+
ASSERT(num_args.is_valid());
|
1039
|
+
__ movq(num_args.reg(), Immediate(arg_count));
|
1040
|
+
|
1041
|
+
function.Unuse();
|
1042
|
+
num_args.Unuse();
|
1043
|
+
return RawCallCodeObject(ic, RelocInfo::CONSTRUCT_CALL);
|
1044
|
+
}
|
1045
|
+
|
1046
|
+
|
1047
|
+
Result VirtualFrame::CallStoreIC() {
|
1048
|
+
// Name, value, and receiver are on top of the frame. The IC
|
1049
|
+
// expects name in rcx, value in rax, and receiver on the stack. It
|
1050
|
+
// does not drop the receiver.
|
1051
|
+
Handle<Code> ic(Builtins::builtin(Builtins::StoreIC_Initialize));
|
1052
|
+
Result name = Pop();
|
1053
|
+
Result value = Pop();
|
1054
|
+
PrepareForCall(1, 0); // One stack arg, not callee-dropped.
|
1055
|
+
|
1056
|
+
if (value.is_register() && value.reg().is(rcx)) {
|
1057
|
+
if (name.is_register() && name.reg().is(rax)) {
|
1058
|
+
// Wrong registers.
|
1059
|
+
__ xchg(rax, rcx);
|
1060
|
+
} else {
|
1061
|
+
// Register rax is free for value, which frees rcx for name.
|
1062
|
+
value.ToRegister(rax);
|
1063
|
+
name.ToRegister(rcx);
|
1064
|
+
}
|
1065
|
+
} else {
|
1066
|
+
// Register rcx is free for name, which guarantees rax is free for
|
1067
|
+
// value.
|
1068
|
+
name.ToRegister(rcx);
|
1069
|
+
value.ToRegister(rax);
|
1070
|
+
}
|
1071
|
+
|
1072
|
+
name.Unuse();
|
1073
|
+
value.Unuse();
|
1074
|
+
return RawCallCodeObject(ic, RelocInfo::CODE_TARGET);
|
1075
|
+
}
|
1076
|
+
|
1077
|
+
|
1078
|
+
void VirtualFrame::PushTryHandler(HandlerType type) {
|
1079
|
+
ASSERT(cgen()->HasValidEntryRegisters());
|
1080
|
+
// Grow the expression stack by handler size less one (the return
|
1081
|
+
// address is already pushed by a call instruction).
|
1082
|
+
Adjust(kHandlerSize - 1);
|
1083
|
+
__ PushTryHandler(IN_JAVASCRIPT, type);
|
1084
|
+
}
|
1085
|
+
|
1086
|
+
|
1087
|
+
#undef __
|
1088
|
+
|
1089
|
+
} } // namespace v8::internal
|