mustang 0.0.1 → 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.rspec +1 -0
- data/Isolate +9 -0
- data/README.md +6 -12
- data/Rakefile +30 -4
- data/TODO.md +9 -0
- data/ext/v8/extconf.rb +56 -0
- data/ext/v8/v8.cpp +37 -0
- data/ext/v8/v8_array.cpp +161 -0
- data/ext/v8/v8_array.h +17 -0
- data/ext/v8/v8_base.cpp +147 -0
- data/ext/v8/v8_base.h +23 -0
- data/ext/v8/v8_cast.cpp +151 -0
- data/ext/v8/v8_cast.h +64 -0
- data/ext/v8/v8_context.cpp +174 -0
- data/ext/v8/v8_context.h +12 -0
- data/ext/v8/v8_date.cpp +61 -0
- data/ext/v8/v8_date.h +16 -0
- data/ext/v8/v8_errors.cpp +147 -0
- data/ext/v8/v8_errors.h +19 -0
- data/ext/v8/v8_external.cpp +66 -0
- data/ext/v8/v8_external.h +16 -0
- data/ext/v8/v8_function.cpp +182 -0
- data/ext/v8/v8_function.h +14 -0
- data/ext/v8/v8_integer.cpp +70 -0
- data/ext/v8/v8_integer.h +16 -0
- data/ext/v8/v8_macros.h +30 -0
- data/ext/v8/v8_main.cpp +53 -0
- data/ext/v8/v8_main.h +13 -0
- data/ext/v8/v8_number.cpp +62 -0
- data/ext/v8/v8_number.h +16 -0
- data/ext/v8/v8_object.cpp +172 -0
- data/ext/v8/v8_object.h +17 -0
- data/ext/v8/v8_ref.cpp +72 -0
- data/ext/v8/v8_ref.h +43 -0
- data/ext/v8/v8_regexp.cpp +148 -0
- data/ext/v8/v8_regexp.h +16 -0
- data/ext/v8/v8_string.cpp +78 -0
- data/ext/v8/v8_string.h +16 -0
- data/ext/v8/v8_value.cpp +370 -0
- data/ext/v8/v8_value.h +19 -0
- data/gemspec.yml +2 -1
- data/lib/core_ext/class.rb +14 -0
- data/lib/core_ext/object.rb +12 -0
- data/lib/core_ext/symbol.rb +23 -0
- data/lib/mustang.rb +44 -0
- data/lib/mustang/context.rb +69 -0
- data/lib/mustang/errors.rb +36 -0
- data/lib/support/delegated.rb +25 -0
- data/lib/v8/array.rb +21 -0
- data/lib/v8/context.rb +13 -0
- data/lib/v8/date.rb +20 -0
- data/lib/v8/error.rb +15 -0
- data/lib/v8/external.rb +16 -0
- data/lib/v8/function.rb +11 -0
- data/lib/v8/integer.rb +16 -0
- data/lib/v8/number.rb +16 -0
- data/lib/v8/object.rb +66 -0
- data/lib/v8/regexp.rb +23 -0
- data/lib/v8/string.rb +27 -0
- data/mustang.gemspec +3 -0
- data/spec/core_ext/class_spec.rb +19 -0
- data/spec/core_ext/object_spec.rb +19 -0
- data/spec/core_ext/symbol_spec.rb +27 -0
- data/spec/fixtures/test1.js +2 -0
- data/spec/fixtures/test2.js +2 -0
- data/spec/spec_helper.rb +20 -0
- data/spec/v8/array_spec.rb +88 -0
- data/spec/v8/cast_spec.rb +151 -0
- data/spec/v8/context_spec.rb +78 -0
- data/spec/v8/data_spec.rb +39 -0
- data/spec/v8/date_spec.rb +45 -0
- data/spec/v8/empty_spec.rb +27 -0
- data/spec/v8/errors_spec.rb +142 -0
- data/spec/v8/external_spec.rb +44 -0
- data/spec/v8/function_spec.rb +170 -0
- data/spec/v8/integer_spec.rb +41 -0
- data/spec/v8/main_spec.rb +18 -0
- data/spec/v8/null_spec.rb +27 -0
- data/spec/v8/number_spec.rb +40 -0
- data/spec/v8/object_spec.rb +79 -0
- data/spec/v8/primitive_spec.rb +9 -0
- data/spec/v8/regexp_spec.rb +65 -0
- data/spec/v8/string_spec.rb +48 -0
- data/spec/v8/undefined_spec.rb +27 -0
- data/spec/v8/value_spec.rb +215 -0
- data/vendor/v8/.gitignore +2 -0
- data/vendor/v8/AUTHORS +3 -1
- data/vendor/v8/ChangeLog +117 -0
- data/vendor/v8/SConstruct +334 -53
- data/vendor/v8/include/v8-debug.h +21 -11
- data/vendor/v8/include/v8-preparser.h +1 -1
- data/vendor/v8/include/v8-profiler.h +122 -43
- data/vendor/v8/include/v8-testing.h +5 -0
- data/vendor/v8/include/v8.h +171 -17
- data/vendor/v8/preparser/SConscript +38 -0
- data/vendor/v8/preparser/preparser-process.cc +77 -114
- data/vendor/v8/samples/shell.cc +232 -46
- data/vendor/v8/src/SConscript +29 -5
- data/vendor/v8/src/accessors.cc +70 -211
- data/vendor/v8/{test/cctest/test-mips.cc → src/allocation-inl.h} +15 -18
- data/vendor/v8/src/allocation.cc +0 -82
- data/vendor/v8/src/allocation.h +9 -42
- data/vendor/v8/src/api.cc +1645 -1156
- data/vendor/v8/src/api.h +76 -12
- data/vendor/v8/src/apiutils.h +0 -7
- data/vendor/v8/src/arguments.h +15 -4
- data/vendor/v8/src/arm/assembler-arm-inl.h +10 -9
- data/vendor/v8/src/arm/assembler-arm.cc +62 -23
- data/vendor/v8/src/arm/assembler-arm.h +76 -11
- data/vendor/v8/src/arm/builtins-arm.cc +39 -33
- data/vendor/v8/src/arm/code-stubs-arm.cc +1182 -402
- data/vendor/v8/src/arm/code-stubs-arm.h +20 -54
- data/vendor/v8/src/arm/codegen-arm.cc +159 -106
- data/vendor/v8/src/arm/codegen-arm.h +6 -6
- data/vendor/v8/src/arm/constants-arm.h +16 -1
- data/vendor/v8/src/arm/cpu-arm.cc +7 -5
- data/vendor/v8/src/arm/debug-arm.cc +6 -4
- data/vendor/v8/src/arm/deoptimizer-arm.cc +51 -14
- data/vendor/v8/src/arm/disasm-arm.cc +47 -15
- data/vendor/v8/src/arm/frames-arm.h +1 -1
- data/vendor/v8/src/arm/full-codegen-arm.cc +724 -408
- data/vendor/v8/src/arm/ic-arm.cc +90 -85
- data/vendor/v8/src/arm/lithium-arm.cc +140 -69
- data/vendor/v8/src/arm/lithium-arm.h +161 -46
- data/vendor/v8/src/arm/lithium-codegen-arm.cc +567 -297
- data/vendor/v8/src/arm/lithium-codegen-arm.h +21 -9
- data/vendor/v8/src/arm/lithium-gap-resolver-arm.cc +2 -0
- data/vendor/v8/src/arm/macro-assembler-arm.cc +457 -96
- data/vendor/v8/src/arm/macro-assembler-arm.h +115 -18
- data/vendor/v8/src/arm/regexp-macro-assembler-arm.cc +20 -13
- data/vendor/v8/src/arm/regexp-macro-assembler-arm.h +1 -0
- data/vendor/v8/src/arm/simulator-arm.cc +184 -101
- data/vendor/v8/src/arm/simulator-arm.h +26 -21
- data/vendor/v8/src/arm/stub-cache-arm.cc +450 -467
- data/vendor/v8/src/arm/virtual-frame-arm.cc +14 -12
- data/vendor/v8/src/arm/virtual-frame-arm.h +11 -8
- data/vendor/v8/src/array.js +35 -18
- data/vendor/v8/src/assembler.cc +186 -92
- data/vendor/v8/src/assembler.h +106 -69
- data/vendor/v8/src/ast-inl.h +5 -0
- data/vendor/v8/src/ast.cc +46 -35
- data/vendor/v8/src/ast.h +107 -50
- data/vendor/v8/src/atomicops.h +2 -0
- data/vendor/v8/src/atomicops_internals_mips_gcc.h +169 -0
- data/vendor/v8/src/bootstrapper.cc +649 -399
- data/vendor/v8/src/bootstrapper.h +94 -27
- data/vendor/v8/src/builtins.cc +359 -227
- data/vendor/v8/src/builtins.h +157 -123
- data/vendor/v8/src/checks.cc +2 -2
- data/vendor/v8/src/checks.h +4 -0
- data/vendor/v8/src/code-stubs.cc +27 -17
- data/vendor/v8/src/code-stubs.h +38 -17
- data/vendor/v8/src/codegen-inl.h +5 -1
- data/vendor/v8/src/codegen.cc +27 -17
- data/vendor/v8/src/codegen.h +9 -9
- data/vendor/v8/src/compilation-cache.cc +92 -206
- data/vendor/v8/src/compilation-cache.h +205 -30
- data/vendor/v8/src/compiler.cc +107 -120
- data/vendor/v8/src/compiler.h +17 -2
- data/vendor/v8/src/contexts.cc +22 -15
- data/vendor/v8/src/contexts.h +14 -8
- data/vendor/v8/src/conversions.cc +86 -30
- data/vendor/v8/src/counters.cc +19 -4
- data/vendor/v8/src/counters.h +28 -16
- data/vendor/v8/src/cpu-profiler-inl.h +4 -3
- data/vendor/v8/src/cpu-profiler.cc +123 -72
- data/vendor/v8/src/cpu-profiler.h +33 -19
- data/vendor/v8/src/cpu.h +2 -0
- data/vendor/v8/src/d8-debug.cc +3 -3
- data/vendor/v8/src/d8-debug.h +7 -6
- data/vendor/v8/src/d8-posix.cc +2 -0
- data/vendor/v8/src/d8.cc +22 -12
- data/vendor/v8/src/d8.gyp +3 -0
- data/vendor/v8/src/d8.js +618 -0
- data/vendor/v8/src/data-flow.h +3 -3
- data/vendor/v8/src/dateparser.h +4 -2
- data/vendor/v8/src/debug-agent.cc +10 -9
- data/vendor/v8/src/debug-agent.h +9 -11
- data/vendor/v8/src/debug-debugger.js +121 -0
- data/vendor/v8/src/debug.cc +331 -227
- data/vendor/v8/src/debug.h +248 -219
- data/vendor/v8/src/deoptimizer.cc +173 -62
- data/vendor/v8/src/deoptimizer.h +119 -19
- data/vendor/v8/src/disasm.h +3 -0
- data/vendor/v8/src/disassembler.cc +10 -9
- data/vendor/v8/src/execution.cc +185 -129
- data/vendor/v8/src/execution.h +47 -78
- data/vendor/v8/src/extensions/experimental/break-iterator.cc +250 -0
- data/vendor/v8/src/extensions/experimental/break-iterator.h +89 -0
- data/vendor/v8/src/extensions/experimental/experimental.gyp +2 -0
- data/vendor/v8/src/extensions/experimental/i18n-extension.cc +22 -2
- data/vendor/v8/src/extensions/externalize-string-extension.cc +2 -2
- data/vendor/v8/src/extensions/gc-extension.cc +1 -1
- data/vendor/v8/src/factory.cc +261 -154
- data/vendor/v8/src/factory.h +162 -158
- data/vendor/v8/src/flag-definitions.h +17 -11
- data/vendor/v8/src/frame-element.cc +0 -5
- data/vendor/v8/src/frame-element.h +9 -13
- data/vendor/v8/src/frames-inl.h +7 -0
- data/vendor/v8/src/frames.cc +56 -46
- data/vendor/v8/src/frames.h +36 -25
- data/vendor/v8/src/full-codegen.cc +15 -24
- data/vendor/v8/src/full-codegen.h +13 -41
- data/vendor/v8/src/func-name-inferrer.cc +7 -6
- data/vendor/v8/src/func-name-inferrer.h +1 -1
- data/vendor/v8/src/gdb-jit.cc +1 -0
- data/vendor/v8/src/global-handles.cc +118 -56
- data/vendor/v8/src/global-handles.h +98 -40
- data/vendor/v8/src/globals.h +2 -2
- data/vendor/v8/src/handles-inl.h +106 -9
- data/vendor/v8/src/handles.cc +220 -157
- data/vendor/v8/src/handles.h +38 -59
- data/vendor/v8/src/hashmap.h +3 -3
- data/vendor/v8/src/heap-inl.h +141 -25
- data/vendor/v8/src/heap-profiler.cc +117 -63
- data/vendor/v8/src/heap-profiler.h +38 -21
- data/vendor/v8/src/heap.cc +805 -564
- data/vendor/v8/src/heap.h +640 -594
- data/vendor/v8/src/hydrogen-instructions.cc +216 -73
- data/vendor/v8/src/hydrogen-instructions.h +259 -124
- data/vendor/v8/src/hydrogen.cc +996 -1171
- data/vendor/v8/src/hydrogen.h +163 -144
- data/vendor/v8/src/ia32/assembler-ia32-inl.h +12 -11
- data/vendor/v8/src/ia32/assembler-ia32.cc +85 -39
- data/vendor/v8/src/ia32/assembler-ia32.h +82 -16
- data/vendor/v8/src/ia32/builtins-ia32.cc +64 -58
- data/vendor/v8/src/ia32/code-stubs-ia32.cc +248 -324
- data/vendor/v8/src/ia32/code-stubs-ia32.h +3 -44
- data/vendor/v8/src/ia32/codegen-ia32.cc +217 -165
- data/vendor/v8/src/ia32/codegen-ia32.h +3 -0
- data/vendor/v8/src/ia32/cpu-ia32.cc +6 -5
- data/vendor/v8/src/ia32/debug-ia32.cc +8 -5
- data/vendor/v8/src/ia32/deoptimizer-ia32.cc +124 -14
- data/vendor/v8/src/ia32/disasm-ia32.cc +85 -62
- data/vendor/v8/src/ia32/frames-ia32.h +1 -1
- data/vendor/v8/src/ia32/full-codegen-ia32.cc +348 -435
- data/vendor/v8/src/ia32/ic-ia32.cc +91 -91
- data/vendor/v8/src/ia32/lithium-codegen-ia32.cc +500 -255
- data/vendor/v8/src/ia32/lithium-codegen-ia32.h +13 -4
- data/vendor/v8/src/ia32/lithium-gap-resolver-ia32.cc +6 -0
- data/vendor/v8/src/ia32/lithium-ia32.cc +122 -45
- data/vendor/v8/src/ia32/lithium-ia32.h +128 -41
- data/vendor/v8/src/ia32/macro-assembler-ia32.cc +109 -84
- data/vendor/v8/src/ia32/macro-assembler-ia32.h +18 -9
- data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.cc +26 -15
- data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.h +1 -0
- data/vendor/v8/src/ia32/register-allocator-ia32.cc +30 -30
- data/vendor/v8/src/ia32/simulator-ia32.h +4 -4
- data/vendor/v8/src/ia32/stub-cache-ia32.cc +383 -400
- data/vendor/v8/src/ia32/virtual-frame-ia32.cc +36 -13
- data/vendor/v8/src/ia32/virtual-frame-ia32.h +11 -5
- data/vendor/v8/src/ic-inl.h +12 -2
- data/vendor/v8/src/ic.cc +304 -221
- data/vendor/v8/src/ic.h +115 -58
- data/vendor/v8/src/interpreter-irregexp.cc +25 -21
- data/vendor/v8/src/interpreter-irregexp.h +2 -1
- data/vendor/v8/src/isolate.cc +883 -0
- data/vendor/v8/src/isolate.h +1304 -0
- data/vendor/v8/src/json.js +10 -10
- data/vendor/v8/src/jsregexp.cc +111 -80
- data/vendor/v8/src/jsregexp.h +6 -7
- data/vendor/v8/src/jump-target-heavy.cc +5 -8
- data/vendor/v8/src/jump-target-heavy.h +0 -6
- data/vendor/v8/src/jump-target-inl.h +1 -1
- data/vendor/v8/src/jump-target-light.cc +3 -3
- data/vendor/v8/src/lithium-allocator-inl.h +2 -0
- data/vendor/v8/src/lithium-allocator.cc +42 -30
- data/vendor/v8/src/lithium-allocator.h +8 -22
- data/vendor/v8/src/lithium.cc +1 -0
- data/vendor/v8/src/liveedit.cc +141 -99
- data/vendor/v8/src/liveedit.h +7 -2
- data/vendor/v8/src/liveobjectlist-inl.h +90 -0
- data/vendor/v8/src/liveobjectlist.cc +2537 -1
- data/vendor/v8/src/liveobjectlist.h +245 -35
- data/vendor/v8/src/log-utils.cc +122 -35
- data/vendor/v8/src/log-utils.h +33 -36
- data/vendor/v8/src/log.cc +299 -241
- data/vendor/v8/src/log.h +177 -110
- data/vendor/v8/src/mark-compact.cc +612 -470
- data/vendor/v8/src/mark-compact.h +153 -80
- data/vendor/v8/src/messages.cc +16 -14
- data/vendor/v8/src/messages.js +30 -7
- data/vendor/v8/src/mips/assembler-mips-inl.h +155 -35
- data/vendor/v8/src/mips/assembler-mips.cc +1093 -219
- data/vendor/v8/src/mips/assembler-mips.h +552 -153
- data/vendor/v8/src/mips/builtins-mips.cc +43 -100
- data/vendor/v8/src/mips/code-stubs-mips.cc +752 -0
- data/vendor/v8/src/mips/code-stubs-mips.h +511 -0
- data/vendor/v8/src/mips/codegen-mips-inl.h +8 -14
- data/vendor/v8/src/mips/codegen-mips.cc +672 -896
- data/vendor/v8/src/mips/codegen-mips.h +271 -69
- data/vendor/v8/src/mips/constants-mips.cc +44 -20
- data/vendor/v8/src/mips/constants-mips.h +238 -40
- data/vendor/v8/src/mips/cpu-mips.cc +20 -3
- data/vendor/v8/src/mips/debug-mips.cc +35 -7
- data/vendor/v8/src/mips/deoptimizer-mips.cc +91 -0
- data/vendor/v8/src/mips/disasm-mips.cc +329 -93
- data/vendor/v8/src/mips/frames-mips.cc +2 -50
- data/vendor/v8/src/mips/frames-mips.h +24 -9
- data/vendor/v8/src/mips/full-codegen-mips.cc +473 -23
- data/vendor/v8/src/mips/ic-mips.cc +81 -45
- data/vendor/v8/src/mips/jump-target-mips.cc +11 -106
- data/vendor/v8/src/mips/lithium-codegen-mips.h +65 -0
- data/vendor/v8/src/mips/lithium-mips.h +304 -0
- data/vendor/v8/src/mips/macro-assembler-mips.cc +2391 -390
- data/vendor/v8/src/mips/macro-assembler-mips.h +718 -121
- data/vendor/v8/src/mips/regexp-macro-assembler-mips.cc +478 -0
- data/vendor/v8/src/mips/regexp-macro-assembler-mips.h +250 -0
- data/vendor/v8/src/mips/register-allocator-mips-inl.h +0 -3
- data/vendor/v8/src/mips/register-allocator-mips.h +3 -2
- data/vendor/v8/src/mips/simulator-mips.cc +1009 -221
- data/vendor/v8/src/mips/simulator-mips.h +119 -36
- data/vendor/v8/src/mips/stub-cache-mips.cc +331 -148
- data/vendor/v8/src/mips/{fast-codegen-mips.cc → virtual-frame-mips-inl.h} +11 -30
- data/vendor/v8/src/mips/virtual-frame-mips.cc +137 -149
- data/vendor/v8/src/mips/virtual-frame-mips.h +294 -312
- data/vendor/v8/src/mirror-debugger.js +9 -8
- data/vendor/v8/src/mksnapshot.cc +2 -2
- data/vendor/v8/src/objects-debug.cc +16 -16
- data/vendor/v8/src/objects-inl.h +421 -195
- data/vendor/v8/src/objects-printer.cc +7 -7
- data/vendor/v8/src/objects-visiting.cc +1 -1
- data/vendor/v8/src/objects-visiting.h +33 -12
- data/vendor/v8/src/objects.cc +935 -658
- data/vendor/v8/src/objects.h +234 -139
- data/vendor/v8/src/parser.cc +484 -439
- data/vendor/v8/src/parser.h +35 -14
- data/vendor/v8/src/platform-cygwin.cc +173 -107
- data/vendor/v8/src/platform-freebsd.cc +224 -72
- data/vendor/v8/src/platform-linux.cc +234 -95
- data/vendor/v8/src/platform-macos.cc +215 -82
- data/vendor/v8/src/platform-nullos.cc +9 -3
- data/vendor/v8/src/platform-openbsd.cc +22 -7
- data/vendor/v8/src/platform-posix.cc +30 -5
- data/vendor/v8/src/platform-solaris.cc +120 -38
- data/vendor/v8/src/platform-tls-mac.h +62 -0
- data/vendor/v8/src/platform-tls-win32.h +62 -0
- data/vendor/v8/src/platform-tls.h +50 -0
- data/vendor/v8/src/platform-win32.cc +195 -97
- data/vendor/v8/src/platform.h +72 -15
- data/vendor/v8/src/preparse-data.cc +2 -0
- data/vendor/v8/src/preparser-api.cc +8 -2
- data/vendor/v8/src/preparser.cc +1 -1
- data/vendor/v8/src/prettyprinter.cc +43 -52
- data/vendor/v8/src/prettyprinter.h +1 -1
- data/vendor/v8/src/profile-generator-inl.h +0 -28
- data/vendor/v8/src/profile-generator.cc +942 -685
- data/vendor/v8/src/profile-generator.h +210 -176
- data/vendor/v8/src/property.cc +6 -0
- data/vendor/v8/src/property.h +14 -3
- data/vendor/v8/src/regexp-macro-assembler-irregexp.cc +1 -1
- data/vendor/v8/src/regexp-macro-assembler.cc +28 -19
- data/vendor/v8/src/regexp-macro-assembler.h +11 -6
- data/vendor/v8/src/regexp-stack.cc +18 -10
- data/vendor/v8/src/regexp-stack.h +45 -21
- data/vendor/v8/src/regexp.js +3 -3
- data/vendor/v8/src/register-allocator-inl.h +3 -3
- data/vendor/v8/src/register-allocator.cc +1 -7
- data/vendor/v8/src/register-allocator.h +5 -15
- data/vendor/v8/src/rewriter.cc +2 -1
- data/vendor/v8/src/runtime-profiler.cc +158 -128
- data/vendor/v8/src/runtime-profiler.h +131 -15
- data/vendor/v8/src/runtime.cc +2409 -1692
- data/vendor/v8/src/runtime.h +93 -17
- data/vendor/v8/src/safepoint-table.cc +3 -0
- data/vendor/v8/src/safepoint-table.h +9 -3
- data/vendor/v8/src/scanner-base.cc +21 -28
- data/vendor/v8/src/scanner-base.h +22 -11
- data/vendor/v8/src/scanner.cc +3 -5
- data/vendor/v8/src/scanner.h +4 -2
- data/vendor/v8/src/scopeinfo.cc +11 -16
- data/vendor/v8/src/scopeinfo.h +26 -15
- data/vendor/v8/src/scopes.cc +67 -37
- data/vendor/v8/src/scopes.h +26 -12
- data/vendor/v8/src/serialize.cc +193 -154
- data/vendor/v8/src/serialize.h +41 -36
- data/vendor/v8/src/small-pointer-list.h +163 -0
- data/vendor/v8/src/snapshot-common.cc +1 -1
- data/vendor/v8/src/snapshot.h +3 -1
- data/vendor/v8/src/spaces-inl.h +30 -25
- data/vendor/v8/src/spaces.cc +263 -370
- data/vendor/v8/src/spaces.h +178 -166
- data/vendor/v8/src/string-search.cc +4 -3
- data/vendor/v8/src/string-search.h +21 -20
- data/vendor/v8/src/string-stream.cc +32 -24
- data/vendor/v8/src/string.js +7 -7
- data/vendor/v8/src/stub-cache.cc +324 -248
- data/vendor/v8/src/stub-cache.h +181 -155
- data/vendor/v8/src/token.cc +3 -3
- data/vendor/v8/src/token.h +3 -3
- data/vendor/v8/src/top.cc +218 -390
- data/vendor/v8/src/type-info.cc +98 -32
- data/vendor/v8/src/type-info.h +10 -3
- data/vendor/v8/src/unicode.cc +1 -1
- data/vendor/v8/src/unicode.h +1 -1
- data/vendor/v8/src/utils.h +3 -0
- data/vendor/v8/src/v8-counters.cc +18 -11
- data/vendor/v8/src/v8-counters.h +34 -13
- data/vendor/v8/src/v8.cc +66 -121
- data/vendor/v8/src/v8.h +7 -4
- data/vendor/v8/src/v8globals.h +18 -12
- data/vendor/v8/src/{memory.h → v8memory.h} +0 -0
- data/vendor/v8/src/v8natives.js +59 -18
- data/vendor/v8/src/v8threads.cc +127 -114
- data/vendor/v8/src/v8threads.h +42 -35
- data/vendor/v8/src/v8utils.h +2 -39
- data/vendor/v8/src/variables.h +1 -1
- data/vendor/v8/src/version.cc +26 -5
- data/vendor/v8/src/version.h +4 -0
- data/vendor/v8/src/virtual-frame-heavy-inl.h +2 -4
- data/vendor/v8/src/virtual-frame-light-inl.h +5 -4
- data/vendor/v8/src/vm-state-inl.h +21 -17
- data/vendor/v8/src/vm-state.h +7 -5
- data/vendor/v8/src/win32-headers.h +1 -0
- data/vendor/v8/src/x64/assembler-x64-inl.h +12 -11
- data/vendor/v8/src/x64/assembler-x64.cc +80 -40
- data/vendor/v8/src/x64/assembler-x64.h +67 -17
- data/vendor/v8/src/x64/builtins-x64.cc +34 -33
- data/vendor/v8/src/x64/code-stubs-x64.cc +636 -377
- data/vendor/v8/src/x64/code-stubs-x64.h +14 -48
- data/vendor/v8/src/x64/codegen-x64-inl.h +1 -1
- data/vendor/v8/src/x64/codegen-x64.cc +158 -136
- data/vendor/v8/src/x64/codegen-x64.h +4 -1
- data/vendor/v8/src/x64/cpu-x64.cc +7 -5
- data/vendor/v8/src/x64/debug-x64.cc +8 -6
- data/vendor/v8/src/x64/deoptimizer-x64.cc +195 -20
- data/vendor/v8/src/x64/disasm-x64.cc +42 -23
- data/vendor/v8/src/x64/frames-x64.cc +1 -1
- data/vendor/v8/src/x64/frames-x64.h +2 -2
- data/vendor/v8/src/x64/full-codegen-x64.cc +780 -218
- data/vendor/v8/src/x64/ic-x64.cc +77 -79
- data/vendor/v8/src/x64/jump-target-x64.cc +1 -1
- data/vendor/v8/src/x64/lithium-codegen-x64.cc +698 -181
- data/vendor/v8/src/x64/lithium-codegen-x64.h +31 -6
- data/vendor/v8/src/x64/lithium-x64.cc +136 -54
- data/vendor/v8/src/x64/lithium-x64.h +142 -51
- data/vendor/v8/src/x64/macro-assembler-x64.cc +456 -187
- data/vendor/v8/src/x64/macro-assembler-x64.h +166 -34
- data/vendor/v8/src/x64/regexp-macro-assembler-x64.cc +44 -28
- data/vendor/v8/src/x64/regexp-macro-assembler-x64.h +8 -4
- data/vendor/v8/src/x64/register-allocator-x64-inl.h +3 -3
- data/vendor/v8/src/x64/register-allocator-x64.cc +12 -8
- data/vendor/v8/src/x64/simulator-x64.h +5 -5
- data/vendor/v8/src/x64/stub-cache-x64.cc +299 -344
- data/vendor/v8/src/x64/virtual-frame-x64.cc +37 -13
- data/vendor/v8/src/x64/virtual-frame-x64.h +13 -7
- data/vendor/v8/src/zone-inl.h +49 -3
- data/vendor/v8/src/zone.cc +42 -41
- data/vendor/v8/src/zone.h +37 -34
- data/vendor/v8/test/benchmarks/testcfg.py +100 -0
- data/vendor/v8/test/cctest/SConscript +5 -4
- data/vendor/v8/test/cctest/cctest.h +3 -2
- data/vendor/v8/test/cctest/cctest.status +6 -11
- data/vendor/v8/test/cctest/test-accessors.cc +3 -3
- data/vendor/v8/test/cctest/test-alloc.cc +39 -33
- data/vendor/v8/test/cctest/test-api.cc +1092 -205
- data/vendor/v8/test/cctest/test-assembler-arm.cc +39 -25
- data/vendor/v8/test/cctest/test-assembler-ia32.cc +36 -37
- data/vendor/v8/test/cctest/test-assembler-mips.cc +1098 -40
- data/vendor/v8/test/cctest/test-assembler-x64.cc +32 -25
- data/vendor/v8/test/cctest/test-ast.cc +1 -0
- data/vendor/v8/test/cctest/test-circular-queue.cc +8 -5
- data/vendor/v8/test/cctest/test-compiler.cc +24 -24
- data/vendor/v8/test/cctest/test-cpu-profiler.cc +140 -5
- data/vendor/v8/test/cctest/test-dataflow.cc +1 -0
- data/vendor/v8/test/cctest/test-debug.cc +136 -77
- data/vendor/v8/test/cctest/test-decls.cc +1 -1
- data/vendor/v8/test/cctest/test-deoptimization.cc +25 -24
- data/vendor/v8/test/cctest/test-disasm-arm.cc +9 -4
- data/vendor/v8/test/cctest/test-disasm-ia32.cc +10 -8
- data/vendor/v8/test/cctest/test-func-name-inference.cc +10 -4
- data/vendor/v8/test/cctest/test-heap-profiler.cc +226 -164
- data/vendor/v8/test/cctest/test-heap.cc +240 -217
- data/vendor/v8/test/cctest/test-liveedit.cc +1 -0
- data/vendor/v8/test/cctest/test-log-stack-tracer.cc +18 -20
- data/vendor/v8/test/cctest/test-log.cc +114 -108
- data/vendor/v8/test/cctest/test-macro-assembler-x64.cc +247 -177
- data/vendor/v8/test/cctest/test-mark-compact.cc +129 -90
- data/vendor/v8/test/cctest/test-parsing.cc +15 -14
- data/vendor/v8/test/cctest/test-platform-linux.cc +1 -0
- data/vendor/v8/test/cctest/test-platform-tls.cc +66 -0
- data/vendor/v8/test/cctest/test-platform-win32.cc +1 -0
- data/vendor/v8/test/cctest/test-profile-generator.cc +1 -1
- data/vendor/v8/test/cctest/test-regexp.cc +53 -41
- data/vendor/v8/test/cctest/test-reloc-info.cc +18 -11
- data/vendor/v8/test/cctest/test-serialize.cc +44 -43
- data/vendor/v8/test/cctest/test-sockets.cc +8 -3
- data/vendor/v8/test/cctest/test-spaces.cc +47 -29
- data/vendor/v8/test/cctest/test-strings.cc +20 -20
- data/vendor/v8/test/cctest/test-thread-termination.cc +8 -3
- data/vendor/v8/test/cctest/test-threads.cc +5 -3
- data/vendor/v8/test/cctest/test-utils.cc +5 -4
- data/vendor/v8/test/cctest/testcfg.py +7 -3
- data/vendor/v8/test/es5conform/es5conform.status +2 -77
- data/vendor/v8/test/es5conform/testcfg.py +1 -1
- data/vendor/v8/test/message/testcfg.py +1 -1
- data/vendor/v8/test/mjsunit/accessors-on-global-object.js +3 -3
- data/vendor/v8/test/mjsunit/array-concat.js +43 -1
- data/vendor/v8/test/mjsunit/array-join.js +25 -0
- data/vendor/v8/test/mjsunit/bitops-info.js +7 -1
- data/vendor/v8/test/mjsunit/compiler/array-length.js +2 -2
- data/vendor/v8/test/mjsunit/compiler/global-accessors.js +47 -0
- data/vendor/v8/test/mjsunit/compiler/pic.js +1 -1
- data/vendor/v8/test/mjsunit/compiler/regress-loadfield.js +65 -0
- data/vendor/v8/test/mjsunit/math-sqrt.js +5 -1
- data/vendor/v8/test/mjsunit/mjsunit.js +59 -8
- data/vendor/v8/test/mjsunit/mjsunit.status +0 -12
- data/vendor/v8/test/mjsunit/mul-exhaustive.js +129 -11
- data/vendor/v8/test/mjsunit/negate-zero.js +1 -1
- data/vendor/v8/test/mjsunit/object-freeze.js +5 -13
- data/vendor/v8/test/mjsunit/object-prevent-extensions.js +9 -50
- data/vendor/v8/test/mjsunit/object-seal.js +4 -13
- data/vendor/v8/test/mjsunit/override-eval-with-non-function.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-1145.js +54 -0
- data/vendor/v8/test/mjsunit/regress/regress-1172-bis.js +37 -0
- data/vendor/v8/test/mjsunit/regress/regress-1181.js +54 -0
- data/vendor/v8/test/mjsunit/regress/regress-1207.js +35 -0
- data/vendor/v8/test/mjsunit/regress/regress-1209.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-1210.js +48 -0
- data/vendor/v8/test/mjsunit/regress/regress-1213.js +43 -0
- data/vendor/v8/test/mjsunit/regress/regress-1218.js +29 -0
- data/vendor/v8/test/mjsunit/regress/regress-1229.js +79 -0
- data/vendor/v8/test/mjsunit/regress/regress-1233.js +47 -0
- data/vendor/v8/test/mjsunit/regress/regress-1236.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-1237.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-1240.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-1257.js +58 -0
- data/vendor/v8/test/mjsunit/regress/regress-1278.js +69 -0
- data/vendor/v8/test/mjsunit/regress/regress-create-exception.js +1 -0
- data/vendor/v8/test/mjsunit/regress/regress-lazy-deopt-reloc.js +52 -0
- data/vendor/v8/test/mjsunit/sin-cos.js +15 -10
- data/vendor/v8/test/mjsunit/smi-negative-zero.js +2 -2
- data/vendor/v8/test/mjsunit/str-to-num.js +1 -1
- data/vendor/v8/test/mjsunit/strict-mode.js +435 -0
- data/vendor/v8/test/mjsunit/testcfg.py +23 -6
- data/vendor/v8/test/mozilla/mozilla.status +0 -2
- data/vendor/v8/test/mozilla/testcfg.py +1 -1
- data/vendor/v8/test/preparser/empty.js +28 -0
- data/vendor/v8/test/preparser/functions-only.js +38 -0
- data/vendor/v8/test/preparser/non-alphanum.js +34 -0
- data/vendor/v8/test/preparser/symbols-only.js +49 -0
- data/vendor/v8/test/preparser/testcfg.py +90 -0
- data/vendor/v8/test/sputnik/testcfg.py +1 -1
- data/vendor/v8/test/test262/README +16 -0
- data/vendor/v8/test/test262/harness-adapt.js +80 -0
- data/vendor/v8/test/test262/test262.status +1506 -0
- data/vendor/v8/test/test262/testcfg.py +123 -0
- data/vendor/v8/tools/freebsd-tick-processor +10 -0
- data/vendor/v8/tools/gyp/v8.gyp +8 -33
- data/vendor/v8/tools/linux-tick-processor +5 -3
- data/vendor/v8/tools/test.py +37 -14
- data/vendor/v8/tools/tickprocessor.js +22 -8
- data/vendor/v8/tools/visual_studio/v8_base.vcproj +13 -1
- data/vendor/v8/tools/visual_studio/v8_base_arm.vcproj +5 -1
- data/vendor/v8/tools/visual_studio/v8_base_x64.vcproj +5 -1
- data/vendor/v8/tools/visual_studio/x64.vsprops +1 -0
- metadata +1495 -1341
- data/ext/extconf.rb +0 -22
- data/ext/mustang.cpp +0 -58
- data/vendor/v8/src/top.h +0 -608
@@ -1,4 +1,4 @@
|
|
1
|
-
// Copyright
|
1
|
+
// Copyright 2011 the V8 project authors. All rights reserved.
|
2
2
|
// Redistribution and use in source and binary forms, with or without
|
3
3
|
// modification, are permitted provided that the following conditions are
|
4
4
|
// met:
|
@@ -97,10 +97,10 @@ private:
|
|
97
97
|
#define FLAG FLAG_FULL
|
98
98
|
|
99
99
|
// Flags for Crankshaft.
|
100
|
-
#ifdef
|
101
|
-
DEFINE_bool(crankshaft,
|
100
|
+
#ifdef V8_TARGET_ARCH_MIPS
|
101
|
+
DEFINE_bool(crankshaft, false, "use crankshaft")
|
102
102
|
#else
|
103
|
-
DEFINE_bool(crankshaft,
|
103
|
+
DEFINE_bool(crankshaft, true, "use crankshaft")
|
104
104
|
#endif
|
105
105
|
DEFINE_string(hydrogen_filter, "", "hydrogen use/trace filter")
|
106
106
|
DEFINE_bool(use_hydrogen, true, "use generated hydrogen for compilation")
|
@@ -110,13 +110,12 @@ DEFINE_bool(use_lithium, true, "use lithium code generator")
|
|
110
110
|
DEFINE_bool(use_range, true, "use hydrogen range analysis")
|
111
111
|
DEFINE_bool(eliminate_dead_phis, true, "eliminate dead phis")
|
112
112
|
DEFINE_bool(use_gvn, true, "use hydrogen global value numbering")
|
113
|
-
DEFINE_bool(use_peeling, false, "use loop peeling")
|
114
113
|
DEFINE_bool(use_canonicalizing, true, "use hydrogen instruction canonicalizing")
|
115
114
|
DEFINE_bool(use_inlining, true, "use function inlining")
|
116
115
|
DEFINE_bool(limit_inlining, true, "limit code size growth from inlining")
|
117
116
|
DEFINE_bool(eliminate_empty_blocks, true, "eliminate empty blocks")
|
118
117
|
DEFINE_bool(loop_invariant_code_motion, true, "loop invariant code motion")
|
119
|
-
DEFINE_bool(
|
118
|
+
DEFINE_bool(hydrogen_stats, false, "print statistics for hydrogen")
|
120
119
|
DEFINE_bool(trace_hydrogen, false, "trace generated hydrogen to file")
|
121
120
|
DEFINE_bool(trace_inlining, false, "trace inlining decisions")
|
122
121
|
DEFINE_bool(trace_alloc, false, "trace register allocator")
|
@@ -135,11 +134,8 @@ DEFINE_bool(deoptimize_uncommon_cases, true, "deoptimize uncommon cases")
|
|
135
134
|
DEFINE_bool(polymorphic_inlining, true, "polymorphic inlining")
|
136
135
|
DEFINE_bool(aggressive_loop_invariant_motion, true,
|
137
136
|
"aggressive motion of instructions out of loops")
|
138
|
-
#ifdef V8_TARGET_ARCH_X64
|
139
|
-
DEFINE_bool(use_osr, false, "use on-stack replacement")
|
140
|
-
#else
|
141
137
|
DEFINE_bool(use_osr, true, "use on-stack replacement")
|
142
|
-
|
138
|
+
|
143
139
|
DEFINE_bool(trace_osr, false, "trace on-stack replacement")
|
144
140
|
DEFINE_int(stress_runs, 0, "number of stress runs")
|
145
141
|
DEFINE_bool(optimize_closures, true, "optimize closures")
|
@@ -169,6 +165,8 @@ DEFINE_bool(enable_vfp3, true,
|
|
169
165
|
"enable use of VFP3 instructions if available (ARM only)")
|
170
166
|
DEFINE_bool(enable_armv7, true,
|
171
167
|
"enable use of ARMv7 instructions if available (ARM only)")
|
168
|
+
DEFINE_bool(enable_fpu, true,
|
169
|
+
"enable use of MIPS FPU instructions if available (MIPS only)")
|
172
170
|
|
173
171
|
// bootstrapper.cc
|
174
172
|
DEFINE_string(expose_natives_as, NULL, "expose natives in global object")
|
@@ -270,6 +268,12 @@ DEFINE_bool(use_idle_notification, true,
|
|
270
268
|
// ic.cc
|
271
269
|
DEFINE_bool(use_ic, true, "use inline caching")
|
272
270
|
|
271
|
+
#ifdef LIVE_OBJECT_LIST
|
272
|
+
// liveobjectlist.cc
|
273
|
+
DEFINE_string(lol_workdir, NULL, "path for lol temp files")
|
274
|
+
DEFINE_bool(verify_lol, false, "perform debugging verification for lol")
|
275
|
+
#endif
|
276
|
+
|
273
277
|
// macro-assembler-ia32.cc
|
274
278
|
DEFINE_bool(native_code_counters, false,
|
275
279
|
"generate extra code for manipulating stats counters")
|
@@ -358,7 +362,7 @@ DEFINE_bool(remote_debugger, false, "Connect JavaScript debugger to the "
|
|
358
362
|
"debugger agent in another process")
|
359
363
|
DEFINE_bool(debugger_agent, false, "Enable debugger agent")
|
360
364
|
DEFINE_int(debugger_port, 5858, "Port to use for remote debugging")
|
361
|
-
DEFINE_string(map_counters,
|
365
|
+
DEFINE_string(map_counters, "", "Map counters to a file")
|
362
366
|
DEFINE_args(js_arguments, JSArguments(),
|
363
367
|
"Pass all remaining arguments to the script. Alias for \"--\".")
|
364
368
|
|
@@ -449,6 +453,8 @@ DEFINE_bool(collect_heap_spill_statistics, false,
|
|
449
453
|
"report heap spill statistics along with heap_stats "
|
450
454
|
"(requires heap_stats)")
|
451
455
|
|
456
|
+
DEFINE_bool(trace_isolates, false, "trace isolate state changes")
|
457
|
+
|
452
458
|
// VM state
|
453
459
|
DEFINE_bool(log_state_changes, false, "Log state changes.")
|
454
460
|
|
@@ -106,16 +106,9 @@ class FrameElement BASE_EMBEDDED {
|
|
106
106
|
return result;
|
107
107
|
}
|
108
108
|
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
typedef ZoneList<Handle<Object> > ZoneObjectList;
|
113
|
-
|
114
|
-
static ZoneObjectList* ConstantList();
|
115
|
-
|
116
|
-
// Clear the constants indirection table.
|
117
|
-
static void ClearConstantList() {
|
118
|
-
ConstantList()->Clear();
|
109
|
+
static bool ConstantPoolOverflowed() {
|
110
|
+
return !DataField::is_valid(
|
111
|
+
Isolate::Current()->frame_element_constant_list()->length());
|
119
112
|
}
|
120
113
|
|
121
114
|
bool is_synced() const { return SyncedField::decode(value_); }
|
@@ -160,7 +153,8 @@ class FrameElement BASE_EMBEDDED {
|
|
160
153
|
|
161
154
|
Handle<Object> handle() const {
|
162
155
|
ASSERT(is_constant());
|
163
|
-
return
|
156
|
+
return Isolate::Current()->frame_element_constant_list()->
|
157
|
+
at(DataField::decode(value_));
|
164
158
|
}
|
165
159
|
|
166
160
|
int index() const {
|
@@ -228,12 +222,14 @@ class FrameElement BASE_EMBEDDED {
|
|
228
222
|
|
229
223
|
// Used to construct constant elements.
|
230
224
|
FrameElement(Handle<Object> value, SyncFlag is_synced, TypeInfo info) {
|
225
|
+
ZoneObjectList* constant_list =
|
226
|
+
Isolate::Current()->frame_element_constant_list();
|
231
227
|
value_ = TypeField::encode(CONSTANT)
|
232
228
|
| CopiedField::encode(false)
|
233
229
|
| SyncedField::encode(is_synced != NOT_SYNCED)
|
234
230
|
| TypeInfoField::encode(info.ToInt())
|
235
|
-
| DataField::encode(
|
236
|
-
|
231
|
+
| DataField::encode(constant_list->length());
|
232
|
+
constant_list->Add(value);
|
237
233
|
}
|
238
234
|
|
239
235
|
Type type() const { return TypeField::decode(value_); }
|
data/vendor/v8/src/frames-inl.h
CHANGED
@@ -29,6 +29,8 @@
|
|
29
29
|
#define V8_FRAMES_INL_H_
|
30
30
|
|
31
31
|
#include "frames.h"
|
32
|
+
#include "isolate.h"
|
33
|
+
#include "v8memory.h"
|
32
34
|
|
33
35
|
#if V8_TARGET_ARCH_IA32
|
34
36
|
#include "ia32/frames-ia32.h"
|
@@ -91,6 +93,11 @@ inline StackHandler* StackFrame::top_handler() const {
|
|
91
93
|
}
|
92
94
|
|
93
95
|
|
96
|
+
inline Code* StackFrame::GetContainingCode(Isolate* isolate, Address pc) {
|
97
|
+
return isolate->pc_to_code_cache()->GetCacheEntry(pc)->code;
|
98
|
+
}
|
99
|
+
|
100
|
+
|
94
101
|
inline Object* StandardFrame::GetExpression(int index) const {
|
95
102
|
return Memory::Object_at(GetExpressionAddress(index));
|
96
103
|
}
|
data/vendor/v8/src/frames.cc
CHANGED
@@ -35,13 +35,10 @@
|
|
35
35
|
#include "safepoint-table.h"
|
36
36
|
#include "scopeinfo.h"
|
37
37
|
#include "string-stream.h"
|
38
|
-
#include "top.h"
|
39
38
|
|
40
39
|
namespace v8 {
|
41
40
|
namespace internal {
|
42
41
|
|
43
|
-
PcToCodeCache::PcToCodeCacheEntry
|
44
|
-
PcToCodeCache::cache_[PcToCodeCache::kPcToCodeCacheSize];
|
45
42
|
|
46
43
|
int SafeStackFrameIterator::active_count_ = 0;
|
47
44
|
|
@@ -77,7 +74,8 @@ class StackHandlerIterator BASE_EMBEDDED {
|
|
77
74
|
#define INITIALIZE_SINGLETON(type, field) field##_(this),
|
78
75
|
StackFrameIterator::StackFrameIterator()
|
79
76
|
: STACK_FRAME_TYPE_LIST(INITIALIZE_SINGLETON)
|
80
|
-
frame_(NULL), handler_(NULL),
|
77
|
+
frame_(NULL), handler_(NULL),
|
78
|
+
thread_(Isolate::Current()->thread_local_top()),
|
81
79
|
fp_(NULL), sp_(NULL), advance_(&StackFrameIterator::AdvanceWithHandler) {
|
82
80
|
Reset();
|
83
81
|
}
|
@@ -87,10 +85,11 @@ StackFrameIterator::StackFrameIterator(ThreadLocalTop* t)
|
|
87
85
|
fp_(NULL), sp_(NULL), advance_(&StackFrameIterator::AdvanceWithHandler) {
|
88
86
|
Reset();
|
89
87
|
}
|
90
|
-
StackFrameIterator::StackFrameIterator(
|
88
|
+
StackFrameIterator::StackFrameIterator(Isolate* isolate,
|
89
|
+
bool use_top, Address fp, Address sp)
|
91
90
|
: STACK_FRAME_TYPE_LIST(INITIALIZE_SINGLETON)
|
92
91
|
frame_(NULL), handler_(NULL),
|
93
|
-
thread_(use_top ?
|
92
|
+
thread_(use_top ? isolate->thread_local_top() : NULL),
|
94
93
|
fp_(use_top ? NULL : fp), sp_(sp),
|
95
94
|
advance_(use_top ? &StackFrameIterator::AdvanceWithHandler :
|
96
95
|
&StackFrameIterator::AdvanceWithoutHandler) {
|
@@ -138,8 +137,10 @@ void StackFrameIterator::Reset() {
|
|
138
137
|
StackFrame::State state;
|
139
138
|
StackFrame::Type type;
|
140
139
|
if (thread_ != NULL) {
|
141
|
-
type = ExitFrame::GetStateForFramePointer(
|
142
|
-
|
140
|
+
type = ExitFrame::GetStateForFramePointer(
|
141
|
+
Isolate::c_entry_fp(thread_), &state);
|
142
|
+
handler_ = StackHandler::FromAddress(
|
143
|
+
Isolate::handler(thread_));
|
143
144
|
} else {
|
144
145
|
ASSERT(fp_ != NULL);
|
145
146
|
state.fp = fp_;
|
@@ -221,22 +222,25 @@ bool SafeStackFrameIterator::ExitFrameValidator::IsValidFP(Address fp) {
|
|
221
222
|
|
222
223
|
|
223
224
|
SafeStackFrameIterator::SafeStackFrameIterator(
|
225
|
+
Isolate* isolate,
|
224
226
|
Address fp, Address sp, Address low_bound, Address high_bound) :
|
225
227
|
maintainer_(),
|
226
228
|
stack_validator_(low_bound, high_bound),
|
227
|
-
is_valid_top_(IsValidTop(low_bound, high_bound)),
|
229
|
+
is_valid_top_(IsValidTop(isolate, low_bound, high_bound)),
|
228
230
|
is_valid_fp_(IsWithinBounds(low_bound, high_bound, fp)),
|
229
231
|
is_working_iterator_(is_valid_top_ || is_valid_fp_),
|
230
232
|
iteration_done_(!is_working_iterator_),
|
231
|
-
iterator_(is_valid_top_, is_valid_fp_ ? fp : NULL, sp) {
|
233
|
+
iterator_(isolate, is_valid_top_, is_valid_fp_ ? fp : NULL, sp) {
|
232
234
|
}
|
233
235
|
|
234
236
|
|
235
|
-
bool SafeStackFrameIterator::IsValidTop(
|
236
|
-
|
237
|
+
bool SafeStackFrameIterator::IsValidTop(Isolate* isolate,
|
238
|
+
Address low_bound, Address high_bound) {
|
239
|
+
ThreadLocalTop* top = isolate->thread_local_top();
|
240
|
+
Address fp = Isolate::c_entry_fp(top);
|
237
241
|
ExitFrameValidator validator(low_bound, high_bound);
|
238
242
|
if (!validator.IsValidFP(fp)) return false;
|
239
|
-
return
|
243
|
+
return Isolate::handler(top) != NULL;
|
240
244
|
}
|
241
245
|
|
242
246
|
|
@@ -312,8 +316,9 @@ void SafeStackFrameIterator::Reset() {
|
|
312
316
|
|
313
317
|
#ifdef ENABLE_LOGGING_AND_PROFILING
|
314
318
|
SafeStackTraceFrameIterator::SafeStackTraceFrameIterator(
|
319
|
+
Isolate* isolate,
|
315
320
|
Address fp, Address sp, Address low_bound, Address high_bound) :
|
316
|
-
SafeJavaScriptFrameIterator(fp, sp, low_bound, high_bound) {
|
321
|
+
SafeJavaScriptFrameIterator(isolate, fp, sp, low_bound, high_bound) {
|
317
322
|
if (!done() && !frame()->is_java_script()) Advance();
|
318
323
|
}
|
319
324
|
|
@@ -331,7 +336,9 @@ void SafeStackTraceFrameIterator::Advance() {
|
|
331
336
|
Code* StackFrame::GetSafepointData(Address pc,
|
332
337
|
SafepointEntry* safepoint_entry,
|
333
338
|
unsigned* stack_slots) {
|
334
|
-
|
339
|
+
Isolate* isolate = Isolate::Current();
|
340
|
+
PcToCodeCache::PcToCodeCacheEntry* entry =
|
341
|
+
isolate->pc_to_code_cache()->GetCacheEntry(pc);
|
335
342
|
SafepointEntry cached_safepoint_entry = entry->safepoint_entry;
|
336
343
|
if (!entry->safepoint_entry.is_valid()) {
|
337
344
|
entry->safepoint_entry = entry->code->GetSafepointEntry(pc);
|
@@ -386,7 +393,8 @@ StackFrame::Type StackFrame::ComputeType(State* state) {
|
|
386
393
|
// into the heap to determine the state. This is safe as long
|
387
394
|
// as nobody tries to GC...
|
388
395
|
if (SafeStackFrameIterator::is_active()) return JAVA_SCRIPT;
|
389
|
-
Code::Kind kind = GetContainingCode(
|
396
|
+
Code::Kind kind = GetContainingCode(Isolate::Current(),
|
397
|
+
*(state->pc_address))->kind();
|
390
398
|
ASSERT(kind == Code::FUNCTION || kind == Code::OPTIMIZED_FUNCTION);
|
391
399
|
return (kind == Code::OPTIMIZED_FUNCTION) ? OPTIMIZED : JAVA_SCRIPT;
|
392
400
|
}
|
@@ -402,7 +410,7 @@ StackFrame::Type StackFrame::GetCallerState(State* state) const {
|
|
402
410
|
|
403
411
|
|
404
412
|
Code* EntryFrame::unchecked_code() const {
|
405
|
-
return
|
413
|
+
return HEAP->raw_unchecked_js_entry_code();
|
406
414
|
}
|
407
415
|
|
408
416
|
|
@@ -425,7 +433,7 @@ StackFrame::Type EntryFrame::GetCallerState(State* state) const {
|
|
425
433
|
|
426
434
|
|
427
435
|
Code* EntryConstructFrame::unchecked_code() const {
|
428
|
-
return
|
436
|
+
return HEAP->raw_unchecked_js_construct_entry_code();
|
429
437
|
}
|
430
438
|
|
431
439
|
|
@@ -457,7 +465,7 @@ void ExitFrame::SetCallerFp(Address caller_fp) {
|
|
457
465
|
void ExitFrame::Iterate(ObjectVisitor* v) const {
|
458
466
|
// The arguments are traversed as part of the expression stack of
|
459
467
|
// the calling frame.
|
460
|
-
IteratePc(v, pc_address(),
|
468
|
+
IteratePc(v, pc_address(), LookupCode(Isolate::Current()));
|
461
469
|
v->VisitPointer(&code_slot());
|
462
470
|
}
|
463
471
|
|
@@ -609,7 +617,7 @@ Object* JavaScriptFrame::GetParameter(int index) const {
|
|
609
617
|
|
610
618
|
int JavaScriptFrame::ComputeParametersCount() const {
|
611
619
|
Address base = caller_sp() + JavaScriptFrameConstants::kReceiverOffset;
|
612
|
-
Address limit = fp() + JavaScriptFrameConstants::
|
620
|
+
Address limit = fp() + JavaScriptFrameConstants::kLastParameterOffset;
|
613
621
|
return static_cast<int>((base - limit) / kPointerSize);
|
614
622
|
}
|
615
623
|
|
@@ -630,15 +638,10 @@ Code* JavaScriptFrame::unchecked_code() const {
|
|
630
638
|
}
|
631
639
|
|
632
640
|
|
633
|
-
int JavaScriptFrame::GetProvidedParametersCount() const {
|
634
|
-
return ComputeParametersCount();
|
635
|
-
}
|
636
|
-
|
637
|
-
|
638
641
|
Address JavaScriptFrame::GetCallerStackPointer() const {
|
639
642
|
int arguments;
|
640
|
-
if (
|
641
|
-
|
643
|
+
if (SafeStackFrameIterator::is_active() ||
|
644
|
+
HEAP->gc_state() != Heap::NOT_IN_GC) {
|
642
645
|
// If the we are currently iterating the safe stack the
|
643
646
|
// arguments for frames are traversed as if they were
|
644
647
|
// expression stack elements of the calling frame. The reason for
|
@@ -667,7 +670,7 @@ void JavaScriptFrame::GetFunctions(List<JSFunction*>* functions) {
|
|
667
670
|
|
668
671
|
void JavaScriptFrame::Summarize(List<FrameSummary>* functions) {
|
669
672
|
ASSERT(functions->length() == 0);
|
670
|
-
Code* code_pointer =
|
673
|
+
Code* code_pointer = LookupCode(Isolate::Current());
|
671
674
|
int offset = static_cast<int>(pc() - code_pointer->address());
|
672
675
|
FrameSummary summary(receiver(),
|
673
676
|
JSFunction::cast(function()),
|
@@ -786,7 +789,7 @@ DeoptimizationInputData* OptimizedFrame::GetDeoptimizationData(
|
|
786
789
|
// back to a slow search in this case to find the original optimized
|
787
790
|
// code object.
|
788
791
|
if (!code->contains(pc())) {
|
789
|
-
code =
|
792
|
+
code = Isolate::Current()->pc_to_code_cache()->GcSafeFindCodeForPc(pc());
|
790
793
|
}
|
791
794
|
ASSERT(code != NULL);
|
792
795
|
ASSERT(code->kind() == Code::OPTIMIZED_FUNCTION);
|
@@ -847,7 +850,8 @@ Address InternalFrame::GetCallerStackPointer() const {
|
|
847
850
|
|
848
851
|
|
849
852
|
Code* ArgumentsAdaptorFrame::unchecked_code() const {
|
850
|
-
return
|
853
|
+
return Isolate::Current()->builtins()->builtin(
|
854
|
+
Builtins::kArgumentsAdaptorTrampoline);
|
851
855
|
}
|
852
856
|
|
853
857
|
|
@@ -1041,14 +1045,14 @@ void EntryFrame::Iterate(ObjectVisitor* v) const {
|
|
1041
1045
|
ASSERT(!it.done());
|
1042
1046
|
StackHandler* handler = it.handler();
|
1043
1047
|
ASSERT(handler->is_entry());
|
1044
|
-
handler->Iterate(v,
|
1048
|
+
handler->Iterate(v, LookupCode(Isolate::Current()));
|
1045
1049
|
#ifdef DEBUG
|
1046
1050
|
// Make sure that the entry frame does not contain more than one
|
1047
1051
|
// stack handler.
|
1048
1052
|
it.Advance();
|
1049
1053
|
ASSERT(it.done());
|
1050
1054
|
#endif
|
1051
|
-
IteratePc(v, pc_address(),
|
1055
|
+
IteratePc(v, pc_address(), LookupCode(Isolate::Current()));
|
1052
1056
|
}
|
1053
1057
|
|
1054
1058
|
|
@@ -1065,7 +1069,7 @@ void StandardFrame::IterateExpressions(ObjectVisitor* v) const {
|
|
1065
1069
|
v->VisitPointers(base, reinterpret_cast<Object**>(address));
|
1066
1070
|
base = reinterpret_cast<Object**>(address + StackHandlerConstants::kSize);
|
1067
1071
|
// Traverse the pointers in the handler itself.
|
1068
|
-
handler->Iterate(v,
|
1072
|
+
handler->Iterate(v, LookupCode(Isolate::Current()));
|
1069
1073
|
}
|
1070
1074
|
v->VisitPointers(base, limit);
|
1071
1075
|
}
|
@@ -1073,14 +1077,14 @@ void StandardFrame::IterateExpressions(ObjectVisitor* v) const {
|
|
1073
1077
|
|
1074
1078
|
void JavaScriptFrame::Iterate(ObjectVisitor* v) const {
|
1075
1079
|
IterateExpressions(v);
|
1076
|
-
IteratePc(v, pc_address(),
|
1080
|
+
IteratePc(v, pc_address(), LookupCode(Isolate::Current()));
|
1077
1081
|
IterateArguments(v);
|
1078
1082
|
}
|
1079
1083
|
|
1080
1084
|
|
1081
1085
|
void JavaScriptFrame::IterateArguments(ObjectVisitor* v) const {
|
1082
1086
|
// Traverse callee-saved registers, receiver, and parameters.
|
1083
|
-
const int kBaseOffset = JavaScriptFrameConstants::
|
1087
|
+
const int kBaseOffset = JavaScriptFrameConstants::kLastParameterOffset;
|
1084
1088
|
const int kLimitOffset = JavaScriptFrameConstants::kReceiverOffset;
|
1085
1089
|
Object** base = &Memory::Object_at(fp() + kBaseOffset);
|
1086
1090
|
Object** limit = &Memory::Object_at(caller_sp() + kLimitOffset) + 1;
|
@@ -1092,7 +1096,7 @@ void InternalFrame::Iterate(ObjectVisitor* v) const {
|
|
1092
1096
|
// Internal frames only have object pointers on the expression stack
|
1093
1097
|
// as they never have any arguments.
|
1094
1098
|
IterateExpressions(v);
|
1095
|
-
IteratePc(v, pc_address(),
|
1099
|
+
IteratePc(v, pc_address(), LookupCode(Isolate::Current()));
|
1096
1100
|
}
|
1097
1101
|
|
1098
1102
|
|
@@ -1122,14 +1126,15 @@ Code* PcToCodeCache::GcSafeCastToCode(HeapObject* object, Address pc) {
|
|
1122
1126
|
|
1123
1127
|
|
1124
1128
|
Code* PcToCodeCache::GcSafeFindCodeForPc(Address pc) {
|
1129
|
+
Heap* heap = isolate_->heap();
|
1125
1130
|
// Check if the pc points into a large object chunk.
|
1126
|
-
LargeObjectChunk* chunk =
|
1131
|
+
LargeObjectChunk* chunk = heap->lo_space()->FindChunkContainingPc(pc);
|
1127
1132
|
if (chunk != NULL) return GcSafeCastToCode(chunk->GetObject(), pc);
|
1128
1133
|
|
1129
1134
|
// Iterate through the 8K page until we reach the end or find an
|
1130
1135
|
// object starting after the pc.
|
1131
1136
|
Page* page = Page::FromAddress(pc);
|
1132
|
-
HeapObjectIterator iterator(page,
|
1137
|
+
HeapObjectIterator iterator(page, heap->GcSafeSizeOfOldObjectFunction());
|
1133
1138
|
HeapObject* previous = NULL;
|
1134
1139
|
while (true) {
|
1135
1140
|
HeapObject* next = iterator.next();
|
@@ -1142,14 +1147,14 @@ Code* PcToCodeCache::GcSafeFindCodeForPc(Address pc) {
|
|
1142
1147
|
|
1143
1148
|
|
1144
1149
|
PcToCodeCache::PcToCodeCacheEntry* PcToCodeCache::GetCacheEntry(Address pc) {
|
1145
|
-
|
1150
|
+
isolate_->counters()->pc_to_code()->Increment();
|
1146
1151
|
ASSERT(IsPowerOf2(kPcToCodeCacheSize));
|
1147
1152
|
uint32_t hash = ComputeIntegerHash(
|
1148
1153
|
static_cast<uint32_t>(reinterpret_cast<uintptr_t>(pc)));
|
1149
1154
|
uint32_t index = hash & (kPcToCodeCacheSize - 1);
|
1150
1155
|
PcToCodeCacheEntry* entry = cache(index);
|
1151
1156
|
if (entry->pc == pc) {
|
1152
|
-
|
1157
|
+
isolate_->counters()->pc_to_code_cached()->Increment();
|
1153
1158
|
ASSERT(entry->code == GcSafeFindCodeForPc(pc));
|
1154
1159
|
} else {
|
1155
1160
|
// Because this code may be interrupted by a profiling signal that
|
@@ -1176,11 +1181,8 @@ int NumRegs(RegList reglist) {
|
|
1176
1181
|
}
|
1177
1182
|
|
1178
1183
|
|
1179
|
-
|
1180
|
-
|
1181
|
-
static bool initialized = false;
|
1182
|
-
if (!initialized) {
|
1183
|
-
initialized = true;
|
1184
|
+
struct JSCallerSavedCodeData {
|
1185
|
+
JSCallerSavedCodeData() {
|
1184
1186
|
int i = 0;
|
1185
1187
|
for (int r = 0; r < kNumRegs; r++)
|
1186
1188
|
if ((kJSCallerSaved & (1 << r)) != 0)
|
@@ -1188,8 +1190,16 @@ int JSCallerSavedCode(int n) {
|
|
1188
1190
|
|
1189
1191
|
ASSERT(i == kNumJSCallerSaved);
|
1190
1192
|
}
|
1193
|
+
int reg_code[kNumJSCallerSaved];
|
1194
|
+
};
|
1195
|
+
|
1196
|
+
|
1197
|
+
static const JSCallerSavedCodeData kCallerSavedCodeData;
|
1198
|
+
|
1199
|
+
|
1200
|
+
int JSCallerSavedCode(int n) {
|
1191
1201
|
ASSERT(0 <= n && n < kNumJSCallerSaved);
|
1192
|
-
return reg_code[n];
|
1202
|
+
return kCallerSavedCodeData.reg_code[n];
|
1193
1203
|
}
|
1194
1204
|
|
1195
1205
|
|