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,79 @@
|
|
1
|
+
// Copyright 2006-2008 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
|
+
// CPU specific code for ia32 independent of OS goes here.
|
29
|
+
|
30
|
+
#ifdef __GNUC__
|
31
|
+
#include "third_party/valgrind/valgrind.h"
|
32
|
+
#endif
|
33
|
+
|
34
|
+
#include "v8.h"
|
35
|
+
|
36
|
+
#include "cpu.h"
|
37
|
+
#include "macro-assembler.h"
|
38
|
+
|
39
|
+
namespace v8 {
|
40
|
+
namespace internal {
|
41
|
+
|
42
|
+
void CPU::Setup() {
|
43
|
+
CpuFeatures::Probe();
|
44
|
+
}
|
45
|
+
|
46
|
+
|
47
|
+
void CPU::FlushICache(void* start, size_t size) {
|
48
|
+
// No need to flush the instruction cache on Intel. On Intel instruction
|
49
|
+
// cache flushing is only necessary when multiple cores running the same
|
50
|
+
// code simultaneously. V8 (and JavaScript) is single threaded and when code
|
51
|
+
// is patched on an intel CPU the core performing the patching will have its
|
52
|
+
// own instruction cache updated automatically.
|
53
|
+
|
54
|
+
// If flushing of the instruction cache becomes necessary Windows has the
|
55
|
+
// API function FlushInstructionCache.
|
56
|
+
|
57
|
+
// By default, valgrind only checks the stack for writes that might need to
|
58
|
+
// invalidate already cached translated code. This leads to random
|
59
|
+
// instability when code patches or moves are sometimes unnoticed. One
|
60
|
+
// solution is to run valgrind with --smc-check=all, but this comes at a big
|
61
|
+
// performance cost. We can notify valgrind to invalidate its cache.
|
62
|
+
#ifdef VALGRIND_DISCARD_TRANSLATIONS
|
63
|
+
VALGRIND_DISCARD_TRANSLATIONS(start, size);
|
64
|
+
#endif
|
65
|
+
}
|
66
|
+
|
67
|
+
|
68
|
+
void CPU::DebugBreak() {
|
69
|
+
#ifdef _MSC_VER
|
70
|
+
// To avoid Visual Studio runtime support the following code can be used
|
71
|
+
// instead
|
72
|
+
// __asm { int 3 }
|
73
|
+
__debugbreak();
|
74
|
+
#else
|
75
|
+
asm("int $3");
|
76
|
+
#endif
|
77
|
+
}
|
78
|
+
|
79
|
+
} } // namespace v8::internal
|
@@ -0,0 +1,208 @@
|
|
1
|
+
// Copyright 2006-2008 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 "debug.h"
|
32
|
+
|
33
|
+
|
34
|
+
namespace v8 {
|
35
|
+
namespace internal {
|
36
|
+
|
37
|
+
#ifdef ENABLE_DEBUGGER_SUPPORT
|
38
|
+
|
39
|
+
bool BreakLocationIterator::IsDebugBreakAtReturn() {
|
40
|
+
return Debug::IsDebugBreakAtReturn(rinfo());
|
41
|
+
}
|
42
|
+
|
43
|
+
|
44
|
+
// Patch the JS frame exit code with a debug break call. See
|
45
|
+
// CodeGenerator::VisitReturnStatement and VirtualFrame::Exit in codegen-ia32.cc
|
46
|
+
// for the precise return instructions sequence.
|
47
|
+
void BreakLocationIterator::SetDebugBreakAtReturn() {
|
48
|
+
ASSERT(Assembler::kJSReturnSequenceLength >=
|
49
|
+
Assembler::kCallInstructionLength);
|
50
|
+
rinfo()->PatchCodeWithCall(Debug::debug_break_return()->entry(),
|
51
|
+
Assembler::kJSReturnSequenceLength - Assembler::kCallInstructionLength);
|
52
|
+
}
|
53
|
+
|
54
|
+
|
55
|
+
// Restore the JS frame exit code.
|
56
|
+
void BreakLocationIterator::ClearDebugBreakAtReturn() {
|
57
|
+
rinfo()->PatchCode(original_rinfo()->pc(),
|
58
|
+
Assembler::kJSReturnSequenceLength);
|
59
|
+
}
|
60
|
+
|
61
|
+
|
62
|
+
// A debug break in the frame exit code is identified by the JS frame exit code
|
63
|
+
// having been patched with a call instruction.
|
64
|
+
bool Debug::IsDebugBreakAtReturn(RelocInfo* rinfo) {
|
65
|
+
ASSERT(RelocInfo::IsJSReturn(rinfo->rmode()));
|
66
|
+
return rinfo->IsPatchedReturnSequence();
|
67
|
+
}
|
68
|
+
|
69
|
+
|
70
|
+
#define __ ACCESS_MASM(masm)
|
71
|
+
|
72
|
+
|
73
|
+
static void Generate_DebugBreakCallHelper(MacroAssembler* masm,
|
74
|
+
RegList pointer_regs,
|
75
|
+
bool convert_call_to_jmp) {
|
76
|
+
// Save the content of all general purpose registers in memory. This copy in
|
77
|
+
// memory is later pushed onto the JS expression stack for the fake JS frame
|
78
|
+
// generated and also to the C frame generated on top of that. In the JS
|
79
|
+
// frame ONLY the registers containing pointers will be pushed on the
|
80
|
+
// expression stack. This causes the GC to update these pointers so that
|
81
|
+
// they will have the correct value when returning from the debugger.
|
82
|
+
__ SaveRegistersToMemory(kJSCallerSaved);
|
83
|
+
|
84
|
+
// Enter an internal frame.
|
85
|
+
__ EnterInternalFrame();
|
86
|
+
|
87
|
+
// Store the registers containing object pointers on the expression stack to
|
88
|
+
// make sure that these are correctly updated during GC.
|
89
|
+
__ PushRegistersFromMemory(pointer_regs);
|
90
|
+
|
91
|
+
#ifdef DEBUG
|
92
|
+
__ RecordComment("// Calling from debug break to runtime - come in - over");
|
93
|
+
#endif
|
94
|
+
__ Set(eax, Immediate(0)); // no arguments
|
95
|
+
__ mov(ebx, Immediate(ExternalReference::debug_break()));
|
96
|
+
|
97
|
+
CEntryDebugBreakStub ceb;
|
98
|
+
__ CallStub(&ceb);
|
99
|
+
|
100
|
+
// Restore the register values containing object pointers from the expression
|
101
|
+
// stack in the reverse order as they where pushed.
|
102
|
+
__ PopRegistersToMemory(pointer_regs);
|
103
|
+
|
104
|
+
// Get rid of the internal frame.
|
105
|
+
__ LeaveInternalFrame();
|
106
|
+
|
107
|
+
// If this call did not replace a call but patched other code then there will
|
108
|
+
// be an unwanted return address left on the stack. Here we get rid of that.
|
109
|
+
if (convert_call_to_jmp) {
|
110
|
+
__ pop(eax);
|
111
|
+
}
|
112
|
+
|
113
|
+
// Finally restore all registers.
|
114
|
+
__ RestoreRegistersFromMemory(kJSCallerSaved);
|
115
|
+
|
116
|
+
// Now that the break point has been handled, resume normal execution by
|
117
|
+
// jumping to the target address intended by the caller and that was
|
118
|
+
// overwritten by the address of DebugBreakXXX.
|
119
|
+
ExternalReference after_break_target =
|
120
|
+
ExternalReference(Debug_Address::AfterBreakTarget());
|
121
|
+
__ jmp(Operand::StaticVariable(after_break_target));
|
122
|
+
}
|
123
|
+
|
124
|
+
|
125
|
+
void Debug::GenerateLoadICDebugBreak(MacroAssembler* masm) {
|
126
|
+
// Register state for IC load call (from ic-ia32.cc).
|
127
|
+
// ----------- S t a t e -------------
|
128
|
+
// -- ecx : name
|
129
|
+
// -----------------------------------
|
130
|
+
Generate_DebugBreakCallHelper(masm, ecx.bit(), false);
|
131
|
+
}
|
132
|
+
|
133
|
+
|
134
|
+
void Debug::GenerateStoreICDebugBreak(MacroAssembler* masm) {
|
135
|
+
// REgister state for IC store call (from ic-ia32.cc).
|
136
|
+
// ----------- S t a t e -------------
|
137
|
+
// -- eax : value
|
138
|
+
// -- ecx : name
|
139
|
+
// -----------------------------------
|
140
|
+
Generate_DebugBreakCallHelper(masm, eax.bit() | ecx.bit(), false);
|
141
|
+
}
|
142
|
+
|
143
|
+
|
144
|
+
void Debug::GenerateKeyedLoadICDebugBreak(MacroAssembler* masm) {
|
145
|
+
// Register state for keyed IC load call (from ic-ia32.cc).
|
146
|
+
// ----------- S t a t e -------------
|
147
|
+
// No registers used on entry.
|
148
|
+
// -----------------------------------
|
149
|
+
Generate_DebugBreakCallHelper(masm, 0, false);
|
150
|
+
}
|
151
|
+
|
152
|
+
|
153
|
+
void Debug::GenerateKeyedStoreICDebugBreak(MacroAssembler* masm) {
|
154
|
+
// Register state for keyed IC load call (from ic-ia32.cc).
|
155
|
+
// ----------- S t a t e -------------
|
156
|
+
// -- eax : value
|
157
|
+
// -----------------------------------
|
158
|
+
// Register eax contains an object that needs to be pushed on the
|
159
|
+
// expression stack of the fake JS frame.
|
160
|
+
Generate_DebugBreakCallHelper(masm, eax.bit(), false);
|
161
|
+
}
|
162
|
+
|
163
|
+
|
164
|
+
void Debug::GenerateCallICDebugBreak(MacroAssembler* masm) {
|
165
|
+
// Register state for keyed IC call call (from ic-ia32.cc)
|
166
|
+
// ----------- S t a t e -------------
|
167
|
+
// -- eax: number of arguments
|
168
|
+
// -----------------------------------
|
169
|
+
// The number of arguments in eax is not smi encoded.
|
170
|
+
Generate_DebugBreakCallHelper(masm, 0, false);
|
171
|
+
}
|
172
|
+
|
173
|
+
|
174
|
+
void Debug::GenerateConstructCallDebugBreak(MacroAssembler* masm) {
|
175
|
+
// Register state just before return from JS function (from codegen-ia32.cc).
|
176
|
+
// eax is the actual number of arguments not encoded as a smi see comment
|
177
|
+
// above IC call.
|
178
|
+
// ----------- S t a t e -------------
|
179
|
+
// -- eax: number of arguments
|
180
|
+
// -----------------------------------
|
181
|
+
// The number of arguments in eax is not smi encoded.
|
182
|
+
Generate_DebugBreakCallHelper(masm, 0, false);
|
183
|
+
}
|
184
|
+
|
185
|
+
|
186
|
+
void Debug::GenerateReturnDebugBreak(MacroAssembler* masm) {
|
187
|
+
// Register state just before return from JS function (from codegen-ia32.cc).
|
188
|
+
// ----------- S t a t e -------------
|
189
|
+
// -- eax: return value
|
190
|
+
// -----------------------------------
|
191
|
+
Generate_DebugBreakCallHelper(masm, eax.bit(), true);
|
192
|
+
}
|
193
|
+
|
194
|
+
|
195
|
+
void Debug::GenerateStubNoRegistersDebugBreak(MacroAssembler* masm) {
|
196
|
+
// Register state for stub CallFunction (from CallFunctionStub in ic-ia32.cc).
|
197
|
+
// ----------- S t a t e -------------
|
198
|
+
// No registers used on entry.
|
199
|
+
// -----------------------------------
|
200
|
+
Generate_DebugBreakCallHelper(masm, 0, false);
|
201
|
+
}
|
202
|
+
|
203
|
+
|
204
|
+
#undef __
|
205
|
+
|
206
|
+
#endif // ENABLE_DEBUGGER_SUPPORT
|
207
|
+
|
208
|
+
} } // namespace v8::internal
|
@@ -0,0 +1,1357 @@
|
|
1
|
+
// Copyright 2007-2008 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 <assert.h>
|
29
|
+
#include <stdio.h>
|
30
|
+
#include <stdarg.h>
|
31
|
+
|
32
|
+
#include "v8.h"
|
33
|
+
#include "disasm.h"
|
34
|
+
|
35
|
+
namespace disasm {
|
36
|
+
|
37
|
+
enum OperandOrder {
|
38
|
+
UNSET_OP_ORDER = 0,
|
39
|
+
REG_OPER_OP_ORDER,
|
40
|
+
OPER_REG_OP_ORDER
|
41
|
+
};
|
42
|
+
|
43
|
+
|
44
|
+
//------------------------------------------------------------------
|
45
|
+
// Tables
|
46
|
+
//------------------------------------------------------------------
|
47
|
+
struct ByteMnemonic {
|
48
|
+
int b; // -1 terminates, otherwise must be in range (0..255)
|
49
|
+
const char* mnem;
|
50
|
+
OperandOrder op_order_;
|
51
|
+
};
|
52
|
+
|
53
|
+
|
54
|
+
static ByteMnemonic two_operands_instr[] = {
|
55
|
+
{0x03, "add", REG_OPER_OP_ORDER},
|
56
|
+
{0x21, "and", OPER_REG_OP_ORDER},
|
57
|
+
{0x23, "and", REG_OPER_OP_ORDER},
|
58
|
+
{0x3B, "cmp", REG_OPER_OP_ORDER},
|
59
|
+
{0x8D, "lea", REG_OPER_OP_ORDER},
|
60
|
+
{0x09, "or", OPER_REG_OP_ORDER},
|
61
|
+
{0x0B, "or", REG_OPER_OP_ORDER},
|
62
|
+
{0x1B, "sbb", REG_OPER_OP_ORDER},
|
63
|
+
{0x29, "sub", OPER_REG_OP_ORDER},
|
64
|
+
{0x2A, "subb", REG_OPER_OP_ORDER},
|
65
|
+
{0x2B, "sub", REG_OPER_OP_ORDER},
|
66
|
+
{0x85, "test", REG_OPER_OP_ORDER},
|
67
|
+
{0x31, "xor", OPER_REG_OP_ORDER},
|
68
|
+
{0x33, "xor", REG_OPER_OP_ORDER},
|
69
|
+
{0x87, "xchg", REG_OPER_OP_ORDER},
|
70
|
+
{0x8A, "mov_b", REG_OPER_OP_ORDER},
|
71
|
+
{0x8B, "mov", REG_OPER_OP_ORDER},
|
72
|
+
{-1, "", UNSET_OP_ORDER}
|
73
|
+
};
|
74
|
+
|
75
|
+
|
76
|
+
static ByteMnemonic zero_operands_instr[] = {
|
77
|
+
{0xC3, "ret", UNSET_OP_ORDER},
|
78
|
+
{0xC9, "leave", UNSET_OP_ORDER},
|
79
|
+
{0x90, "nop", UNSET_OP_ORDER},
|
80
|
+
{0xF4, "hlt", UNSET_OP_ORDER},
|
81
|
+
{0xCC, "int3", UNSET_OP_ORDER},
|
82
|
+
{0x60, "pushad", UNSET_OP_ORDER},
|
83
|
+
{0x61, "popad", UNSET_OP_ORDER},
|
84
|
+
{0x9C, "pushfd", UNSET_OP_ORDER},
|
85
|
+
{0x9D, "popfd", UNSET_OP_ORDER},
|
86
|
+
{0x9E, "sahf", UNSET_OP_ORDER},
|
87
|
+
{0x99, "cdq", UNSET_OP_ORDER},
|
88
|
+
{0x9B, "fwait", UNSET_OP_ORDER},
|
89
|
+
{-1, "", UNSET_OP_ORDER}
|
90
|
+
};
|
91
|
+
|
92
|
+
|
93
|
+
static ByteMnemonic call_jump_instr[] = {
|
94
|
+
{0xE8, "call", UNSET_OP_ORDER},
|
95
|
+
{0xE9, "jmp", UNSET_OP_ORDER},
|
96
|
+
{-1, "", UNSET_OP_ORDER}
|
97
|
+
};
|
98
|
+
|
99
|
+
|
100
|
+
static ByteMnemonic short_immediate_instr[] = {
|
101
|
+
{0x05, "add", UNSET_OP_ORDER},
|
102
|
+
{0x0D, "or", UNSET_OP_ORDER},
|
103
|
+
{0x15, "adc", UNSET_OP_ORDER},
|
104
|
+
{0x25, "and", UNSET_OP_ORDER},
|
105
|
+
{0x2D, "sub", UNSET_OP_ORDER},
|
106
|
+
{0x35, "xor", UNSET_OP_ORDER},
|
107
|
+
{0x3D, "cmp", UNSET_OP_ORDER},
|
108
|
+
{-1, "", UNSET_OP_ORDER}
|
109
|
+
};
|
110
|
+
|
111
|
+
|
112
|
+
static const char* jump_conditional_mnem[] = {
|
113
|
+
/*0*/ "jo", "jno", "jc", "jnc",
|
114
|
+
/*4*/ "jz", "jnz", "jna", "ja",
|
115
|
+
/*8*/ "js", "jns", "jpe", "jpo",
|
116
|
+
/*12*/ "jl", "jnl", "jng", "jg"
|
117
|
+
};
|
118
|
+
|
119
|
+
|
120
|
+
static const char* set_conditional_mnem[] = {
|
121
|
+
/*0*/ "seto", "setno", "setc", "setnc",
|
122
|
+
/*4*/ "setz", "setnz", "setna", "seta",
|
123
|
+
/*8*/ "sets", "setns", "setpe", "setpo",
|
124
|
+
/*12*/ "setl", "setnl", "setng", "setg"
|
125
|
+
};
|
126
|
+
|
127
|
+
|
128
|
+
static const char* conditional_move_mnem[] = {
|
129
|
+
/*0*/ "cmovo", "cmovno", "cmovc", "cmovnc",
|
130
|
+
/*4*/ "cmovz", "cmovnz", "cmovna", "cmova",
|
131
|
+
/*8*/ "cmovs", "cmovns", "cmovpe", "cmovpo",
|
132
|
+
/*12*/ "cmovl", "cmovnl", "cmovng", "cmovg"
|
133
|
+
};
|
134
|
+
|
135
|
+
|
136
|
+
enum InstructionType {
|
137
|
+
NO_INSTR,
|
138
|
+
ZERO_OPERANDS_INSTR,
|
139
|
+
TWO_OPERANDS_INSTR,
|
140
|
+
JUMP_CONDITIONAL_SHORT_INSTR,
|
141
|
+
REGISTER_INSTR,
|
142
|
+
MOVE_REG_INSTR,
|
143
|
+
CALL_JUMP_INSTR,
|
144
|
+
SHORT_IMMEDIATE_INSTR
|
145
|
+
};
|
146
|
+
|
147
|
+
|
148
|
+
struct InstructionDesc {
|
149
|
+
const char* mnem;
|
150
|
+
InstructionType type;
|
151
|
+
OperandOrder op_order_;
|
152
|
+
};
|
153
|
+
|
154
|
+
|
155
|
+
class InstructionTable {
|
156
|
+
public:
|
157
|
+
InstructionTable();
|
158
|
+
const InstructionDesc& Get(byte x) const { return instructions_[x]; }
|
159
|
+
|
160
|
+
private:
|
161
|
+
InstructionDesc instructions_[256];
|
162
|
+
void Clear();
|
163
|
+
void Init();
|
164
|
+
void CopyTable(ByteMnemonic bm[], InstructionType type);
|
165
|
+
void SetTableRange(InstructionType type,
|
166
|
+
byte start,
|
167
|
+
byte end,
|
168
|
+
const char* mnem);
|
169
|
+
void AddJumpConditionalShort();
|
170
|
+
};
|
171
|
+
|
172
|
+
|
173
|
+
InstructionTable::InstructionTable() {
|
174
|
+
Clear();
|
175
|
+
Init();
|
176
|
+
}
|
177
|
+
|
178
|
+
|
179
|
+
void InstructionTable::Clear() {
|
180
|
+
for (int i = 0; i < 256; i++) {
|
181
|
+
instructions_[i].mnem = "";
|
182
|
+
instructions_[i].type = NO_INSTR;
|
183
|
+
instructions_[i].op_order_ = UNSET_OP_ORDER;
|
184
|
+
}
|
185
|
+
}
|
186
|
+
|
187
|
+
|
188
|
+
void InstructionTable::Init() {
|
189
|
+
CopyTable(two_operands_instr, TWO_OPERANDS_INSTR);
|
190
|
+
CopyTable(zero_operands_instr, ZERO_OPERANDS_INSTR);
|
191
|
+
CopyTable(call_jump_instr, CALL_JUMP_INSTR);
|
192
|
+
CopyTable(short_immediate_instr, SHORT_IMMEDIATE_INSTR);
|
193
|
+
AddJumpConditionalShort();
|
194
|
+
SetTableRange(REGISTER_INSTR, 0x40, 0x47, "inc");
|
195
|
+
SetTableRange(REGISTER_INSTR, 0x48, 0x4F, "dec");
|
196
|
+
SetTableRange(REGISTER_INSTR, 0x50, 0x57, "push");
|
197
|
+
SetTableRange(REGISTER_INSTR, 0x58, 0x5F, "pop");
|
198
|
+
SetTableRange(REGISTER_INSTR, 0x91, 0x97, "xchg eax,"); // 0x90 is nop.
|
199
|
+
SetTableRange(MOVE_REG_INSTR, 0xB8, 0xBF, "mov");
|
200
|
+
}
|
201
|
+
|
202
|
+
|
203
|
+
void InstructionTable::CopyTable(ByteMnemonic bm[], InstructionType type) {
|
204
|
+
for (int i = 0; bm[i].b >= 0; i++) {
|
205
|
+
InstructionDesc* id = &instructions_[bm[i].b];
|
206
|
+
id->mnem = bm[i].mnem;
|
207
|
+
id->op_order_ = bm[i].op_order_;
|
208
|
+
ASSERT_EQ(NO_INSTR, id->type); // Information not already entered.
|
209
|
+
id->type = type;
|
210
|
+
}
|
211
|
+
}
|
212
|
+
|
213
|
+
|
214
|
+
void InstructionTable::SetTableRange(InstructionType type,
|
215
|
+
byte start,
|
216
|
+
byte end,
|
217
|
+
const char* mnem) {
|
218
|
+
for (byte b = start; b <= end; b++) {
|
219
|
+
InstructionDesc* id = &instructions_[b];
|
220
|
+
ASSERT_EQ(NO_INSTR, id->type); // Information not already entered.
|
221
|
+
id->mnem = mnem;
|
222
|
+
id->type = type;
|
223
|
+
}
|
224
|
+
}
|
225
|
+
|
226
|
+
|
227
|
+
void InstructionTable::AddJumpConditionalShort() {
|
228
|
+
for (byte b = 0x70; b <= 0x7F; b++) {
|
229
|
+
InstructionDesc* id = &instructions_[b];
|
230
|
+
ASSERT_EQ(NO_INSTR, id->type); // Information not already entered.
|
231
|
+
id->mnem = jump_conditional_mnem[b & 0x0F];
|
232
|
+
id->type = JUMP_CONDITIONAL_SHORT_INSTR;
|
233
|
+
}
|
234
|
+
}
|
235
|
+
|
236
|
+
|
237
|
+
static InstructionTable instruction_table;
|
238
|
+
|
239
|
+
|
240
|
+
// The IA32 disassembler implementation.
|
241
|
+
class DisassemblerIA32 {
|
242
|
+
public:
|
243
|
+
DisassemblerIA32(const NameConverter& converter,
|
244
|
+
bool abort_on_unimplemented = true)
|
245
|
+
: converter_(converter),
|
246
|
+
tmp_buffer_pos_(0),
|
247
|
+
abort_on_unimplemented_(abort_on_unimplemented) {
|
248
|
+
tmp_buffer_[0] = '\0';
|
249
|
+
}
|
250
|
+
|
251
|
+
virtual ~DisassemblerIA32() {}
|
252
|
+
|
253
|
+
// Writes one disassembled instruction into 'buffer' (0-terminated).
|
254
|
+
// Returns the length of the disassembled machine instruction in bytes.
|
255
|
+
int InstructionDecode(v8::internal::Vector<char> buffer, byte* instruction);
|
256
|
+
|
257
|
+
private:
|
258
|
+
const NameConverter& converter_;
|
259
|
+
v8::internal::EmbeddedVector<char, 128> tmp_buffer_;
|
260
|
+
unsigned int tmp_buffer_pos_;
|
261
|
+
bool abort_on_unimplemented_;
|
262
|
+
|
263
|
+
|
264
|
+
enum {
|
265
|
+
eax = 0,
|
266
|
+
ecx = 1,
|
267
|
+
edx = 2,
|
268
|
+
ebx = 3,
|
269
|
+
esp = 4,
|
270
|
+
ebp = 5,
|
271
|
+
esi = 6,
|
272
|
+
edi = 7
|
273
|
+
};
|
274
|
+
|
275
|
+
|
276
|
+
enum ShiftOpcodeExtension {
|
277
|
+
kROL = 0,
|
278
|
+
kROR = 1,
|
279
|
+
kRCL = 2,
|
280
|
+
kRCR = 3,
|
281
|
+
kSHL = 4,
|
282
|
+
KSHR = 5,
|
283
|
+
kSAR = 7
|
284
|
+
};
|
285
|
+
|
286
|
+
|
287
|
+
const char* NameOfCPURegister(int reg) const {
|
288
|
+
return converter_.NameOfCPURegister(reg);
|
289
|
+
}
|
290
|
+
|
291
|
+
|
292
|
+
const char* NameOfByteCPURegister(int reg) const {
|
293
|
+
return converter_.NameOfByteCPURegister(reg);
|
294
|
+
}
|
295
|
+
|
296
|
+
|
297
|
+
const char* NameOfXMMRegister(int reg) const {
|
298
|
+
return converter_.NameOfXMMRegister(reg);
|
299
|
+
}
|
300
|
+
|
301
|
+
|
302
|
+
const char* NameOfAddress(byte* addr) const {
|
303
|
+
return converter_.NameOfAddress(addr);
|
304
|
+
}
|
305
|
+
|
306
|
+
|
307
|
+
// Disassembler helper functions.
|
308
|
+
static void get_modrm(byte data, int* mod, int* regop, int* rm) {
|
309
|
+
*mod = (data >> 6) & 3;
|
310
|
+
*regop = (data & 0x38) >> 3;
|
311
|
+
*rm = data & 7;
|
312
|
+
}
|
313
|
+
|
314
|
+
|
315
|
+
static void get_sib(byte data, int* scale, int* index, int* base) {
|
316
|
+
*scale = (data >> 6) & 3;
|
317
|
+
*index = (data >> 3) & 7;
|
318
|
+
*base = data & 7;
|
319
|
+
}
|
320
|
+
|
321
|
+
typedef const char* (DisassemblerIA32::*RegisterNameMapping)(int reg) const;
|
322
|
+
|
323
|
+
int PrintRightOperandHelper(byte* modrmp, RegisterNameMapping register_name);
|
324
|
+
int PrintRightOperand(byte* modrmp);
|
325
|
+
int PrintRightByteOperand(byte* modrmp);
|
326
|
+
int PrintOperands(const char* mnem, OperandOrder op_order, byte* data);
|
327
|
+
int PrintImmediateOp(byte* data);
|
328
|
+
int F7Instruction(byte* data);
|
329
|
+
int D1D3C1Instruction(byte* data);
|
330
|
+
int JumpShort(byte* data);
|
331
|
+
int JumpConditional(byte* data, const char* comment);
|
332
|
+
int JumpConditionalShort(byte* data, const char* comment);
|
333
|
+
int SetCC(byte* data);
|
334
|
+
int CMov(byte* data);
|
335
|
+
int FPUInstruction(byte* data);
|
336
|
+
int MemoryFPUInstruction(int escape_opcode, int regop, byte* modrm_start);
|
337
|
+
int RegisterFPUInstruction(int escape_opcode, byte modrm_byte);
|
338
|
+
void AppendToBuffer(const char* format, ...);
|
339
|
+
|
340
|
+
|
341
|
+
void UnimplementedInstruction() {
|
342
|
+
if (abort_on_unimplemented_) {
|
343
|
+
UNIMPLEMENTED();
|
344
|
+
} else {
|
345
|
+
AppendToBuffer("'Unimplemented Instruction'");
|
346
|
+
}
|
347
|
+
}
|
348
|
+
};
|
349
|
+
|
350
|
+
|
351
|
+
void DisassemblerIA32::AppendToBuffer(const char* format, ...) {
|
352
|
+
v8::internal::Vector<char> buf = tmp_buffer_ + tmp_buffer_pos_;
|
353
|
+
va_list args;
|
354
|
+
va_start(args, format);
|
355
|
+
int result = v8::internal::OS::VSNPrintF(buf, format, args);
|
356
|
+
va_end(args);
|
357
|
+
tmp_buffer_pos_ += result;
|
358
|
+
}
|
359
|
+
|
360
|
+
int DisassemblerIA32::PrintRightOperandHelper(
|
361
|
+
byte* modrmp,
|
362
|
+
RegisterNameMapping register_name) {
|
363
|
+
int mod, regop, rm;
|
364
|
+
get_modrm(*modrmp, &mod, ®op, &rm);
|
365
|
+
switch (mod) {
|
366
|
+
case 0:
|
367
|
+
if (rm == ebp) {
|
368
|
+
int32_t disp = *reinterpret_cast<int32_t*>(modrmp+1);
|
369
|
+
AppendToBuffer("[0x%x]", disp);
|
370
|
+
return 5;
|
371
|
+
} else if (rm == esp) {
|
372
|
+
byte sib = *(modrmp + 1);
|
373
|
+
int scale, index, base;
|
374
|
+
get_sib(sib, &scale, &index, &base);
|
375
|
+
if (index == esp && base == esp && scale == 0 /*times_1*/) {
|
376
|
+
AppendToBuffer("[%s]", (this->*register_name)(rm));
|
377
|
+
return 2;
|
378
|
+
} else if (base == ebp) {
|
379
|
+
int32_t disp = *reinterpret_cast<int32_t*>(modrmp + 2);
|
380
|
+
AppendToBuffer("[%s*%d+0x%x]",
|
381
|
+
(this->*register_name)(index),
|
382
|
+
1 << scale,
|
383
|
+
disp);
|
384
|
+
return 6;
|
385
|
+
} else if (index != esp && base != ebp) {
|
386
|
+
// [base+index*scale]
|
387
|
+
AppendToBuffer("[%s+%s*%d]",
|
388
|
+
(this->*register_name)(base),
|
389
|
+
(this->*register_name)(index),
|
390
|
+
1 << scale);
|
391
|
+
return 2;
|
392
|
+
} else {
|
393
|
+
UnimplementedInstruction();
|
394
|
+
return 1;
|
395
|
+
}
|
396
|
+
} else {
|
397
|
+
AppendToBuffer("[%s]", (this->*register_name)(rm));
|
398
|
+
return 1;
|
399
|
+
}
|
400
|
+
break;
|
401
|
+
case 1: // fall through
|
402
|
+
case 2:
|
403
|
+
if (rm == esp) {
|
404
|
+
byte sib = *(modrmp + 1);
|
405
|
+
int scale, index, base;
|
406
|
+
get_sib(sib, &scale, &index, &base);
|
407
|
+
int disp =
|
408
|
+
mod == 2 ? *reinterpret_cast<int32_t*>(modrmp + 2) : *(modrmp + 2);
|
409
|
+
if (index == base && index == rm /*esp*/ && scale == 0 /*times_1*/) {
|
410
|
+
AppendToBuffer("[%s+0x%x]", (this->*register_name)(rm), disp);
|
411
|
+
} else {
|
412
|
+
AppendToBuffer("[%s+%s*%d+0x%x]",
|
413
|
+
(this->*register_name)(base),
|
414
|
+
(this->*register_name)(index),
|
415
|
+
1 << scale,
|
416
|
+
disp);
|
417
|
+
}
|
418
|
+
return mod == 2 ? 6 : 3;
|
419
|
+
} else {
|
420
|
+
// No sib.
|
421
|
+
int disp =
|
422
|
+
mod == 2 ? *reinterpret_cast<int32_t*>(modrmp + 1) : *(modrmp + 1);
|
423
|
+
AppendToBuffer("[%s+0x%x]", (this->*register_name)(rm), disp);
|
424
|
+
return mod == 2 ? 5 : 2;
|
425
|
+
}
|
426
|
+
break;
|
427
|
+
case 3:
|
428
|
+
AppendToBuffer("%s", (this->*register_name)(rm));
|
429
|
+
return 1;
|
430
|
+
default:
|
431
|
+
UnimplementedInstruction();
|
432
|
+
return 1;
|
433
|
+
}
|
434
|
+
UNREACHABLE();
|
435
|
+
}
|
436
|
+
|
437
|
+
|
438
|
+
int DisassemblerIA32::PrintRightOperand(byte* modrmp) {
|
439
|
+
return PrintRightOperandHelper(modrmp, &DisassemblerIA32::NameOfCPURegister);
|
440
|
+
}
|
441
|
+
|
442
|
+
|
443
|
+
int DisassemblerIA32::PrintRightByteOperand(byte* modrmp) {
|
444
|
+
return PrintRightOperandHelper(modrmp,
|
445
|
+
&DisassemblerIA32::NameOfByteCPURegister);
|
446
|
+
}
|
447
|
+
|
448
|
+
|
449
|
+
// Returns number of bytes used including the current *data.
|
450
|
+
// Writes instruction's mnemonic, left and right operands to 'tmp_buffer_'.
|
451
|
+
int DisassemblerIA32::PrintOperands(const char* mnem,
|
452
|
+
OperandOrder op_order,
|
453
|
+
byte* data) {
|
454
|
+
byte modrm = *data;
|
455
|
+
int mod, regop, rm;
|
456
|
+
get_modrm(modrm, &mod, ®op, &rm);
|
457
|
+
int advance = 0;
|
458
|
+
switch (op_order) {
|
459
|
+
case REG_OPER_OP_ORDER: {
|
460
|
+
AppendToBuffer("%s %s,", mnem, NameOfCPURegister(regop));
|
461
|
+
advance = PrintRightOperand(data);
|
462
|
+
break;
|
463
|
+
}
|
464
|
+
case OPER_REG_OP_ORDER: {
|
465
|
+
AppendToBuffer("%s ", mnem);
|
466
|
+
advance = PrintRightOperand(data);
|
467
|
+
AppendToBuffer(",%s", NameOfCPURegister(regop));
|
468
|
+
break;
|
469
|
+
}
|
470
|
+
default:
|
471
|
+
UNREACHABLE();
|
472
|
+
break;
|
473
|
+
}
|
474
|
+
return advance;
|
475
|
+
}
|
476
|
+
|
477
|
+
|
478
|
+
// Returns number of bytes used by machine instruction, including *data byte.
|
479
|
+
// Writes immediate instructions to 'tmp_buffer_'.
|
480
|
+
int DisassemblerIA32::PrintImmediateOp(byte* data) {
|
481
|
+
bool sign_extension_bit = (*data & 0x02) != 0;
|
482
|
+
byte modrm = *(data+1);
|
483
|
+
int mod, regop, rm;
|
484
|
+
get_modrm(modrm, &mod, ®op, &rm);
|
485
|
+
const char* mnem = "Imm???";
|
486
|
+
switch (regop) {
|
487
|
+
case 0: mnem = "add"; break;
|
488
|
+
case 1: mnem = "or"; break;
|
489
|
+
case 2: mnem = "adc"; break;
|
490
|
+
case 4: mnem = "and"; break;
|
491
|
+
case 5: mnem = "sub"; break;
|
492
|
+
case 6: mnem = "xor"; break;
|
493
|
+
case 7: mnem = "cmp"; break;
|
494
|
+
default: UnimplementedInstruction();
|
495
|
+
}
|
496
|
+
AppendToBuffer("%s ", mnem);
|
497
|
+
int count = PrintRightOperand(data+1);
|
498
|
+
if (sign_extension_bit) {
|
499
|
+
AppendToBuffer(",0x%x", *(data + 1 + count));
|
500
|
+
return 1 + count + 1 /*int8*/;
|
501
|
+
} else {
|
502
|
+
AppendToBuffer(",0x%x", *reinterpret_cast<int32_t*>(data + 1 + count));
|
503
|
+
return 1 + count + 4 /*int32_t*/;
|
504
|
+
}
|
505
|
+
}
|
506
|
+
|
507
|
+
|
508
|
+
// Returns number of bytes used, including *data.
|
509
|
+
int DisassemblerIA32::F7Instruction(byte* data) {
|
510
|
+
ASSERT_EQ(0xF7, *data);
|
511
|
+
byte modrm = *(data+1);
|
512
|
+
int mod, regop, rm;
|
513
|
+
get_modrm(modrm, &mod, ®op, &rm);
|
514
|
+
if (mod == 3 && regop != 0) {
|
515
|
+
const char* mnem = NULL;
|
516
|
+
switch (regop) {
|
517
|
+
case 2: mnem = "not"; break;
|
518
|
+
case 3: mnem = "neg"; break;
|
519
|
+
case 4: mnem = "mul"; break;
|
520
|
+
case 7: mnem = "idiv"; break;
|
521
|
+
default: UnimplementedInstruction();
|
522
|
+
}
|
523
|
+
AppendToBuffer("%s %s", mnem, NameOfCPURegister(rm));
|
524
|
+
return 2;
|
525
|
+
} else if (mod == 3 && regop == eax) {
|
526
|
+
int32_t imm = *reinterpret_cast<int32_t*>(data+2);
|
527
|
+
AppendToBuffer("test %s,0x%x", NameOfCPURegister(rm), imm);
|
528
|
+
return 6;
|
529
|
+
} else if (regop == eax) {
|
530
|
+
AppendToBuffer("test ");
|
531
|
+
int count = PrintRightOperand(data+1);
|
532
|
+
int32_t imm = *reinterpret_cast<int32_t*>(data+1+count);
|
533
|
+
AppendToBuffer(",0x%x", imm);
|
534
|
+
return 1+count+4 /*int32_t*/;
|
535
|
+
} else {
|
536
|
+
UnimplementedInstruction();
|
537
|
+
return 2;
|
538
|
+
}
|
539
|
+
}
|
540
|
+
|
541
|
+
int DisassemblerIA32::D1D3C1Instruction(byte* data) {
|
542
|
+
byte op = *data;
|
543
|
+
ASSERT(op == 0xD1 || op == 0xD3 || op == 0xC1);
|
544
|
+
byte modrm = *(data+1);
|
545
|
+
int mod, regop, rm;
|
546
|
+
get_modrm(modrm, &mod, ®op, &rm);
|
547
|
+
int imm8 = -1;
|
548
|
+
int num_bytes = 2;
|
549
|
+
if (mod == 3) {
|
550
|
+
const char* mnem = NULL;
|
551
|
+
switch (regop) {
|
552
|
+
case kROL: mnem = "rol"; break;
|
553
|
+
case kROR: mnem = "ror"; break;
|
554
|
+
case kRCL: mnem = "rcl"; break;
|
555
|
+
case kSHL: mnem = "shl"; break;
|
556
|
+
case KSHR: mnem = "shr"; break;
|
557
|
+
case kSAR: mnem = "sar"; break;
|
558
|
+
default: UnimplementedInstruction();
|
559
|
+
}
|
560
|
+
if (op == 0xD1) {
|
561
|
+
imm8 = 1;
|
562
|
+
} else if (op == 0xC1) {
|
563
|
+
imm8 = *(data+2);
|
564
|
+
num_bytes = 3;
|
565
|
+
} else if (op == 0xD3) {
|
566
|
+
// Shift/rotate by cl.
|
567
|
+
}
|
568
|
+
ASSERT_NE(NULL, mnem);
|
569
|
+
AppendToBuffer("%s %s,", mnem, NameOfCPURegister(rm));
|
570
|
+
if (imm8 > 0) {
|
571
|
+
AppendToBuffer("%d", imm8);
|
572
|
+
} else {
|
573
|
+
AppendToBuffer("cl");
|
574
|
+
}
|
575
|
+
} else {
|
576
|
+
UnimplementedInstruction();
|
577
|
+
}
|
578
|
+
return num_bytes;
|
579
|
+
}
|
580
|
+
|
581
|
+
|
582
|
+
// Returns number of bytes used, including *data.
|
583
|
+
int DisassemblerIA32::JumpShort(byte* data) {
|
584
|
+
ASSERT_EQ(0xEB, *data);
|
585
|
+
byte b = *(data+1);
|
586
|
+
byte* dest = data + static_cast<int8_t>(b) + 2;
|
587
|
+
AppendToBuffer("jmp %s", NameOfAddress(dest));
|
588
|
+
return 2;
|
589
|
+
}
|
590
|
+
|
591
|
+
|
592
|
+
// Returns number of bytes used, including *data.
|
593
|
+
int DisassemblerIA32::JumpConditional(byte* data, const char* comment) {
|
594
|
+
ASSERT_EQ(0x0F, *data);
|
595
|
+
byte cond = *(data+1) & 0x0F;
|
596
|
+
byte* dest = data + *reinterpret_cast<int32_t*>(data+2) + 6;
|
597
|
+
const char* mnem = jump_conditional_mnem[cond];
|
598
|
+
AppendToBuffer("%s %s", mnem, NameOfAddress(dest));
|
599
|
+
if (comment != NULL) {
|
600
|
+
AppendToBuffer(", %s", comment);
|
601
|
+
}
|
602
|
+
return 6; // includes 0x0F
|
603
|
+
}
|
604
|
+
|
605
|
+
|
606
|
+
// Returns number of bytes used, including *data.
|
607
|
+
int DisassemblerIA32::JumpConditionalShort(byte* data, const char* comment) {
|
608
|
+
byte cond = *data & 0x0F;
|
609
|
+
byte b = *(data+1);
|
610
|
+
byte* dest = data + static_cast<int8_t>(b) + 2;
|
611
|
+
const char* mnem = jump_conditional_mnem[cond];
|
612
|
+
AppendToBuffer("%s %s", mnem, NameOfAddress(dest));
|
613
|
+
if (comment != NULL) {
|
614
|
+
AppendToBuffer(", %s", comment);
|
615
|
+
}
|
616
|
+
return 2;
|
617
|
+
}
|
618
|
+
|
619
|
+
|
620
|
+
// Returns number of bytes used, including *data.
|
621
|
+
int DisassemblerIA32::SetCC(byte* data) {
|
622
|
+
ASSERT_EQ(0x0F, *data);
|
623
|
+
byte cond = *(data+1) & 0x0F;
|
624
|
+
const char* mnem = set_conditional_mnem[cond];
|
625
|
+
AppendToBuffer("%s ", mnem);
|
626
|
+
PrintRightByteOperand(data+2);
|
627
|
+
return 3; // Includes 0x0F.
|
628
|
+
}
|
629
|
+
|
630
|
+
|
631
|
+
// Returns number of bytes used, including *data.
|
632
|
+
int DisassemblerIA32::CMov(byte* data) {
|
633
|
+
ASSERT_EQ(0x0F, *data);
|
634
|
+
byte cond = *(data + 1) & 0x0F;
|
635
|
+
const char* mnem = conditional_move_mnem[cond];
|
636
|
+
int op_size = PrintOperands(mnem, REG_OPER_OP_ORDER, data + 2);
|
637
|
+
return 2 + op_size; // includes 0x0F
|
638
|
+
}
|
639
|
+
|
640
|
+
|
641
|
+
// Returns number of bytes used, including *data.
|
642
|
+
int DisassemblerIA32::FPUInstruction(byte* data) {
|
643
|
+
byte escape_opcode = *data;
|
644
|
+
ASSERT_EQ(0xD8, escape_opcode & 0xF8);
|
645
|
+
byte modrm_byte = *(data+1);
|
646
|
+
|
647
|
+
if (modrm_byte >= 0xC0) {
|
648
|
+
return RegisterFPUInstruction(escape_opcode, modrm_byte);
|
649
|
+
} else {
|
650
|
+
return MemoryFPUInstruction(escape_opcode, modrm_byte, data+1);
|
651
|
+
}
|
652
|
+
}
|
653
|
+
|
654
|
+
int DisassemblerIA32::MemoryFPUInstruction(int escape_opcode,
|
655
|
+
int modrm_byte,
|
656
|
+
byte* modrm_start) {
|
657
|
+
const char* mnem = "?";
|
658
|
+
int regop = (modrm_byte >> 3) & 0x7; // reg/op field of modrm byte.
|
659
|
+
switch (escape_opcode) {
|
660
|
+
case 0xD9: switch (regop) {
|
661
|
+
case 0: mnem = "fld_s"; break;
|
662
|
+
case 3: mnem = "fstp_s"; break;
|
663
|
+
case 7: mnem = "fstcw"; break;
|
664
|
+
default: UnimplementedInstruction();
|
665
|
+
}
|
666
|
+
break;
|
667
|
+
|
668
|
+
case 0xDB: switch (regop) {
|
669
|
+
case 0: mnem = "fild_s"; break;
|
670
|
+
case 1: mnem = "fisttp_s"; break;
|
671
|
+
case 2: mnem = "fist_s"; break;
|
672
|
+
case 3: mnem = "fistp_s"; break;
|
673
|
+
default: UnimplementedInstruction();
|
674
|
+
}
|
675
|
+
break;
|
676
|
+
|
677
|
+
case 0xDD: switch (regop) {
|
678
|
+
case 0: mnem = "fld_d"; break;
|
679
|
+
case 3: mnem = "fstp_d"; break;
|
680
|
+
default: UnimplementedInstruction();
|
681
|
+
}
|
682
|
+
break;
|
683
|
+
|
684
|
+
case 0xDF: switch (regop) {
|
685
|
+
case 5: mnem = "fild_d"; break;
|
686
|
+
case 7: mnem = "fistp_d"; break;
|
687
|
+
default: UnimplementedInstruction();
|
688
|
+
}
|
689
|
+
break;
|
690
|
+
|
691
|
+
default: UnimplementedInstruction();
|
692
|
+
}
|
693
|
+
AppendToBuffer("%s ", mnem);
|
694
|
+
int count = PrintRightOperand(modrm_start);
|
695
|
+
return count + 1;
|
696
|
+
}
|
697
|
+
|
698
|
+
int DisassemblerIA32::RegisterFPUInstruction(int escape_opcode,
|
699
|
+
byte modrm_byte) {
|
700
|
+
bool has_register = false; // Is the FPU register encoded in modrm_byte?
|
701
|
+
const char* mnem = "?";
|
702
|
+
|
703
|
+
switch (escape_opcode) {
|
704
|
+
case 0xD8:
|
705
|
+
UnimplementedInstruction();
|
706
|
+
break;
|
707
|
+
|
708
|
+
case 0xD9:
|
709
|
+
switch (modrm_byte & 0xF8) {
|
710
|
+
case 0xC8:
|
711
|
+
mnem = "fxch";
|
712
|
+
has_register = true;
|
713
|
+
break;
|
714
|
+
default:
|
715
|
+
switch (modrm_byte) {
|
716
|
+
case 0xE0: mnem = "fchs"; break;
|
717
|
+
case 0xE1: mnem = "fabs"; break;
|
718
|
+
case 0xE4: mnem = "ftst"; break;
|
719
|
+
case 0xE8: mnem = "fld1"; break;
|
720
|
+
case 0xEE: mnem = "fldz"; break;
|
721
|
+
case 0xF5: mnem = "fprem1"; break;
|
722
|
+
case 0xF7: mnem = "fincstp"; break;
|
723
|
+
case 0xF8: mnem = "fprem"; break;
|
724
|
+
case 0xFE: mnem = "fsin"; break;
|
725
|
+
case 0xFF: mnem = "fcos"; break;
|
726
|
+
default: UnimplementedInstruction();
|
727
|
+
}
|
728
|
+
}
|
729
|
+
break;
|
730
|
+
|
731
|
+
case 0xDA:
|
732
|
+
if (modrm_byte == 0xE9) {
|
733
|
+
mnem = "fucompp";
|
734
|
+
} else {
|
735
|
+
UnimplementedInstruction();
|
736
|
+
}
|
737
|
+
break;
|
738
|
+
|
739
|
+
case 0xDB:
|
740
|
+
if ((modrm_byte & 0xF8) == 0xE8) {
|
741
|
+
mnem = "fucomi";
|
742
|
+
has_register = true;
|
743
|
+
} else if (modrm_byte == 0xE2) {
|
744
|
+
mnem = "fclex";
|
745
|
+
} else {
|
746
|
+
UnimplementedInstruction();
|
747
|
+
}
|
748
|
+
break;
|
749
|
+
|
750
|
+
case 0xDC:
|
751
|
+
has_register = true;
|
752
|
+
switch (modrm_byte & 0xF8) {
|
753
|
+
case 0xC0: mnem = "fadd"; break;
|
754
|
+
case 0xE8: mnem = "fsub"; break;
|
755
|
+
case 0xC8: mnem = "fmul"; break;
|
756
|
+
case 0xF8: mnem = "fdiv"; break;
|
757
|
+
default: UnimplementedInstruction();
|
758
|
+
}
|
759
|
+
break;
|
760
|
+
|
761
|
+
case 0xDD:
|
762
|
+
has_register = true;
|
763
|
+
switch (modrm_byte & 0xF8) {
|
764
|
+
case 0xC0: mnem = "ffree"; break;
|
765
|
+
case 0xD8: mnem = "fstp"; break;
|
766
|
+
default: UnimplementedInstruction();
|
767
|
+
}
|
768
|
+
break;
|
769
|
+
|
770
|
+
case 0xDE:
|
771
|
+
if (modrm_byte == 0xD9) {
|
772
|
+
mnem = "fcompp";
|
773
|
+
} else {
|
774
|
+
has_register = true;
|
775
|
+
switch (modrm_byte & 0xF8) {
|
776
|
+
case 0xC0: mnem = "faddp"; break;
|
777
|
+
case 0xE8: mnem = "fsubp"; break;
|
778
|
+
case 0xC8: mnem = "fmulp"; break;
|
779
|
+
case 0xF8: mnem = "fdivp"; break;
|
780
|
+
default: UnimplementedInstruction();
|
781
|
+
}
|
782
|
+
}
|
783
|
+
break;
|
784
|
+
|
785
|
+
case 0xDF:
|
786
|
+
if (modrm_byte == 0xE0) {
|
787
|
+
mnem = "fnstsw_ax";
|
788
|
+
} else if ((modrm_byte & 0xF8) == 0xE8) {
|
789
|
+
mnem = "fucomip";
|
790
|
+
has_register = true;
|
791
|
+
}
|
792
|
+
break;
|
793
|
+
|
794
|
+
default: UnimplementedInstruction();
|
795
|
+
}
|
796
|
+
|
797
|
+
if (has_register) {
|
798
|
+
AppendToBuffer("%s st%d", mnem, modrm_byte & 0x7);
|
799
|
+
} else {
|
800
|
+
AppendToBuffer("%s", mnem);
|
801
|
+
}
|
802
|
+
return 2;
|
803
|
+
}
|
804
|
+
|
805
|
+
|
806
|
+
// Mnemonics for instructions 0xF0 byte.
|
807
|
+
// Returns NULL if the instruction is not handled here.
|
808
|
+
static const char* F0Mnem(byte f0byte) {
|
809
|
+
switch (f0byte) {
|
810
|
+
case 0xA2: return "cpuid";
|
811
|
+
case 0x31: return "rdtsc";
|
812
|
+
case 0xBE: return "movsx_b";
|
813
|
+
case 0xBF: return "movsx_w";
|
814
|
+
case 0xB6: return "movzx_b";
|
815
|
+
case 0xB7: return "movzx_w";
|
816
|
+
case 0xAF: return "imul";
|
817
|
+
case 0xA5: return "shld";
|
818
|
+
case 0xAD: return "shrd";
|
819
|
+
case 0xAB: return "bts";
|
820
|
+
default: return NULL;
|
821
|
+
}
|
822
|
+
}
|
823
|
+
|
824
|
+
|
825
|
+
// Disassembled instruction '*instr' and writes it into 'out_buffer'.
|
826
|
+
int DisassemblerIA32::InstructionDecode(v8::internal::Vector<char> out_buffer,
|
827
|
+
byte* instr) {
|
828
|
+
tmp_buffer_pos_ = 0; // starting to write as position 0
|
829
|
+
byte* data = instr;
|
830
|
+
// Check for hints.
|
831
|
+
const char* branch_hint = NULL;
|
832
|
+
// We use these two prefixes only with branch prediction
|
833
|
+
if (*data == 0x3E /*ds*/) {
|
834
|
+
branch_hint = "predicted taken";
|
835
|
+
data++;
|
836
|
+
} else if (*data == 0x2E /*cs*/) {
|
837
|
+
branch_hint = "predicted not taken";
|
838
|
+
data++;
|
839
|
+
}
|
840
|
+
bool processed = true; // Will be set to false if the current instruction
|
841
|
+
// is not in 'instructions' table.
|
842
|
+
const InstructionDesc& idesc = instruction_table.Get(*data);
|
843
|
+
switch (idesc.type) {
|
844
|
+
case ZERO_OPERANDS_INSTR:
|
845
|
+
AppendToBuffer(idesc.mnem);
|
846
|
+
data++;
|
847
|
+
break;
|
848
|
+
|
849
|
+
case TWO_OPERANDS_INSTR:
|
850
|
+
data++;
|
851
|
+
data += PrintOperands(idesc.mnem, idesc.op_order_, data);
|
852
|
+
break;
|
853
|
+
|
854
|
+
case JUMP_CONDITIONAL_SHORT_INSTR:
|
855
|
+
data += JumpConditionalShort(data, branch_hint);
|
856
|
+
break;
|
857
|
+
|
858
|
+
case REGISTER_INSTR:
|
859
|
+
AppendToBuffer("%s %s", idesc.mnem, NameOfCPURegister(*data & 0x07));
|
860
|
+
data++;
|
861
|
+
break;
|
862
|
+
|
863
|
+
case MOVE_REG_INSTR: {
|
864
|
+
byte* addr = reinterpret_cast<byte*>(*reinterpret_cast<int32_t*>(data+1));
|
865
|
+
AppendToBuffer("mov %s,%s",
|
866
|
+
NameOfCPURegister(*data & 0x07),
|
867
|
+
NameOfAddress(addr));
|
868
|
+
data += 5;
|
869
|
+
break;
|
870
|
+
}
|
871
|
+
|
872
|
+
case CALL_JUMP_INSTR: {
|
873
|
+
byte* addr = data + *reinterpret_cast<int32_t*>(data+1) + 5;
|
874
|
+
AppendToBuffer("%s %s", idesc.mnem, NameOfAddress(addr));
|
875
|
+
data += 5;
|
876
|
+
break;
|
877
|
+
}
|
878
|
+
|
879
|
+
case SHORT_IMMEDIATE_INSTR: {
|
880
|
+
byte* addr = reinterpret_cast<byte*>(*reinterpret_cast<int32_t*>(data+1));
|
881
|
+
AppendToBuffer("%s eax, %s", idesc.mnem, NameOfAddress(addr));
|
882
|
+
data += 5;
|
883
|
+
break;
|
884
|
+
}
|
885
|
+
|
886
|
+
case NO_INSTR:
|
887
|
+
processed = false;
|
888
|
+
break;
|
889
|
+
|
890
|
+
default:
|
891
|
+
UNIMPLEMENTED(); // This type is not implemented.
|
892
|
+
}
|
893
|
+
//----------------------------
|
894
|
+
if (!processed) {
|
895
|
+
switch (*data) {
|
896
|
+
case 0xC2:
|
897
|
+
AppendToBuffer("ret 0x%x", *reinterpret_cast<uint16_t*>(data+1));
|
898
|
+
data += 3;
|
899
|
+
break;
|
900
|
+
|
901
|
+
case 0x69: // fall through
|
902
|
+
case 0x6B:
|
903
|
+
{ int mod, regop, rm;
|
904
|
+
get_modrm(*(data+1), &mod, ®op, &rm);
|
905
|
+
int32_t imm =
|
906
|
+
*data == 0x6B ? *(data+2) : *reinterpret_cast<int32_t*>(data+2);
|
907
|
+
AppendToBuffer("imul %s,%s,0x%x",
|
908
|
+
NameOfCPURegister(regop),
|
909
|
+
NameOfCPURegister(rm),
|
910
|
+
imm);
|
911
|
+
data += 2 + (*data == 0x6B ? 1 : 4);
|
912
|
+
}
|
913
|
+
break;
|
914
|
+
|
915
|
+
case 0xF6:
|
916
|
+
{ int mod, regop, rm;
|
917
|
+
get_modrm(*(data+1), &mod, ®op, &rm);
|
918
|
+
if (mod == 3 && regop == eax) {
|
919
|
+
AppendToBuffer("test_b %s,%d", NameOfCPURegister(rm), *(data+2));
|
920
|
+
} else {
|
921
|
+
UnimplementedInstruction();
|
922
|
+
}
|
923
|
+
data += 3;
|
924
|
+
}
|
925
|
+
break;
|
926
|
+
|
927
|
+
case 0x81: // fall through
|
928
|
+
case 0x83: // 0x81 with sign extension bit set
|
929
|
+
data += PrintImmediateOp(data);
|
930
|
+
break;
|
931
|
+
|
932
|
+
case 0x0F:
|
933
|
+
{ byte f0byte = *(data+1);
|
934
|
+
const char* f0mnem = F0Mnem(f0byte);
|
935
|
+
if (f0byte == 0xA2 || f0byte == 0x31) {
|
936
|
+
AppendToBuffer("%s", f0mnem);
|
937
|
+
data += 2;
|
938
|
+
} else if ((f0byte & 0xF0) == 0x80) {
|
939
|
+
data += JumpConditional(data, branch_hint);
|
940
|
+
} else if (f0byte == 0xBE || f0byte == 0xBF || f0byte == 0xB6 ||
|
941
|
+
f0byte == 0xB7 || f0byte == 0xAF) {
|
942
|
+
data += 2;
|
943
|
+
data += PrintOperands(f0mnem, REG_OPER_OP_ORDER, data);
|
944
|
+
} else if ((f0byte & 0xF0) == 0x90) {
|
945
|
+
data += SetCC(data);
|
946
|
+
} else if ((f0byte & 0xF0) == 0x40) {
|
947
|
+
data += CMov(data);
|
948
|
+
} else {
|
949
|
+
data += 2;
|
950
|
+
if (f0byte == 0xAB || f0byte == 0xA5 || f0byte == 0xAD) {
|
951
|
+
// shrd, shld, bts
|
952
|
+
AppendToBuffer("%s ", f0mnem);
|
953
|
+
int mod, regop, rm;
|
954
|
+
get_modrm(*data, &mod, ®op, &rm);
|
955
|
+
data += PrintRightOperand(data);
|
956
|
+
if (f0byte == 0xAB) {
|
957
|
+
AppendToBuffer(",%s", NameOfCPURegister(regop));
|
958
|
+
} else {
|
959
|
+
AppendToBuffer(",%s,cl", NameOfCPURegister(regop));
|
960
|
+
}
|
961
|
+
} else {
|
962
|
+
UnimplementedInstruction();
|
963
|
+
}
|
964
|
+
}
|
965
|
+
}
|
966
|
+
break;
|
967
|
+
|
968
|
+
case 0x8F:
|
969
|
+
{ data++;
|
970
|
+
int mod, regop, rm;
|
971
|
+
get_modrm(*data, &mod, ®op, &rm);
|
972
|
+
if (regop == eax) {
|
973
|
+
AppendToBuffer("pop ");
|
974
|
+
data += PrintRightOperand(data);
|
975
|
+
}
|
976
|
+
}
|
977
|
+
break;
|
978
|
+
|
979
|
+
case 0xFF:
|
980
|
+
{ data++;
|
981
|
+
int mod, regop, rm;
|
982
|
+
get_modrm(*data, &mod, ®op, &rm);
|
983
|
+
const char* mnem = NULL;
|
984
|
+
switch (regop) {
|
985
|
+
case esi: mnem = "push"; break;
|
986
|
+
case eax: mnem = "inc"; break;
|
987
|
+
case ecx: mnem = "dec"; break;
|
988
|
+
case edx: mnem = "call"; break;
|
989
|
+
case esp: mnem = "jmp"; break;
|
990
|
+
default: mnem = "???";
|
991
|
+
}
|
992
|
+
AppendToBuffer("%s ", mnem);
|
993
|
+
data += PrintRightOperand(data);
|
994
|
+
}
|
995
|
+
break;
|
996
|
+
|
997
|
+
case 0xC7: // imm32, fall through
|
998
|
+
case 0xC6: // imm8
|
999
|
+
{ bool is_byte = *data == 0xC6;
|
1000
|
+
data++;
|
1001
|
+
AppendToBuffer("%s ", is_byte ? "mov_b" : "mov");
|
1002
|
+
data += PrintRightOperand(data);
|
1003
|
+
int32_t imm = is_byte ? *data : *reinterpret_cast<int32_t*>(data);
|
1004
|
+
AppendToBuffer(",0x%x", imm);
|
1005
|
+
data += is_byte ? 1 : 4;
|
1006
|
+
}
|
1007
|
+
break;
|
1008
|
+
|
1009
|
+
case 0x80:
|
1010
|
+
{ data++;
|
1011
|
+
int mod, regop, rm;
|
1012
|
+
get_modrm(*data, &mod, ®op, &rm);
|
1013
|
+
const char* mnem = NULL;
|
1014
|
+
printf("%d\n", regop);
|
1015
|
+
switch (regop) {
|
1016
|
+
case 5: mnem = "subb"; break;
|
1017
|
+
case 7: mnem = "cmpb"; break;
|
1018
|
+
default: UnimplementedInstruction();
|
1019
|
+
}
|
1020
|
+
AppendToBuffer("%s ", mnem);
|
1021
|
+
data += PrintRightOperand(data);
|
1022
|
+
int32_t imm = *data;
|
1023
|
+
AppendToBuffer(",0x%x", imm);
|
1024
|
+
data++;
|
1025
|
+
}
|
1026
|
+
break;
|
1027
|
+
|
1028
|
+
case 0x88: // 8bit, fall through
|
1029
|
+
case 0x89: // 32bit
|
1030
|
+
{ bool is_byte = *data == 0x88;
|
1031
|
+
int mod, regop, rm;
|
1032
|
+
data++;
|
1033
|
+
get_modrm(*data, &mod, ®op, &rm);
|
1034
|
+
AppendToBuffer("%s ", is_byte ? "mov_b" : "mov");
|
1035
|
+
data += PrintRightOperand(data);
|
1036
|
+
AppendToBuffer(",%s", NameOfCPURegister(regop));
|
1037
|
+
}
|
1038
|
+
break;
|
1039
|
+
|
1040
|
+
case 0x66: // prefix
|
1041
|
+
data++;
|
1042
|
+
if (*data == 0x8B) {
|
1043
|
+
data++;
|
1044
|
+
data += PrintOperands("mov_w", REG_OPER_OP_ORDER, data);
|
1045
|
+
} else if (*data == 0x89) {
|
1046
|
+
data++;
|
1047
|
+
int mod, regop, rm;
|
1048
|
+
get_modrm(*data, &mod, ®op, &rm);
|
1049
|
+
AppendToBuffer("mov_w ");
|
1050
|
+
data += PrintRightOperand(data);
|
1051
|
+
AppendToBuffer(",%s", NameOfCPURegister(regop));
|
1052
|
+
} else if (*data == 0x0F) {
|
1053
|
+
data++;
|
1054
|
+
if (*data == 0x2F) {
|
1055
|
+
data++;
|
1056
|
+
int mod, regop, rm;
|
1057
|
+
get_modrm(*data, &mod, ®op, &rm);
|
1058
|
+
AppendToBuffer("comisd %s,%s",
|
1059
|
+
NameOfXMMRegister(regop),
|
1060
|
+
NameOfXMMRegister(rm));
|
1061
|
+
data++;
|
1062
|
+
} else if (*data == 0x57) {
|
1063
|
+
data++;
|
1064
|
+
int mod, regop, rm;
|
1065
|
+
get_modrm(*data, &mod, ®op, &rm);
|
1066
|
+
AppendToBuffer("xorpd %s,%s",
|
1067
|
+
NameOfXMMRegister(regop),
|
1068
|
+
NameOfXMMRegister(rm));
|
1069
|
+
data++;
|
1070
|
+
} else if (*data == 0x6F) {
|
1071
|
+
data++;
|
1072
|
+
int mod, regop, rm;
|
1073
|
+
get_modrm(*data, &mod, ®op, &rm);
|
1074
|
+
AppendToBuffer("movdqa %s,", NameOfXMMRegister(regop));
|
1075
|
+
data += PrintRightOperand(data);
|
1076
|
+
} else if (*data == 0x7F) {
|
1077
|
+
AppendToBuffer("movdqa ");
|
1078
|
+
data++;
|
1079
|
+
int mod, regop, rm;
|
1080
|
+
get_modrm(*data, &mod, ®op, &rm);
|
1081
|
+
data += PrintRightOperand(data);
|
1082
|
+
AppendToBuffer(",%s", NameOfXMMRegister(regop));
|
1083
|
+
} else {
|
1084
|
+
UnimplementedInstruction();
|
1085
|
+
}
|
1086
|
+
} else {
|
1087
|
+
UnimplementedInstruction();
|
1088
|
+
}
|
1089
|
+
break;
|
1090
|
+
|
1091
|
+
case 0xFE:
|
1092
|
+
{ data++;
|
1093
|
+
int mod, regop, rm;
|
1094
|
+
get_modrm(*data, &mod, ®op, &rm);
|
1095
|
+
if (mod == 3 && regop == ecx) {
|
1096
|
+
AppendToBuffer("dec_b %s", NameOfCPURegister(rm));
|
1097
|
+
} else {
|
1098
|
+
UnimplementedInstruction();
|
1099
|
+
}
|
1100
|
+
data++;
|
1101
|
+
}
|
1102
|
+
break;
|
1103
|
+
|
1104
|
+
case 0x68:
|
1105
|
+
AppendToBuffer("push 0x%x", *reinterpret_cast<int32_t*>(data+1));
|
1106
|
+
data += 5;
|
1107
|
+
break;
|
1108
|
+
|
1109
|
+
case 0x6A:
|
1110
|
+
AppendToBuffer("push 0x%x", *reinterpret_cast<int8_t*>(data + 1));
|
1111
|
+
data += 2;
|
1112
|
+
break;
|
1113
|
+
|
1114
|
+
case 0xA8:
|
1115
|
+
AppendToBuffer("test al,0x%x", *reinterpret_cast<uint8_t*>(data+1));
|
1116
|
+
data += 2;
|
1117
|
+
break;
|
1118
|
+
|
1119
|
+
case 0x2C:
|
1120
|
+
AppendToBuffer("subb eax,0x%x", *reinterpret_cast<uint8_t*>(data+1));
|
1121
|
+
data += 2;
|
1122
|
+
break;
|
1123
|
+
|
1124
|
+
case 0xA9:
|
1125
|
+
AppendToBuffer("test eax,0x%x", *reinterpret_cast<int32_t*>(data+1));
|
1126
|
+
data += 5;
|
1127
|
+
break;
|
1128
|
+
|
1129
|
+
case 0xD1: // fall through
|
1130
|
+
case 0xD3: // fall through
|
1131
|
+
case 0xC1:
|
1132
|
+
data += D1D3C1Instruction(data);
|
1133
|
+
break;
|
1134
|
+
|
1135
|
+
case 0xD9: // fall through
|
1136
|
+
case 0xDA: // fall through
|
1137
|
+
case 0xDB: // fall through
|
1138
|
+
case 0xDC: // fall through
|
1139
|
+
case 0xDD: // fall through
|
1140
|
+
case 0xDE: // fall through
|
1141
|
+
case 0xDF:
|
1142
|
+
data += FPUInstruction(data);
|
1143
|
+
break;
|
1144
|
+
|
1145
|
+
case 0xEB:
|
1146
|
+
data += JumpShort(data);
|
1147
|
+
break;
|
1148
|
+
|
1149
|
+
case 0xF2:
|
1150
|
+
if (*(data+1) == 0x0F) {
|
1151
|
+
byte b2 = *(data+2);
|
1152
|
+
if (b2 == 0x11) {
|
1153
|
+
AppendToBuffer("movsd ");
|
1154
|
+
data += 3;
|
1155
|
+
int mod, regop, rm;
|
1156
|
+
get_modrm(*data, &mod, ®op, &rm);
|
1157
|
+
data += PrintRightOperand(data);
|
1158
|
+
AppendToBuffer(",%s", NameOfXMMRegister(regop));
|
1159
|
+
} else if (b2 == 0x10) {
|
1160
|
+
data += 3;
|
1161
|
+
int mod, regop, rm;
|
1162
|
+
get_modrm(*data, &mod, ®op, &rm);
|
1163
|
+
AppendToBuffer("movsd %s,", NameOfXMMRegister(regop));
|
1164
|
+
data += PrintRightOperand(data);
|
1165
|
+
} else {
|
1166
|
+
const char* mnem = "?";
|
1167
|
+
switch (b2) {
|
1168
|
+
case 0x2A: mnem = "cvtsi2sd"; break;
|
1169
|
+
case 0x58: mnem = "addsd"; break;
|
1170
|
+
case 0x59: mnem = "mulsd"; break;
|
1171
|
+
case 0x5C: mnem = "subsd"; break;
|
1172
|
+
case 0x5E: mnem = "divsd"; break;
|
1173
|
+
}
|
1174
|
+
data += 3;
|
1175
|
+
int mod, regop, rm;
|
1176
|
+
get_modrm(*data, &mod, ®op, &rm);
|
1177
|
+
if (b2 == 0x2A) {
|
1178
|
+
AppendToBuffer("%s %s,", mnem, NameOfXMMRegister(regop));
|
1179
|
+
data += PrintRightOperand(data);
|
1180
|
+
} else {
|
1181
|
+
AppendToBuffer("%s %s,%s",
|
1182
|
+
mnem,
|
1183
|
+
NameOfXMMRegister(regop),
|
1184
|
+
NameOfXMMRegister(rm));
|
1185
|
+
data++;
|
1186
|
+
}
|
1187
|
+
}
|
1188
|
+
} else {
|
1189
|
+
UnimplementedInstruction();
|
1190
|
+
}
|
1191
|
+
break;
|
1192
|
+
|
1193
|
+
case 0xF3:
|
1194
|
+
if (*(data+1) == 0x0F) {
|
1195
|
+
if (*(data+2) == 0x2C) {
|
1196
|
+
data += 3;
|
1197
|
+
data += PrintOperands("cvttss2si", REG_OPER_OP_ORDER, data);
|
1198
|
+
} else if (*(data+2) == 0x6F) {
|
1199
|
+
data += 3;
|
1200
|
+
int mod, regop, rm;
|
1201
|
+
get_modrm(*data, &mod, ®op, &rm);
|
1202
|
+
AppendToBuffer("movdqu %s,", NameOfXMMRegister(regop));
|
1203
|
+
data += PrintRightOperand(data);
|
1204
|
+
} else if (*(data+2) == 0x7F) {
|
1205
|
+
AppendToBuffer("movdqu ");
|
1206
|
+
data += 3;
|
1207
|
+
int mod, regop, rm;
|
1208
|
+
get_modrm(*data, &mod, ®op, &rm);
|
1209
|
+
data += PrintRightOperand(data);
|
1210
|
+
AppendToBuffer(",%s", NameOfXMMRegister(regop));
|
1211
|
+
} else {
|
1212
|
+
UnimplementedInstruction();
|
1213
|
+
}
|
1214
|
+
} else if (*(data+1) == 0xA5) {
|
1215
|
+
data += 2;
|
1216
|
+
AppendToBuffer("rep_movs");
|
1217
|
+
} else {
|
1218
|
+
UnimplementedInstruction();
|
1219
|
+
}
|
1220
|
+
break;
|
1221
|
+
|
1222
|
+
case 0xF7:
|
1223
|
+
data += F7Instruction(data);
|
1224
|
+
break;
|
1225
|
+
|
1226
|
+
default:
|
1227
|
+
UnimplementedInstruction();
|
1228
|
+
}
|
1229
|
+
}
|
1230
|
+
|
1231
|
+
if (tmp_buffer_pos_ < sizeof tmp_buffer_) {
|
1232
|
+
tmp_buffer_[tmp_buffer_pos_] = '\0';
|
1233
|
+
}
|
1234
|
+
|
1235
|
+
int instr_len = data - instr;
|
1236
|
+
if (instr_len == 0) {
|
1237
|
+
printf("%02x", *data);
|
1238
|
+
}
|
1239
|
+
ASSERT(instr_len > 0); // Ensure progress.
|
1240
|
+
|
1241
|
+
int outp = 0;
|
1242
|
+
// Instruction bytes.
|
1243
|
+
for (byte* bp = instr; bp < data; bp++) {
|
1244
|
+
outp += v8::internal::OS::SNPrintF(out_buffer + outp,
|
1245
|
+
"%02x",
|
1246
|
+
*bp);
|
1247
|
+
}
|
1248
|
+
for (int i = 6 - instr_len; i >= 0; i--) {
|
1249
|
+
outp += v8::internal::OS::SNPrintF(out_buffer + outp,
|
1250
|
+
" ");
|
1251
|
+
}
|
1252
|
+
|
1253
|
+
outp += v8::internal::OS::SNPrintF(out_buffer + outp,
|
1254
|
+
" %s",
|
1255
|
+
tmp_buffer_.start());
|
1256
|
+
return instr_len;
|
1257
|
+
}
|
1258
|
+
|
1259
|
+
|
1260
|
+
//------------------------------------------------------------------------------
|
1261
|
+
|
1262
|
+
|
1263
|
+
static const char* cpu_regs[8] = {
|
1264
|
+
"eax", "ecx", "edx", "ebx", "esp", "ebp", "esi", "edi"
|
1265
|
+
};
|
1266
|
+
|
1267
|
+
|
1268
|
+
static const char* byte_cpu_regs[8] = {
|
1269
|
+
"al", "cl", "dl", "bl", "ah", "ch", "dh", "bh"
|
1270
|
+
};
|
1271
|
+
|
1272
|
+
|
1273
|
+
static const char* xmm_regs[8] = {
|
1274
|
+
"xmm0", "xmm1", "xmm2", "xmm3", "xmm4", "xmm5", "xmm6", "xmm7"
|
1275
|
+
};
|
1276
|
+
|
1277
|
+
|
1278
|
+
const char* NameConverter::NameOfAddress(byte* addr) const {
|
1279
|
+
static v8::internal::EmbeddedVector<char, 32> tmp_buffer;
|
1280
|
+
v8::internal::OS::SNPrintF(tmp_buffer, "%p", addr);
|
1281
|
+
return tmp_buffer.start();
|
1282
|
+
}
|
1283
|
+
|
1284
|
+
|
1285
|
+
const char* NameConverter::NameOfConstant(byte* addr) const {
|
1286
|
+
return NameOfAddress(addr);
|
1287
|
+
}
|
1288
|
+
|
1289
|
+
|
1290
|
+
const char* NameConverter::NameOfCPURegister(int reg) const {
|
1291
|
+
if (0 <= reg && reg < 8) return cpu_regs[reg];
|
1292
|
+
return "noreg";
|
1293
|
+
}
|
1294
|
+
|
1295
|
+
|
1296
|
+
const char* NameConverter::NameOfByteCPURegister(int reg) const {
|
1297
|
+
if (0 <= reg && reg < 8) return byte_cpu_regs[reg];
|
1298
|
+
return "noreg";
|
1299
|
+
}
|
1300
|
+
|
1301
|
+
|
1302
|
+
const char* NameConverter::NameOfXMMRegister(int reg) const {
|
1303
|
+
if (0 <= reg && reg < 8) return xmm_regs[reg];
|
1304
|
+
return "noxmmreg";
|
1305
|
+
}
|
1306
|
+
|
1307
|
+
|
1308
|
+
const char* NameConverter::NameInCode(byte* addr) const {
|
1309
|
+
// IA32 does not embed debug strings at the moment.
|
1310
|
+
UNREACHABLE();
|
1311
|
+
return "";
|
1312
|
+
}
|
1313
|
+
|
1314
|
+
|
1315
|
+
//------------------------------------------------------------------------------
|
1316
|
+
|
1317
|
+
Disassembler::Disassembler(const NameConverter& converter)
|
1318
|
+
: converter_(converter) {}
|
1319
|
+
|
1320
|
+
|
1321
|
+
Disassembler::~Disassembler() {}
|
1322
|
+
|
1323
|
+
|
1324
|
+
int Disassembler::InstructionDecode(v8::internal::Vector<char> buffer,
|
1325
|
+
byte* instruction) {
|
1326
|
+
DisassemblerIA32 d(converter_, false /*do not crash if unimplemented*/);
|
1327
|
+
return d.InstructionDecode(buffer, instruction);
|
1328
|
+
}
|
1329
|
+
|
1330
|
+
|
1331
|
+
// The IA-32 assembler does not currently use constant pools.
|
1332
|
+
int Disassembler::ConstantPoolSizeAt(byte* instruction) { return -1; }
|
1333
|
+
|
1334
|
+
|
1335
|
+
/*static*/ void Disassembler::Disassemble(FILE* f, byte* begin, byte* end) {
|
1336
|
+
NameConverter converter;
|
1337
|
+
Disassembler d(converter);
|
1338
|
+
for (byte* pc = begin; pc < end;) {
|
1339
|
+
v8::internal::EmbeddedVector<char, 128> buffer;
|
1340
|
+
buffer[0] = '\0';
|
1341
|
+
byte* prev_pc = pc;
|
1342
|
+
pc += d.InstructionDecode(buffer, pc);
|
1343
|
+
fprintf(f, "%p", prev_pc);
|
1344
|
+
fprintf(f, " ");
|
1345
|
+
|
1346
|
+
for (byte* bp = prev_pc; bp < pc; bp++) {
|
1347
|
+
fprintf(f, "%02x", *bp);
|
1348
|
+
}
|
1349
|
+
for (int i = 6 - (pc - prev_pc); i >= 0; i--) {
|
1350
|
+
fprintf(f, " ");
|
1351
|
+
}
|
1352
|
+
fprintf(f, " %s\n", buffer.start());
|
1353
|
+
}
|
1354
|
+
}
|
1355
|
+
|
1356
|
+
|
1357
|
+
} // namespace disasm
|