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
data/vendor/v8/src/arm/ic-arm.cc
CHANGED
@@ -552,7 +552,8 @@ static void GenerateMonomorphicCacheProbe(MacroAssembler* masm,
|
|
552
552
|
Code::kNoExtraICState,
|
553
553
|
NORMAL,
|
554
554
|
argc);
|
555
|
-
|
555
|
+
Isolate::Current()->stub_cache()->GenerateProbe(
|
556
|
+
masm, flags, r1, r2, r3, r4, r5);
|
556
557
|
|
557
558
|
// If the stub cache probing failed, the receiver might be a value.
|
558
559
|
// For value objects, we use the map of the prototype objects for
|
@@ -591,7 +592,8 @@ static void GenerateMonomorphicCacheProbe(MacroAssembler* masm,
|
|
591
592
|
|
592
593
|
// Probe the stub cache for the value object.
|
593
594
|
__ bind(&probe);
|
594
|
-
|
595
|
+
Isolate::Current()->stub_cache()->GenerateProbe(
|
596
|
+
masm, flags, r1, r2, r3, r4, r5);
|
595
597
|
|
596
598
|
__ bind(&miss);
|
597
599
|
}
|
@@ -644,11 +646,12 @@ static void GenerateCallMiss(MacroAssembler* masm, int argc, IC::UtilityId id) {
|
|
644
646
|
// -- r2 : name
|
645
647
|
// -- lr : return address
|
646
648
|
// -----------------------------------
|
649
|
+
Isolate* isolate = masm->isolate();
|
647
650
|
|
648
651
|
if (id == IC::kCallIC_Miss) {
|
649
|
-
__ IncrementCounter(
|
652
|
+
__ IncrementCounter(isolate->counters()->call_miss(), 1, r3, r4);
|
650
653
|
} else {
|
651
|
-
__ IncrementCounter(
|
654
|
+
__ IncrementCounter(isolate->counters()->keyed_call_miss(), 1, r3, r4);
|
652
655
|
}
|
653
656
|
|
654
657
|
// Get the receiver of the function from the stack.
|
@@ -661,7 +664,7 @@ static void GenerateCallMiss(MacroAssembler* masm, int argc, IC::UtilityId id) {
|
|
661
664
|
|
662
665
|
// Call the entry.
|
663
666
|
__ mov(r0, Operand(2));
|
664
|
-
__ mov(r1, Operand(ExternalReference(IC_Utility(id))));
|
667
|
+
__ mov(r1, Operand(ExternalReference(IC_Utility(id), isolate)));
|
665
668
|
|
666
669
|
CEntryStub stub(1);
|
667
670
|
__ CallStub(&stub);
|
@@ -763,7 +766,8 @@ void KeyedCallIC::GenerateMegamorphic(MacroAssembler* masm, int argc) {
|
|
763
766
|
|
764
767
|
GenerateFastArrayLoad(
|
765
768
|
masm, r1, r2, r4, r3, r0, r1, &check_number_dictionary, &slow_load);
|
766
|
-
|
769
|
+
Counters* counters = masm->isolate()->counters();
|
770
|
+
__ IncrementCounter(counters->keyed_call_generic_smi_fast(), 1, r0, r3);
|
767
771
|
|
768
772
|
__ bind(&do_call);
|
769
773
|
// receiver in r1 is not used after this point.
|
@@ -782,13 +786,13 @@ void KeyedCallIC::GenerateMegamorphic(MacroAssembler* masm, int argc) {
|
|
782
786
|
__ mov(r0, Operand(r2, ASR, kSmiTagSize));
|
783
787
|
// r0: untagged index
|
784
788
|
GenerateNumberDictionaryLoad(masm, &slow_load, r4, r2, r1, r0, r3, r5);
|
785
|
-
__ IncrementCounter(
|
789
|
+
__ IncrementCounter(counters->keyed_call_generic_smi_dict(), 1, r0, r3);
|
786
790
|
__ jmp(&do_call);
|
787
791
|
|
788
792
|
__ bind(&slow_load);
|
789
793
|
// This branch is taken when calling KeyedCallIC_Miss is neither required
|
790
794
|
// nor beneficial.
|
791
|
-
__ IncrementCounter(
|
795
|
+
__ IncrementCounter(counters->keyed_call_generic_slow_load(), 1, r0, r3);
|
792
796
|
__ EnterInternalFrame();
|
793
797
|
__ push(r2); // save the key
|
794
798
|
__ Push(r1, r2); // pass the receiver and the key
|
@@ -815,11 +819,11 @@ void KeyedCallIC::GenerateMegamorphic(MacroAssembler* masm, int argc) {
|
|
815
819
|
__ b(ne, &lookup_monomorphic_cache);
|
816
820
|
|
817
821
|
GenerateDictionaryLoad(masm, &slow_load, r0, r2, r1, r3, r4);
|
818
|
-
__ IncrementCounter(
|
822
|
+
__ IncrementCounter(counters->keyed_call_generic_lookup_dict(), 1, r0, r3);
|
819
823
|
__ jmp(&do_call);
|
820
824
|
|
821
825
|
__ bind(&lookup_monomorphic_cache);
|
822
|
-
__ IncrementCounter(
|
826
|
+
__ IncrementCounter(counters->keyed_call_generic_lookup_cache(), 1, r0, r3);
|
823
827
|
GenerateMonomorphicCacheProbe(masm, argc, Code::KEYED_CALL_IC);
|
824
828
|
// Fall through on miss.
|
825
829
|
|
@@ -830,7 +834,7 @@ void KeyedCallIC::GenerateMegamorphic(MacroAssembler* masm, int argc) {
|
|
830
834
|
// - the value loaded is not a function,
|
831
835
|
// - there is hope that the runtime will create a monomorphic call stub
|
832
836
|
// that will get fetched next time.
|
833
|
-
__ IncrementCounter(
|
837
|
+
__ IncrementCounter(counters->keyed_call_generic_slow(), 1, r0, r3);
|
834
838
|
GenerateMiss(masm, argc);
|
835
839
|
|
836
840
|
__ bind(&index_string);
|
@@ -873,7 +877,8 @@ void LoadIC::GenerateMegamorphic(MacroAssembler* masm) {
|
|
873
877
|
Code::Flags flags = Code::ComputeFlags(Code::LOAD_IC,
|
874
878
|
NOT_IN_LOOP,
|
875
879
|
MONOMORPHIC);
|
876
|
-
|
880
|
+
Isolate::Current()->stub_cache()->GenerateProbe(
|
881
|
+
masm, flags, r0, r2, r3, r4, r5);
|
877
882
|
|
878
883
|
// Cache miss: Jump to runtime.
|
879
884
|
GenerateMiss(masm);
|
@@ -908,14 +913,16 @@ void LoadIC::GenerateMiss(MacroAssembler* masm) {
|
|
908
913
|
// -- r0 : receiver
|
909
914
|
// -- sp[0] : receiver
|
910
915
|
// -----------------------------------
|
916
|
+
Isolate* isolate = masm->isolate();
|
911
917
|
|
912
|
-
__ IncrementCounter(
|
918
|
+
__ IncrementCounter(isolate->counters()->load_miss(), 1, r3, r4);
|
913
919
|
|
914
920
|
__ mov(r3, r0);
|
915
921
|
__ Push(r3, r2);
|
916
922
|
|
917
923
|
// Perform tail call to the entry.
|
918
|
-
ExternalReference ref =
|
924
|
+
ExternalReference ref =
|
925
|
+
ExternalReference(IC_Utility(kLoadIC_Miss), isolate);
|
919
926
|
__ TailCallExternalReference(ref, 2, 1);
|
920
927
|
}
|
921
928
|
|
@@ -961,7 +968,7 @@ bool LoadIC::PatchInlinedLoad(Address address, Object* map, int offset) {
|
|
961
968
|
|
962
969
|
// Find the end of the inlined code for handling the load if this is an
|
963
970
|
// inlined IC call site.
|
964
|
-
Address inline_end_address;
|
971
|
+
Address inline_end_address = 0;
|
965
972
|
if (InlinedICSiteMarker(address, &inline_end_address)
|
966
973
|
!= Assembler::PROPERTY_ACCESS_INLINED) {
|
967
974
|
return false;
|
@@ -1001,7 +1008,7 @@ bool LoadIC::PatchInlinedContextualLoad(Address address,
|
|
1001
1008
|
bool is_dont_delete) {
|
1002
1009
|
// Find the end of the inlined code for handling the contextual load if
|
1003
1010
|
// this is inlined IC call site.
|
1004
|
-
Address inline_end_address;
|
1011
|
+
Address inline_end_address = 0;
|
1005
1012
|
int marker = InlinedICSiteMarker(address, &inline_end_address);
|
1006
1013
|
if (!((marker == Assembler::PROPERTY_ACCESS_INLINED_CONTEXT) ||
|
1007
1014
|
(marker == Assembler::PROPERTY_ACCESS_INLINED_CONTEXT_DONT_DELETE))) {
|
@@ -1042,7 +1049,7 @@ bool StoreIC::PatchInlinedStore(Address address, Object* map, int offset) {
|
|
1042
1049
|
|
1043
1050
|
// Find the end of the inlined code for the store if there is an
|
1044
1051
|
// inlined version of the store.
|
1045
|
-
Address inline_end_address;
|
1052
|
+
Address inline_end_address = 0;
|
1046
1053
|
if (InlinedICSiteMarker(address, &inline_end_address)
|
1047
1054
|
!= Assembler::PROPERTY_ACCESS_INLINED) {
|
1048
1055
|
return false;
|
@@ -1057,7 +1064,7 @@ bool StoreIC::PatchInlinedStore(Address address, Object* map, int offset) {
|
|
1057
1064
|
// Update the offsets if initializing the inlined store. No reason
|
1058
1065
|
// to update the offsets when clearing the inlined version because
|
1059
1066
|
// it will bail out in the map check.
|
1060
|
-
if (map !=
|
1067
|
+
if (map != HEAP->null_value()) {
|
1061
1068
|
// Patch the offset in the actual store instruction.
|
1062
1069
|
Address str_property_instr_address =
|
1063
1070
|
ldr_map_instr_address + 3 * Assembler::kInstrSize;
|
@@ -1092,7 +1099,7 @@ bool StoreIC::PatchInlinedStore(Address address, Object* map, int offset) {
|
|
1092
1099
|
bool KeyedLoadIC::PatchInlinedLoad(Address address, Object* map) {
|
1093
1100
|
if (V8::UseCrankshaft()) return false;
|
1094
1101
|
|
1095
|
-
Address inline_end_address;
|
1102
|
+
Address inline_end_address = 0;
|
1096
1103
|
if (InlinedICSiteMarker(address, &inline_end_address)
|
1097
1104
|
!= Assembler::PROPERTY_ACCESS_INLINED) {
|
1098
1105
|
return false;
|
@@ -1114,7 +1121,7 @@ bool KeyedStoreIC::PatchInlinedStore(Address address, Object* map) {
|
|
1114
1121
|
|
1115
1122
|
// Find the end of the inlined code for handling the store if this is an
|
1116
1123
|
// inlined IC call site.
|
1117
|
-
Address inline_end_address;
|
1124
|
+
Address inline_end_address = 0;
|
1118
1125
|
if (InlinedICSiteMarker(address, &inline_end_address)
|
1119
1126
|
!= Assembler::PROPERTY_ACCESS_INLINED) {
|
1120
1127
|
return false;
|
@@ -1140,12 +1147,14 @@ void KeyedLoadIC::GenerateMiss(MacroAssembler* masm) {
|
|
1140
1147
|
// -- r0 : key
|
1141
1148
|
// -- r1 : receiver
|
1142
1149
|
// -----------------------------------
|
1150
|
+
Isolate* isolate = masm->isolate();
|
1143
1151
|
|
1144
|
-
__ IncrementCounter(
|
1152
|
+
__ IncrementCounter(isolate->counters()->keyed_load_miss(), 1, r3, r4);
|
1145
1153
|
|
1146
1154
|
__ Push(r1, r0);
|
1147
1155
|
|
1148
|
-
ExternalReference ref =
|
1156
|
+
ExternalReference ref =
|
1157
|
+
ExternalReference(IC_Utility(kKeyedLoadIC_Miss), isolate);
|
1149
1158
|
__ TailCallExternalReference(ref, 2, 1);
|
1150
1159
|
}
|
1151
1160
|
|
@@ -1170,11 +1179,13 @@ void KeyedLoadIC::GenerateGeneric(MacroAssembler* masm) {
|
|
1170
1179
|
// -- r1 : receiver
|
1171
1180
|
// -----------------------------------
|
1172
1181
|
Label slow, check_string, index_smi, index_string, property_array_property;
|
1173
|
-
Label
|
1182
|
+
Label probe_dictionary, check_number_dictionary;
|
1174
1183
|
|
1175
1184
|
Register key = r0;
|
1176
1185
|
Register receiver = r1;
|
1177
1186
|
|
1187
|
+
Isolate* isolate = masm->isolate();
|
1188
|
+
|
1178
1189
|
// Check that the key is a smi.
|
1179
1190
|
__ JumpIfNotSmi(key, &check_string);
|
1180
1191
|
__ bind(&index_smi);
|
@@ -1188,31 +1199,17 @@ void KeyedLoadIC::GenerateGeneric(MacroAssembler* masm) {
|
|
1188
1199
|
// now in r2.
|
1189
1200
|
__ ldrb(r3, FieldMemOperand(r2, Map::kBitField2Offset));
|
1190
1201
|
__ tst(r3, Operand(1 << Map::kHasFastElements));
|
1191
|
-
__ b(eq, &
|
1202
|
+
__ b(eq, &check_number_dictionary);
|
1192
1203
|
|
1193
1204
|
GenerateFastArrayLoad(
|
1194
1205
|
masm, receiver, key, r4, r3, r2, r0, NULL, &slow);
|
1195
|
-
__ IncrementCounter(
|
1206
|
+
__ IncrementCounter(isolate->counters()->keyed_load_generic_smi(), 1, r2, r3);
|
1196
1207
|
__ Ret();
|
1197
1208
|
|
1198
|
-
// Check whether the elements is a pixel array.
|
1199
|
-
// r0: key
|
1200
|
-
// r1: receiver
|
1201
|
-
__ bind(&check_pixel_array);
|
1202
|
-
|
1203
|
-
GenerateFastPixelArrayLoad(masm,
|
1204
|
-
r1,
|
1205
|
-
r0,
|
1206
|
-
r3,
|
1207
|
-
r4,
|
1208
|
-
r2,
|
1209
|
-
r5,
|
1210
|
-
r0,
|
1211
|
-
&check_number_dictionary,
|
1212
|
-
NULL,
|
1213
|
-
&slow);
|
1214
|
-
|
1215
1209
|
__ bind(&check_number_dictionary);
|
1210
|
+
__ ldr(r4, FieldMemOperand(receiver, JSObject::kElementsOffset));
|
1211
|
+
__ ldr(r3, FieldMemOperand(r4, JSObject::kMapOffset));
|
1212
|
+
|
1216
1213
|
// Check whether the elements is a number dictionary.
|
1217
1214
|
// r0: key
|
1218
1215
|
// r3: elements map
|
@@ -1226,7 +1223,8 @@ void KeyedLoadIC::GenerateGeneric(MacroAssembler* masm) {
|
|
1226
1223
|
|
1227
1224
|
// Slow case, key and receiver still in r0 and r1.
|
1228
1225
|
__ bind(&slow);
|
1229
|
-
__ IncrementCounter(
|
1226
|
+
__ IncrementCounter(isolate->counters()->keyed_load_generic_slow(),
|
1227
|
+
1, r2, r3);
|
1230
1228
|
GenerateRuntimeGetProperty(masm);
|
1231
1229
|
|
1232
1230
|
__ bind(&check_string);
|
@@ -1253,7 +1251,8 @@ void KeyedLoadIC::GenerateGeneric(MacroAssembler* masm) {
|
|
1253
1251
|
|
1254
1252
|
// Load the key (consisting of map and symbol) from the cache and
|
1255
1253
|
// check for match.
|
1256
|
-
ExternalReference cache_keys =
|
1254
|
+
ExternalReference cache_keys =
|
1255
|
+
ExternalReference::keyed_lookup_cache_keys(isolate);
|
1257
1256
|
__ mov(r4, Operand(cache_keys));
|
1258
1257
|
__ add(r4, r4, Operand(r3, LSL, kPointerSizeLog2 + 1));
|
1259
1258
|
__ ldr(r5, MemOperand(r4, kPointerSize, PostIndex)); // Move r4 to symbol.
|
@@ -1268,8 +1267,8 @@ void KeyedLoadIC::GenerateGeneric(MacroAssembler* masm) {
|
|
1268
1267
|
// r1 : receiver
|
1269
1268
|
// r2 : receiver's map
|
1270
1269
|
// r3 : lookup cache index
|
1271
|
-
ExternalReference cache_field_offsets
|
1272
|
-
|
1270
|
+
ExternalReference cache_field_offsets =
|
1271
|
+
ExternalReference::keyed_lookup_cache_field_offsets(isolate);
|
1273
1272
|
__ mov(r4, Operand(cache_field_offsets));
|
1274
1273
|
__ ldr(r5, MemOperand(r4, r3, LSL, kPointerSizeLog2));
|
1275
1274
|
__ ldrb(r6, FieldMemOperand(r2, Map::kInObjectPropertiesOffset));
|
@@ -1281,7 +1280,8 @@ void KeyedLoadIC::GenerateGeneric(MacroAssembler* masm) {
|
|
1281
1280
|
__ add(r6, r6, r5); // Index from start of object.
|
1282
1281
|
__ sub(r1, r1, Operand(kHeapObjectTag)); // Remove the heap tag.
|
1283
1282
|
__ ldr(r0, MemOperand(r1, r6, LSL, kPointerSizeLog2));
|
1284
|
-
__ IncrementCounter(
|
1283
|
+
__ IncrementCounter(isolate->counters()->keyed_load_generic_lookup_cache(),
|
1284
|
+
1, r2, r3);
|
1285
1285
|
__ Ret();
|
1286
1286
|
|
1287
1287
|
// Load property array property.
|
@@ -1289,7 +1289,8 @@ void KeyedLoadIC::GenerateGeneric(MacroAssembler* masm) {
|
|
1289
1289
|
__ ldr(r1, FieldMemOperand(r1, JSObject::kPropertiesOffset));
|
1290
1290
|
__ add(r1, r1, Operand(FixedArray::kHeaderSize - kHeapObjectTag));
|
1291
1291
|
__ ldr(r0, MemOperand(r1, r5, LSL, kPointerSizeLog2));
|
1292
|
-
__ IncrementCounter(
|
1292
|
+
__ IncrementCounter(isolate->counters()->keyed_load_generic_lookup_cache(),
|
1293
|
+
1, r2, r3);
|
1293
1294
|
__ Ret();
|
1294
1295
|
|
1295
1296
|
// Do a quick inline probe of the receiver's dictionary, if it
|
@@ -1303,7 +1304,8 @@ void KeyedLoadIC::GenerateGeneric(MacroAssembler* masm) {
|
|
1303
1304
|
GenerateGlobalInstanceTypeCheck(masm, r2, &slow);
|
1304
1305
|
// Load the property to r0.
|
1305
1306
|
GenerateDictionaryLoad(masm, &slow, r3, r0, r0, r2, r4);
|
1306
|
-
__ IncrementCounter(
|
1307
|
+
__ IncrementCounter(isolate->counters()->keyed_load_generic_symbol(),
|
1308
|
+
1, r2, r3);
|
1307
1309
|
__ Ret();
|
1308
1310
|
|
1309
1311
|
__ bind(&index_string);
|
@@ -1376,8 +1378,11 @@ void KeyedLoadIC::GenerateIndexedInterceptor(MacroAssembler* masm) {
|
|
1376
1378
|
__ Push(r1, r0); // Receiver, key.
|
1377
1379
|
|
1378
1380
|
// Perform tail call to the entry.
|
1379
|
-
__ TailCallExternalReference(
|
1380
|
-
|
1381
|
+
__ TailCallExternalReference(
|
1382
|
+
ExternalReference(IC_Utility(kKeyedLoadPropertyWithInterceptor),
|
1383
|
+
masm->isolate()),
|
1384
|
+
2,
|
1385
|
+
1);
|
1381
1386
|
|
1382
1387
|
__ bind(&slow);
|
1383
1388
|
GenerateMiss(masm);
|
@@ -1395,12 +1400,14 @@ void KeyedStoreIC::GenerateMiss(MacroAssembler* masm) {
|
|
1395
1400
|
// Push receiver, key and value for runtime call.
|
1396
1401
|
__ Push(r2, r1, r0);
|
1397
1402
|
|
1398
|
-
ExternalReference ref =
|
1403
|
+
ExternalReference ref =
|
1404
|
+
ExternalReference(IC_Utility(kKeyedStoreIC_Miss), masm->isolate());
|
1399
1405
|
__ TailCallExternalReference(ref, 3, 1);
|
1400
1406
|
}
|
1401
1407
|
|
1402
1408
|
|
1403
|
-
void KeyedStoreIC::GenerateRuntimeSetProperty(MacroAssembler* masm
|
1409
|
+
void KeyedStoreIC::GenerateRuntimeSetProperty(MacroAssembler* masm,
|
1410
|
+
StrictModeFlag strict_mode) {
|
1404
1411
|
// ---------- S t a t e --------------
|
1405
1412
|
// -- r0 : value
|
1406
1413
|
// -- r1 : key
|
@@ -1411,18 +1418,23 @@ void KeyedStoreIC::GenerateRuntimeSetProperty(MacroAssembler* masm) {
|
|
1411
1418
|
// Push receiver, key and value for runtime call.
|
1412
1419
|
__ Push(r2, r1, r0);
|
1413
1420
|
|
1414
|
-
__
|
1421
|
+
__ mov(r1, Operand(Smi::FromInt(NONE))); // PropertyAttributes
|
1422
|
+
__ mov(r0, Operand(Smi::FromInt(strict_mode))); // Strict mode.
|
1423
|
+
__ Push(r1, r0);
|
1424
|
+
|
1425
|
+
__ TailCallRuntime(Runtime::kSetProperty, 5, 1);
|
1415
1426
|
}
|
1416
1427
|
|
1417
1428
|
|
1418
|
-
void KeyedStoreIC::GenerateGeneric(MacroAssembler* masm
|
1429
|
+
void KeyedStoreIC::GenerateGeneric(MacroAssembler* masm,
|
1430
|
+
StrictModeFlag strict_mode) {
|
1419
1431
|
// ---------- S t a t e --------------
|
1420
1432
|
// -- r0 : value
|
1421
1433
|
// -- r1 : key
|
1422
1434
|
// -- r2 : receiver
|
1423
1435
|
// -- lr : return address
|
1424
1436
|
// -----------------------------------
|
1425
|
-
Label slow, fast, array, extra
|
1437
|
+
Label slow, fast, array, extra;
|
1426
1438
|
|
1427
1439
|
// Register usage.
|
1428
1440
|
Register value = r0;
|
@@ -1458,7 +1470,7 @@ void KeyedStoreIC::GenerateGeneric(MacroAssembler* masm) {
|
|
1458
1470
|
__ ldr(r4, FieldMemOperand(elements, HeapObject::kMapOffset));
|
1459
1471
|
__ LoadRoot(ip, Heap::kFixedArrayMapRootIndex);
|
1460
1472
|
__ cmp(r4, ip);
|
1461
|
-
__ b(ne, &
|
1473
|
+
__ b(ne, &slow);
|
1462
1474
|
// Check array bounds. Both the key and the length of FixedArray are smis.
|
1463
1475
|
__ ldr(ip, FieldMemOperand(elements, FixedArray::kLengthOffset));
|
1464
1476
|
__ cmp(key, Operand(ip));
|
@@ -1470,25 +1482,7 @@ void KeyedStoreIC::GenerateGeneric(MacroAssembler* masm) {
|
|
1470
1482
|
// r0: value.
|
1471
1483
|
// r1: key.
|
1472
1484
|
// r2: receiver.
|
1473
|
-
GenerateRuntimeSetProperty(masm);
|
1474
|
-
|
1475
|
-
// Check whether the elements is a pixel array.
|
1476
|
-
// r4: elements map.
|
1477
|
-
__ bind(&check_pixel_array);
|
1478
|
-
GenerateFastPixelArrayStore(masm,
|
1479
|
-
r2,
|
1480
|
-
r1,
|
1481
|
-
r0,
|
1482
|
-
elements,
|
1483
|
-
r4,
|
1484
|
-
r5,
|
1485
|
-
r6,
|
1486
|
-
false,
|
1487
|
-
false,
|
1488
|
-
NULL,
|
1489
|
-
&slow,
|
1490
|
-
&slow,
|
1491
|
-
&slow);
|
1485
|
+
GenerateRuntimeSetProperty(masm, strict_mode);
|
1492
1486
|
|
1493
1487
|
// Extra capacity case: Check if there is extra capacity to
|
1494
1488
|
// perform the store and update the length. Used for adding one
|
@@ -1540,7 +1534,7 @@ void KeyedStoreIC::GenerateGeneric(MacroAssembler* masm) {
|
|
1540
1534
|
|
1541
1535
|
|
1542
1536
|
void StoreIC::GenerateMegamorphic(MacroAssembler* masm,
|
1543
|
-
|
1537
|
+
StrictModeFlag strict_mode) {
|
1544
1538
|
// ----------- S t a t e -------------
|
1545
1539
|
// -- r0 : value
|
1546
1540
|
// -- r1 : receiver
|
@@ -1552,8 +1546,10 @@ void StoreIC::GenerateMegamorphic(MacroAssembler* masm,
|
|
1552
1546
|
Code::Flags flags = Code::ComputeFlags(Code::STORE_IC,
|
1553
1547
|
NOT_IN_LOOP,
|
1554
1548
|
MONOMORPHIC,
|
1555
|
-
|
1556
|
-
|
1549
|
+
strict_mode);
|
1550
|
+
|
1551
|
+
Isolate::Current()->stub_cache()->GenerateProbe(
|
1552
|
+
masm, flags, r1, r2, r3, r4, r5);
|
1557
1553
|
|
1558
1554
|
// Cache miss: Jump to runtime.
|
1559
1555
|
GenerateMiss(masm);
|
@@ -1571,7 +1567,8 @@ void StoreIC::GenerateMiss(MacroAssembler* masm) {
|
|
1571
1567
|
__ Push(r1, r2, r0);
|
1572
1568
|
|
1573
1569
|
// Perform tail call to the entry.
|
1574
|
-
ExternalReference ref =
|
1570
|
+
ExternalReference ref =
|
1571
|
+
ExternalReference(IC_Utility(kStoreIC_Miss), masm->isolate());
|
1575
1572
|
__ TailCallExternalReference(ref, 3, 1);
|
1576
1573
|
}
|
1577
1574
|
|
@@ -1616,7 +1613,8 @@ void StoreIC::GenerateArrayLength(MacroAssembler* masm) {
|
|
1616
1613
|
// Prepare tail call to StoreIC_ArrayLength.
|
1617
1614
|
__ Push(receiver, value);
|
1618
1615
|
|
1619
|
-
ExternalReference ref =
|
1616
|
+
ExternalReference ref =
|
1617
|
+
ExternalReference(IC_Utility(kStoreIC_ArrayLength), masm->isolate());
|
1620
1618
|
__ TailCallExternalReference(ref, 2, 1);
|
1621
1619
|
|
1622
1620
|
__ bind(&miss);
|
@@ -1637,16 +1635,19 @@ void StoreIC::GenerateNormal(MacroAssembler* masm) {
|
|
1637
1635
|
GenerateStringDictionaryReceiverCheck(masm, r1, r3, r4, r5, &miss);
|
1638
1636
|
|
1639
1637
|
GenerateDictionaryStore(masm, &miss, r3, r2, r0, r4, r5);
|
1640
|
-
|
1638
|
+
Counters* counters = masm->isolate()->counters();
|
1639
|
+
__ IncrementCounter(counters->store_normal_hit(),
|
1640
|
+
1, r4, r5);
|
1641
1641
|
__ Ret();
|
1642
1642
|
|
1643
1643
|
__ bind(&miss);
|
1644
|
-
__ IncrementCounter(
|
1644
|
+
__ IncrementCounter(counters->store_normal_miss(), 1, r4, r5);
|
1645
1645
|
GenerateMiss(masm);
|
1646
1646
|
}
|
1647
1647
|
|
1648
1648
|
|
1649
|
-
void StoreIC::GenerateGlobalProxy(MacroAssembler* masm
|
1649
|
+
void StoreIC::GenerateGlobalProxy(MacroAssembler* masm,
|
1650
|
+
StrictModeFlag strict_mode) {
|
1650
1651
|
// ----------- S t a t e -------------
|
1651
1652
|
// -- r0 : value
|
1652
1653
|
// -- r1 : receiver
|
@@ -1656,8 +1657,12 @@ void StoreIC::GenerateGlobalProxy(MacroAssembler* masm) {
|
|
1656
1657
|
|
1657
1658
|
__ Push(r1, r2, r0);
|
1658
1659
|
|
1660
|
+
__ mov(r1, Operand(Smi::FromInt(NONE))); // PropertyAttributes
|
1661
|
+
__ mov(r0, Operand(Smi::FromInt(strict_mode)));
|
1662
|
+
__ Push(r1, r0);
|
1663
|
+
|
1659
1664
|
// Do tail-call to runtime routine.
|
1660
|
-
__ TailCallRuntime(Runtime::kSetProperty,
|
1665
|
+
__ TailCallRuntime(Runtime::kSetProperty, 5, 1);
|
1661
1666
|
}
|
1662
1667
|
|
1663
1668
|
|