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
@@ -41,18 +41,21 @@ namespace internal {
|
|
41
41
|
// -------------------------------------------------------------------------
|
42
42
|
// MacroAssembler implementation.
|
43
43
|
|
44
|
-
MacroAssembler::MacroAssembler(void* buffer, int size)
|
45
|
-
: Assembler(buffer, size),
|
44
|
+
MacroAssembler::MacroAssembler(Isolate* arg_isolate, void* buffer, int size)
|
45
|
+
: Assembler(arg_isolate, buffer, size),
|
46
46
|
generating_stub_(false),
|
47
|
-
allow_stub_calls_(true)
|
48
|
-
|
47
|
+
allow_stub_calls_(true) {
|
48
|
+
if (isolate() != NULL) {
|
49
|
+
code_object_ = Handle<Object>(isolate()->heap()->undefined_value(),
|
50
|
+
isolate());
|
51
|
+
}
|
49
52
|
}
|
50
53
|
|
51
54
|
|
52
55
|
void MacroAssembler::RecordWriteHelper(Register object,
|
53
56
|
Register addr,
|
54
57
|
Register scratch) {
|
55
|
-
if (
|
58
|
+
if (emit_debug_code()) {
|
56
59
|
// Check that the object is not in new space.
|
57
60
|
Label not_in_new_space;
|
58
61
|
InNewSpace(object, scratch, not_equal, ¬_in_new_space);
|
@@ -113,7 +116,7 @@ void MacroAssembler::RecordWrite(Register object,
|
|
113
116
|
|
114
117
|
// Clobber all input registers when running with the debug-code flag
|
115
118
|
// turned on to provoke errors.
|
116
|
-
if (
|
119
|
+
if (emit_debug_code()) {
|
117
120
|
mov(object, Immediate(BitCast<int32_t>(kZapValue)));
|
118
121
|
mov(value, Immediate(BitCast<int32_t>(kZapValue)));
|
119
122
|
mov(scratch, Immediate(BitCast<int32_t>(kZapValue)));
|
@@ -141,7 +144,7 @@ void MacroAssembler::RecordWrite(Register object,
|
|
141
144
|
|
142
145
|
// Clobber all input registers when running with the debug-code flag
|
143
146
|
// turned on to provoke errors.
|
144
|
-
if (
|
147
|
+
if (emit_debug_code()) {
|
145
148
|
mov(object, Immediate(BitCast<int32_t>(kZapValue)));
|
146
149
|
mov(address, Immediate(BitCast<int32_t>(kZapValue)));
|
147
150
|
mov(value, Immediate(BitCast<int32_t>(kZapValue)));
|
@@ -152,7 +155,7 @@ void MacroAssembler::RecordWrite(Register object,
|
|
152
155
|
#ifdef ENABLE_DEBUGGER_SUPPORT
|
153
156
|
void MacroAssembler::DebugBreak() {
|
154
157
|
Set(eax, Immediate(0));
|
155
|
-
mov(ebx, Immediate(ExternalReference(Runtime::kDebugBreak)));
|
158
|
+
mov(ebx, Immediate(ExternalReference(Runtime::kDebugBreak, isolate())));
|
156
159
|
CEntryStub ces(1);
|
157
160
|
call(ces.GetCode(), RelocInfo::DEBUG_BREAK);
|
158
161
|
}
|
@@ -250,7 +253,7 @@ void MacroAssembler::AbortIfNotNumber(Register object) {
|
|
250
253
|
test(object, Immediate(kSmiTagMask));
|
251
254
|
j(zero, &ok);
|
252
255
|
cmp(FieldOperand(object, HeapObject::kMapOffset),
|
253
|
-
|
256
|
+
isolate()->factory()->heap_number_map());
|
254
257
|
Assert(equal, "Operand not a number");
|
255
258
|
bind(&ok);
|
256
259
|
}
|
@@ -285,15 +288,15 @@ void MacroAssembler::EnterFrame(StackFrame::Type type) {
|
|
285
288
|
push(esi);
|
286
289
|
push(Immediate(Smi::FromInt(type)));
|
287
290
|
push(Immediate(CodeObject()));
|
288
|
-
if (
|
289
|
-
cmp(Operand(esp, 0), Immediate(
|
291
|
+
if (emit_debug_code()) {
|
292
|
+
cmp(Operand(esp, 0), Immediate(isolate()->factory()->undefined_value()));
|
290
293
|
Check(not_equal, "code object not properly patched");
|
291
294
|
}
|
292
295
|
}
|
293
296
|
|
294
297
|
|
295
298
|
void MacroAssembler::LeaveFrame(StackFrame::Type type) {
|
296
|
-
if (
|
299
|
+
if (emit_debug_code()) {
|
297
300
|
cmp(Operand(ebp, StandardFrameConstants::kMarkerOffset),
|
298
301
|
Immediate(Smi::FromInt(type)));
|
299
302
|
Check(equal, "stack frame types must match");
|
@@ -316,8 +319,10 @@ void MacroAssembler::EnterExitFramePrologue() {
|
|
316
319
|
push(Immediate(CodeObject())); // Accessed from ExitFrame::code_slot.
|
317
320
|
|
318
321
|
// Save the frame pointer and the context in top.
|
319
|
-
ExternalReference c_entry_fp_address(
|
320
|
-
|
322
|
+
ExternalReference c_entry_fp_address(Isolate::k_c_entry_fp_address,
|
323
|
+
isolate());
|
324
|
+
ExternalReference context_address(Isolate::k_context_address,
|
325
|
+
isolate());
|
321
326
|
mov(Operand::StaticVariable(c_entry_fp_address), ebp);
|
322
327
|
mov(Operand::StaticVariable(context_address), esi);
|
323
328
|
}
|
@@ -339,7 +344,7 @@ void MacroAssembler::EnterExitFrameEpilogue(int argc, bool save_doubles) {
|
|
339
344
|
}
|
340
345
|
|
341
346
|
// Get the required frame alignment for the OS.
|
342
|
-
|
347
|
+
const int kFrameAlignment = OS::ActivationFrameAlignment();
|
343
348
|
if (kFrameAlignment > 0) {
|
344
349
|
ASSERT(IsPowerOf2(kFrameAlignment));
|
345
350
|
and_(esp, -kFrameAlignment);
|
@@ -358,7 +363,8 @@ void MacroAssembler::EnterExitFrame(bool save_doubles) {
|
|
358
363
|
mov(edi, Operand(eax));
|
359
364
|
lea(esi, Operand(ebp, eax, times_4, offset));
|
360
365
|
|
361
|
-
|
366
|
+
// Reserve space for argc, argv and isolate.
|
367
|
+
EnterExitFrameEpilogue(3, save_doubles);
|
362
368
|
}
|
363
369
|
|
364
370
|
|
@@ -394,14 +400,15 @@ void MacroAssembler::LeaveExitFrame(bool save_doubles) {
|
|
394
400
|
|
395
401
|
void MacroAssembler::LeaveExitFrameEpilogue() {
|
396
402
|
// Restore current context from top and clear it in debug mode.
|
397
|
-
ExternalReference context_address(
|
403
|
+
ExternalReference context_address(Isolate::k_context_address, isolate());
|
398
404
|
mov(esi, Operand::StaticVariable(context_address));
|
399
405
|
#ifdef DEBUG
|
400
406
|
mov(Operand::StaticVariable(context_address), Immediate(0));
|
401
407
|
#endif
|
402
408
|
|
403
409
|
// Clear the top frame.
|
404
|
-
ExternalReference c_entry_fp_address(
|
410
|
+
ExternalReference c_entry_fp_address(Isolate::k_c_entry_fp_address,
|
411
|
+
isolate());
|
405
412
|
mov(Operand::StaticVariable(c_entry_fp_address), Immediate(0));
|
406
413
|
}
|
407
414
|
|
@@ -435,15 +442,19 @@ void MacroAssembler::PushTryHandler(CodeLocation try_location,
|
|
435
442
|
push(Immediate(0)); // NULL frame pointer.
|
436
443
|
}
|
437
444
|
// Save the current handler as the next handler.
|
438
|
-
push(Operand::StaticVariable(ExternalReference(
|
445
|
+
push(Operand::StaticVariable(ExternalReference(Isolate::k_handler_address,
|
446
|
+
isolate())));
|
439
447
|
// Link this handler as the new current one.
|
440
|
-
mov(Operand::StaticVariable(ExternalReference(
|
448
|
+
mov(Operand::StaticVariable(ExternalReference(Isolate::k_handler_address,
|
449
|
+
isolate())),
|
450
|
+
esp);
|
441
451
|
}
|
442
452
|
|
443
453
|
|
444
454
|
void MacroAssembler::PopTryHandler() {
|
445
455
|
ASSERT_EQ(0, StackHandlerConstants::kNextOffset);
|
446
|
-
pop(Operand::StaticVariable(ExternalReference(
|
456
|
+
pop(Operand::StaticVariable(ExternalReference(Isolate::k_handler_address,
|
457
|
+
isolate())));
|
447
458
|
add(Operand(esp), Immediate(StackHandlerConstants::kSize - kPointerSize));
|
448
459
|
}
|
449
460
|
|
@@ -458,7 +469,8 @@ void MacroAssembler::Throw(Register value) {
|
|
458
469
|
}
|
459
470
|
|
460
471
|
// Drop the sp to the top of the handler.
|
461
|
-
ExternalReference handler_address(
|
472
|
+
ExternalReference handler_address(Isolate::k_handler_address,
|
473
|
+
isolate());
|
462
474
|
mov(esp, Operand::StaticVariable(handler_address));
|
463
475
|
|
464
476
|
// Restore next handler and frame pointer, discard handler state.
|
@@ -494,7 +506,8 @@ void MacroAssembler::ThrowUncatchable(UncatchableExceptionType type,
|
|
494
506
|
}
|
495
507
|
|
496
508
|
// Drop sp to the top stack handler.
|
497
|
-
ExternalReference handler_address(
|
509
|
+
ExternalReference handler_address(Isolate::k_handler_address,
|
510
|
+
isolate());
|
498
511
|
mov(esp, Operand::StaticVariable(handler_address));
|
499
512
|
|
500
513
|
// Unwind the handlers until the ENTRY handler is found.
|
@@ -516,12 +529,15 @@ void MacroAssembler::ThrowUncatchable(UncatchableExceptionType type,
|
|
516
529
|
|
517
530
|
if (type == OUT_OF_MEMORY) {
|
518
531
|
// Set external caught exception to false.
|
519
|
-
ExternalReference external_caught(
|
532
|
+
ExternalReference external_caught(
|
533
|
+
Isolate::k_external_caught_exception_address,
|
534
|
+
isolate());
|
520
535
|
mov(eax, false);
|
521
536
|
mov(Operand::StaticVariable(external_caught), eax);
|
522
537
|
|
523
538
|
// Set pending exception and eax to out of memory exception.
|
524
|
-
ExternalReference pending_exception(
|
539
|
+
ExternalReference pending_exception(Isolate::k_pending_exception_address,
|
540
|
+
isolate());
|
525
541
|
mov(eax, reinterpret_cast<int32_t>(Failure::OutOfMemoryException()));
|
526
542
|
mov(Operand::StaticVariable(pending_exception), eax);
|
527
543
|
}
|
@@ -550,7 +566,7 @@ void MacroAssembler::CheckAccessGlobalProxy(Register holder_reg,
|
|
550
566
|
mov(scratch, Operand(ebp, StandardFrameConstants::kContextOffset));
|
551
567
|
|
552
568
|
// When generating debug code, make sure the lexical context is set.
|
553
|
-
if (
|
569
|
+
if (emit_debug_code()) {
|
554
570
|
cmp(Operand(scratch), Immediate(0));
|
555
571
|
Check(not_equal, "we should not have an empty lexical context");
|
556
572
|
}
|
@@ -560,11 +576,11 @@ void MacroAssembler::CheckAccessGlobalProxy(Register holder_reg,
|
|
560
576
|
mov(scratch, FieldOperand(scratch, GlobalObject::kGlobalContextOffset));
|
561
577
|
|
562
578
|
// Check the context is a global context.
|
563
|
-
if (
|
579
|
+
if (emit_debug_code()) {
|
564
580
|
push(scratch);
|
565
581
|
// Read the first word and compare to global_context_map.
|
566
582
|
mov(scratch, FieldOperand(scratch, HeapObject::kMapOffset));
|
567
|
-
cmp(scratch,
|
583
|
+
cmp(scratch, isolate()->factory()->global_context_map());
|
568
584
|
Check(equal, "JSGlobalObject::global_context should be a global context.");
|
569
585
|
pop(scratch);
|
570
586
|
}
|
@@ -584,14 +600,14 @@ void MacroAssembler::CheckAccessGlobalProxy(Register holder_reg,
|
|
584
600
|
mov(holder_reg, FieldOperand(holder_reg, JSGlobalProxy::kContextOffset));
|
585
601
|
|
586
602
|
// Check the context is a global context.
|
587
|
-
if (
|
588
|
-
cmp(holder_reg,
|
603
|
+
if (emit_debug_code()) {
|
604
|
+
cmp(holder_reg, isolate()->factory()->null_value());
|
589
605
|
Check(not_equal, "JSGlobalProxy::context() should not be null.");
|
590
606
|
|
591
607
|
push(holder_reg);
|
592
608
|
// Read the first word and compare to global_context_map(),
|
593
609
|
mov(holder_reg, FieldOperand(holder_reg, HeapObject::kMapOffset));
|
594
|
-
cmp(holder_reg,
|
610
|
+
cmp(holder_reg, isolate()->factory()->global_context_map());
|
595
611
|
Check(equal, "JSGlobalObject::global_context should be a global context.");
|
596
612
|
pop(holder_reg);
|
597
613
|
}
|
@@ -611,7 +627,7 @@ void MacroAssembler::LoadAllocationTopHelper(Register result,
|
|
611
627
|
Register scratch,
|
612
628
|
AllocationFlags flags) {
|
613
629
|
ExternalReference new_space_allocation_top =
|
614
|
-
ExternalReference::new_space_allocation_top_address();
|
630
|
+
ExternalReference::new_space_allocation_top_address(isolate());
|
615
631
|
|
616
632
|
// Just return if allocation top is already known.
|
617
633
|
if ((flags & RESULT_CONTAINS_TOP) != 0) {
|
@@ -637,13 +653,13 @@ void MacroAssembler::LoadAllocationTopHelper(Register result,
|
|
637
653
|
|
638
654
|
void MacroAssembler::UpdateAllocationTopHelper(Register result_end,
|
639
655
|
Register scratch) {
|
640
|
-
if (
|
656
|
+
if (emit_debug_code()) {
|
641
657
|
test(result_end, Immediate(kObjectAlignmentMask));
|
642
658
|
Check(zero, "Unaligned allocation in new space");
|
643
659
|
}
|
644
660
|
|
645
661
|
ExternalReference new_space_allocation_top =
|
646
|
-
ExternalReference::new_space_allocation_top_address();
|
662
|
+
ExternalReference::new_space_allocation_top_address(isolate());
|
647
663
|
|
648
664
|
// Update new top. Use scratch if available.
|
649
665
|
if (scratch.is(no_reg)) {
|
@@ -661,7 +677,7 @@ void MacroAssembler::AllocateInNewSpace(int object_size,
|
|
661
677
|
Label* gc_required,
|
662
678
|
AllocationFlags flags) {
|
663
679
|
if (!FLAG_inline_new) {
|
664
|
-
if (
|
680
|
+
if (emit_debug_code()) {
|
665
681
|
// Trash the registers to simulate an allocation failure.
|
666
682
|
mov(result, Immediate(0x7091));
|
667
683
|
if (result_end.is_valid()) {
|
@@ -683,7 +699,7 @@ void MacroAssembler::AllocateInNewSpace(int object_size,
|
|
683
699
|
|
684
700
|
// Calculate new top and bail out if new space is exhausted.
|
685
701
|
ExternalReference new_space_allocation_limit =
|
686
|
-
ExternalReference::new_space_allocation_limit_address();
|
702
|
+
ExternalReference::new_space_allocation_limit_address(isolate());
|
687
703
|
|
688
704
|
if (!top_reg.is(result)) {
|
689
705
|
mov(top_reg, result);
|
@@ -718,7 +734,7 @@ void MacroAssembler::AllocateInNewSpace(int header_size,
|
|
718
734
|
Label* gc_required,
|
719
735
|
AllocationFlags flags) {
|
720
736
|
if (!FLAG_inline_new) {
|
721
|
-
if (
|
737
|
+
if (emit_debug_code()) {
|
722
738
|
// Trash the registers to simulate an allocation failure.
|
723
739
|
mov(result, Immediate(0x7091));
|
724
740
|
mov(result_end, Immediate(0x7191));
|
@@ -737,7 +753,7 @@ void MacroAssembler::AllocateInNewSpace(int header_size,
|
|
737
753
|
|
738
754
|
// Calculate new top and bail out if new space is exhausted.
|
739
755
|
ExternalReference new_space_allocation_limit =
|
740
|
-
ExternalReference::new_space_allocation_limit_address();
|
756
|
+
ExternalReference::new_space_allocation_limit_address(isolate());
|
741
757
|
|
742
758
|
// We assume that element_count*element_size + header_size does not
|
743
759
|
// overflow.
|
@@ -764,7 +780,7 @@ void MacroAssembler::AllocateInNewSpace(Register object_size,
|
|
764
780
|
Label* gc_required,
|
765
781
|
AllocationFlags flags) {
|
766
782
|
if (!FLAG_inline_new) {
|
767
|
-
if (
|
783
|
+
if (emit_debug_code()) {
|
768
784
|
// Trash the registers to simulate an allocation failure.
|
769
785
|
mov(result, Immediate(0x7091));
|
770
786
|
mov(result_end, Immediate(0x7191));
|
@@ -783,7 +799,7 @@ void MacroAssembler::AllocateInNewSpace(Register object_size,
|
|
783
799
|
|
784
800
|
// Calculate new top and bail out if new space is exhausted.
|
785
801
|
ExternalReference new_space_allocation_limit =
|
786
|
-
ExternalReference::new_space_allocation_limit_address();
|
802
|
+
ExternalReference::new_space_allocation_limit_address(isolate());
|
787
803
|
if (!object_size.is(result_end)) {
|
788
804
|
mov(result_end, object_size);
|
789
805
|
}
|
@@ -804,7 +820,7 @@ void MacroAssembler::AllocateInNewSpace(Register object_size,
|
|
804
820
|
|
805
821
|
void MacroAssembler::UndoAllocationInNewSpace(Register object) {
|
806
822
|
ExternalReference new_space_allocation_top =
|
807
|
-
ExternalReference::new_space_allocation_top_address();
|
823
|
+
ExternalReference::new_space_allocation_top_address(isolate());
|
808
824
|
|
809
825
|
// Make sure the object has no tag before resetting top.
|
810
826
|
and_(Operand(object), Immediate(~kHeapObjectTagMask));
|
@@ -830,7 +846,7 @@ void MacroAssembler::AllocateHeapNumber(Register result,
|
|
830
846
|
|
831
847
|
// Set the map.
|
832
848
|
mov(FieldOperand(result, HeapObject::kMapOffset),
|
833
|
-
Immediate(
|
849
|
+
Immediate(isolate()->factory()->heap_number_map()));
|
834
850
|
}
|
835
851
|
|
836
852
|
|
@@ -860,7 +876,7 @@ void MacroAssembler::AllocateTwoByteString(Register result,
|
|
860
876
|
|
861
877
|
// Set the map, length and hash field.
|
862
878
|
mov(FieldOperand(result, HeapObject::kMapOffset),
|
863
|
-
Immediate(
|
879
|
+
Immediate(isolate()->factory()->string_map()));
|
864
880
|
mov(scratch1, length);
|
865
881
|
SmiTag(scratch1);
|
866
882
|
mov(FieldOperand(result, String::kLengthOffset), scratch1);
|
@@ -895,7 +911,7 @@ void MacroAssembler::AllocateAsciiString(Register result,
|
|
895
911
|
|
896
912
|
// Set the map, length and hash field.
|
897
913
|
mov(FieldOperand(result, HeapObject::kMapOffset),
|
898
|
-
Immediate(
|
914
|
+
Immediate(isolate()->factory()->ascii_string_map()));
|
899
915
|
mov(scratch1, length);
|
900
916
|
SmiTag(scratch1);
|
901
917
|
mov(FieldOperand(result, String::kLengthOffset), scratch1);
|
@@ -921,7 +937,7 @@ void MacroAssembler::AllocateAsciiString(Register result,
|
|
921
937
|
|
922
938
|
// Set the map, length and hash field.
|
923
939
|
mov(FieldOperand(result, HeapObject::kMapOffset),
|
924
|
-
Immediate(
|
940
|
+
Immediate(isolate()->factory()->ascii_string_map()));
|
925
941
|
mov(FieldOperand(result, String::kLengthOffset),
|
926
942
|
Immediate(Smi::FromInt(length)));
|
927
943
|
mov(FieldOperand(result, String::kHashFieldOffset),
|
@@ -943,7 +959,7 @@ void MacroAssembler::AllocateConsString(Register result,
|
|
943
959
|
|
944
960
|
// Set the map. The other fields are left uninitialized.
|
945
961
|
mov(FieldOperand(result, HeapObject::kMapOffset),
|
946
|
-
Immediate(
|
962
|
+
Immediate(isolate()->factory()->cons_string_map()));
|
947
963
|
}
|
948
964
|
|
949
965
|
|
@@ -961,7 +977,7 @@ void MacroAssembler::AllocateAsciiConsString(Register result,
|
|
961
977
|
|
962
978
|
// Set the map. The other fields are left uninitialized.
|
963
979
|
mov(FieldOperand(result, HeapObject::kMapOffset),
|
964
|
-
Immediate(
|
980
|
+
Immediate(isolate()->factory()->cons_ascii_string_map()));
|
965
981
|
}
|
966
982
|
|
967
983
|
|
@@ -1079,7 +1095,7 @@ void MacroAssembler::TryGetFunctionPrototype(Register function,
|
|
1079
1095
|
// If the prototype or initial map is the hole, don't return it and
|
1080
1096
|
// simply miss the cache instead. This will allow us to allocate a
|
1081
1097
|
// prototype object on-demand in the runtime system.
|
1082
|
-
cmp(Operand(result), Immediate(
|
1098
|
+
cmp(Operand(result), Immediate(isolate()->factory()->the_hole_value()));
|
1083
1099
|
j(equal, miss, not_taken);
|
1084
1100
|
|
1085
1101
|
// If the function does not have an initial map, we're done.
|
@@ -1145,7 +1161,7 @@ void MacroAssembler::IllegalOperation(int num_arguments) {
|
|
1145
1161
|
if (num_arguments > 0) {
|
1146
1162
|
add(Operand(esp), Immediate(num_arguments * kPointerSize));
|
1147
1163
|
}
|
1148
|
-
mov(eax, Immediate(
|
1164
|
+
mov(eax, Immediate(isolate()->factory()->undefined_value()));
|
1149
1165
|
}
|
1150
1166
|
|
1151
1167
|
|
@@ -1174,9 +1190,9 @@ void MacroAssembler::CallRuntime(Runtime::FunctionId id, int num_arguments) {
|
|
1174
1190
|
|
1175
1191
|
|
1176
1192
|
void MacroAssembler::CallRuntimeSaveDoubles(Runtime::FunctionId id) {
|
1177
|
-
Runtime::Function* function = Runtime::FunctionForId(id);
|
1193
|
+
const Runtime::Function* function = Runtime::FunctionForId(id);
|
1178
1194
|
Set(eax, Immediate(function->nargs));
|
1179
|
-
mov(ebx, Immediate(ExternalReference(function)));
|
1195
|
+
mov(ebx, Immediate(ExternalReference(function, isolate())));
|
1180
1196
|
CEntryStub ces(1);
|
1181
1197
|
ces.SaveDoubles();
|
1182
1198
|
CallStub(&ces);
|
@@ -1189,7 +1205,8 @@ MaybeObject* MacroAssembler::TryCallRuntime(Runtime::FunctionId id,
|
|
1189
1205
|
}
|
1190
1206
|
|
1191
1207
|
|
1192
|
-
void MacroAssembler::CallRuntime(Runtime::Function* f,
|
1208
|
+
void MacroAssembler::CallRuntime(const Runtime::Function* f,
|
1209
|
+
int num_arguments) {
|
1193
1210
|
// If the expected number of arguments of the runtime function is
|
1194
1211
|
// constant, we check that the actual number of arguments match the
|
1195
1212
|
// expectation.
|
@@ -1203,19 +1220,19 @@ void MacroAssembler::CallRuntime(Runtime::Function* f, int num_arguments) {
|
|
1203
1220
|
// should remove this need and make the runtime routine entry code
|
1204
1221
|
// smarter.
|
1205
1222
|
Set(eax, Immediate(num_arguments));
|
1206
|
-
mov(ebx, Immediate(ExternalReference(f)));
|
1223
|
+
mov(ebx, Immediate(ExternalReference(f, isolate())));
|
1207
1224
|
CEntryStub ces(1);
|
1208
1225
|
CallStub(&ces);
|
1209
1226
|
}
|
1210
1227
|
|
1211
1228
|
|
1212
|
-
MaybeObject* MacroAssembler::TryCallRuntime(Runtime::Function* f,
|
1229
|
+
MaybeObject* MacroAssembler::TryCallRuntime(const Runtime::Function* f,
|
1213
1230
|
int num_arguments) {
|
1214
1231
|
if (f->nargs >= 0 && f->nargs != num_arguments) {
|
1215
1232
|
IllegalOperation(num_arguments);
|
1216
1233
|
// Since we did not call the stub, there was no allocation failure.
|
1217
1234
|
// Return some non-failure object.
|
1218
|
-
return
|
1235
|
+
return isolate()->heap()->undefined_value();
|
1219
1236
|
}
|
1220
1237
|
|
1221
1238
|
// TODO(1236192): Most runtime routines don't need the number of
|
@@ -1223,7 +1240,7 @@ MaybeObject* MacroAssembler::TryCallRuntime(Runtime::Function* f,
|
|
1223
1240
|
// should remove this need and make the runtime routine entry code
|
1224
1241
|
// smarter.
|
1225
1242
|
Set(eax, Immediate(num_arguments));
|
1226
|
-
mov(ebx, Immediate(ExternalReference(f)));
|
1243
|
+
mov(ebx, Immediate(ExternalReference(f, isolate())));
|
1227
1244
|
CEntryStub ces(1);
|
1228
1245
|
return TryCallStub(&ces);
|
1229
1246
|
}
|
@@ -1265,7 +1282,9 @@ MaybeObject* MacroAssembler::TryTailCallExternalReference(
|
|
1265
1282
|
void MacroAssembler::TailCallRuntime(Runtime::FunctionId fid,
|
1266
1283
|
int num_arguments,
|
1267
1284
|
int result_size) {
|
1268
|
-
TailCallExternalReference(ExternalReference(fid
|
1285
|
+
TailCallExternalReference(ExternalReference(fid, isolate()),
|
1286
|
+
num_arguments,
|
1287
|
+
result_size);
|
1269
1288
|
}
|
1270
1289
|
|
1271
1290
|
|
@@ -1273,7 +1292,7 @@ MaybeObject* MacroAssembler::TryTailCallRuntime(Runtime::FunctionId fid,
|
|
1273
1292
|
int num_arguments,
|
1274
1293
|
int result_size) {
|
1275
1294
|
return TryTailCallExternalReference(
|
1276
|
-
ExternalReference(fid), num_arguments, result_size);
|
1295
|
+
ExternalReference(fid, isolate()), num_arguments, result_size);
|
1277
1296
|
}
|
1278
1297
|
|
1279
1298
|
|
@@ -1320,7 +1339,7 @@ void MacroAssembler::PrepareCallApiFunction(int argc, Register scratch) {
|
|
1320
1339
|
// pointer to out cell.
|
1321
1340
|
lea(scratch, Operand(esp, (argc + 1) * kPointerSize));
|
1322
1341
|
mov(Operand(esp, 0 * kPointerSize), scratch); // output.
|
1323
|
-
if (
|
1342
|
+
if (emit_debug_code()) {
|
1324
1343
|
mov(Operand(esp, (argc + 1) * kPointerSize), Immediate(0)); // out cell.
|
1325
1344
|
}
|
1326
1345
|
}
|
@@ -1373,9 +1392,9 @@ MaybeObject* MacroAssembler::TryCallApiFunctionAndReturn(ApiFunction* function,
|
|
1373
1392
|
|
1374
1393
|
// Check if the function scheduled an exception.
|
1375
1394
|
ExternalReference scheduled_exception_address =
|
1376
|
-
ExternalReference::scheduled_exception_address();
|
1395
|
+
ExternalReference::scheduled_exception_address(isolate());
|
1377
1396
|
cmp(Operand::StaticVariable(scheduled_exception_address),
|
1378
|
-
Immediate(
|
1397
|
+
Immediate(isolate()->factory()->the_hole_value()));
|
1379
1398
|
j(not_equal, &promote_scheduled_exception, not_taken);
|
1380
1399
|
LeaveApiExitFrame();
|
1381
1400
|
ret(stack_space * kPointerSize);
|
@@ -1387,14 +1406,17 @@ MaybeObject* MacroAssembler::TryCallApiFunctionAndReturn(ApiFunction* function,
|
|
1387
1406
|
}
|
1388
1407
|
bind(&empty_handle);
|
1389
1408
|
// It was zero; the result is undefined.
|
1390
|
-
mov(eax,
|
1409
|
+
mov(eax, isolate()->factory()->undefined_value());
|
1391
1410
|
jmp(&prologue);
|
1392
1411
|
|
1393
1412
|
// HandleScope limit has changed. Delete allocated extensions.
|
1413
|
+
ExternalReference delete_extensions =
|
1414
|
+
ExternalReference::delete_handle_scope_extensions(isolate());
|
1394
1415
|
bind(&delete_allocated_handles);
|
1395
1416
|
mov(Operand::StaticVariable(limit_address), edi);
|
1396
1417
|
mov(edi, eax);
|
1397
|
-
mov(
|
1418
|
+
mov(Operand(esp, 0), Immediate(ExternalReference::isolate_address()));
|
1419
|
+
mov(eax, Immediate(delete_extensions));
|
1398
1420
|
call(Operand(eax));
|
1399
1421
|
mov(eax, edi);
|
1400
1422
|
jmp(&leave_exit_frame);
|
@@ -1424,7 +1446,7 @@ void MacroAssembler::InvokePrologue(const ParameterCount& expected,
|
|
1424
1446
|
const ParameterCount& actual,
|
1425
1447
|
Handle<Code> code_constant,
|
1426
1448
|
const Operand& code_operand,
|
1427
|
-
|
1449
|
+
NearLabel* done,
|
1428
1450
|
InvokeFlag flag,
|
1429
1451
|
PostCallGenerator* post_call_generator) {
|
1430
1452
|
bool definitely_matches = false;
|
@@ -1467,7 +1489,7 @@ void MacroAssembler::InvokePrologue(const ParameterCount& expected,
|
|
1467
1489
|
|
1468
1490
|
if (!definitely_matches) {
|
1469
1491
|
Handle<Code> adaptor =
|
1470
|
-
|
1492
|
+
isolate()->builtins()->ArgumentsAdaptorTrampoline();
|
1471
1493
|
if (!code_constant.is_null()) {
|
1472
1494
|
mov(edx, Immediate(code_constant));
|
1473
1495
|
add(Operand(edx), Immediate(Code::kHeaderSize - kHeapObjectTag));
|
@@ -1492,7 +1514,7 @@ void MacroAssembler::InvokeCode(const Operand& code,
|
|
1492
1514
|
const ParameterCount& actual,
|
1493
1515
|
InvokeFlag flag,
|
1494
1516
|
PostCallGenerator* post_call_generator) {
|
1495
|
-
|
1517
|
+
NearLabel done;
|
1496
1518
|
InvokePrologue(expected, actual, Handle<Code>::null(), code,
|
1497
1519
|
&done, flag, post_call_generator);
|
1498
1520
|
if (flag == CALL_FUNCTION) {
|
@@ -1512,7 +1534,7 @@ void MacroAssembler::InvokeCode(Handle<Code> code,
|
|
1512
1534
|
RelocInfo::Mode rmode,
|
1513
1535
|
InvokeFlag flag,
|
1514
1536
|
PostCallGenerator* post_call_generator) {
|
1515
|
-
|
1537
|
+
NearLabel done;
|
1516
1538
|
Operand dummy(eax);
|
1517
1539
|
InvokePrologue(expected, actual, code, dummy, &done,
|
1518
1540
|
flag, post_call_generator);
|
@@ -1621,7 +1643,7 @@ void MacroAssembler::LoadContext(Register dst, int context_chain_length) {
|
|
1621
1643
|
// (i.e., the static scope chain and runtime context chain do not agree).
|
1622
1644
|
// A variable occurring in such a scope should have slot type LOOKUP and
|
1623
1645
|
// not CONTEXT.
|
1624
|
-
if (
|
1646
|
+
if (emit_debug_code()) {
|
1625
1647
|
cmp(dst, Operand(dst, Context::SlotOffset(Context::FCONTEXT_INDEX)));
|
1626
1648
|
Check(equal, "Yo dawg, I heard you liked function contexts "
|
1627
1649
|
"so I put function contexts in all your contexts");
|
@@ -1643,9 +1665,9 @@ void MacroAssembler::LoadGlobalFunctionInitialMap(Register function,
|
|
1643
1665
|
Register map) {
|
1644
1666
|
// Load the initial map. The global functions all have initial maps.
|
1645
1667
|
mov(map, FieldOperand(function, JSFunction::kPrototypeOrInitialMapOffset));
|
1646
|
-
if (
|
1668
|
+
if (emit_debug_code()) {
|
1647
1669
|
Label ok, fail;
|
1648
|
-
CheckMap(map,
|
1670
|
+
CheckMap(map, isolate()->factory()->meta_map(), &fail, false);
|
1649
1671
|
jmp(&ok);
|
1650
1672
|
bind(&fail);
|
1651
1673
|
Abort("Global functions must have initial map");
|
@@ -1787,18 +1809,19 @@ void MacroAssembler::DecrementCounter(Condition cc,
|
|
1787
1809
|
|
1788
1810
|
|
1789
1811
|
void MacroAssembler::Assert(Condition cc, const char* msg) {
|
1790
|
-
if (
|
1812
|
+
if (emit_debug_code()) Check(cc, msg);
|
1791
1813
|
}
|
1792
1814
|
|
1793
1815
|
|
1794
1816
|
void MacroAssembler::AssertFastElements(Register elements) {
|
1795
|
-
if (
|
1817
|
+
if (emit_debug_code()) {
|
1818
|
+
Factory* factory = isolate()->factory();
|
1796
1819
|
Label ok;
|
1797
1820
|
cmp(FieldOperand(elements, HeapObject::kMapOffset),
|
1798
|
-
Immediate(
|
1821
|
+
Immediate(factory->fixed_array_map()));
|
1799
1822
|
j(equal, &ok);
|
1800
1823
|
cmp(FieldOperand(elements, HeapObject::kMapOffset),
|
1801
|
-
Immediate(
|
1824
|
+
Immediate(factory->fixed_cow_array_map()));
|
1802
1825
|
j(equal, &ok);
|
1803
1826
|
Abort("JSObject with fast elements map has slow elements");
|
1804
1827
|
bind(&ok);
|
@@ -1860,10 +1883,10 @@ void MacroAssembler::Abort(const char* msg) {
|
|
1860
1883
|
void MacroAssembler::JumpIfNotNumber(Register reg,
|
1861
1884
|
TypeInfo info,
|
1862
1885
|
Label* on_not_number) {
|
1863
|
-
if (
|
1886
|
+
if (emit_debug_code()) AbortIfSmi(reg);
|
1864
1887
|
if (!info.IsNumber()) {
|
1865
1888
|
cmp(FieldOperand(reg, HeapObject::kMapOffset),
|
1866
|
-
|
1889
|
+
isolate()->factory()->heap_number_map());
|
1867
1890
|
j(not_equal, on_not_number);
|
1868
1891
|
}
|
1869
1892
|
}
|
@@ -1874,7 +1897,7 @@ void MacroAssembler::ConvertToInt32(Register dst,
|
|
1874
1897
|
Register scratch,
|
1875
1898
|
TypeInfo info,
|
1876
1899
|
Label* on_not_int32) {
|
1877
|
-
if (
|
1900
|
+
if (emit_debug_code()) {
|
1878
1901
|
AbortIfSmi(source);
|
1879
1902
|
AbortIfNotNumber(source);
|
1880
1903
|
}
|
@@ -1968,14 +1991,14 @@ void MacroAssembler::JumpIfNotBothSequentialAsciiStrings(Register object1,
|
|
1968
1991
|
|
1969
1992
|
|
1970
1993
|
void MacroAssembler::PrepareCallCFunction(int num_arguments, Register scratch) {
|
1971
|
-
int
|
1972
|
-
if (
|
1994
|
+
int frame_alignment = OS::ActivationFrameAlignment();
|
1995
|
+
if (frame_alignment != 0) {
|
1973
1996
|
// Make stack end at alignment and make room for num_arguments words
|
1974
1997
|
// and the original value of esp.
|
1975
1998
|
mov(scratch, esp);
|
1976
1999
|
sub(Operand(esp), Immediate((num_arguments + 1) * kPointerSize));
|
1977
|
-
ASSERT(IsPowerOf2(
|
1978
|
-
and_(esp, -
|
2000
|
+
ASSERT(IsPowerOf2(frame_alignment));
|
2001
|
+
and_(esp, -frame_alignment);
|
1979
2002
|
mov(Operand(esp, num_arguments * kPointerSize), scratch);
|
1980
2003
|
} else {
|
1981
2004
|
sub(Operand(esp), Immediate(num_arguments * kPointerSize));
|
@@ -1994,7 +2017,7 @@ void MacroAssembler::CallCFunction(ExternalReference function,
|
|
1994
2017
|
void MacroAssembler::CallCFunction(Register function,
|
1995
2018
|
int num_arguments) {
|
1996
2019
|
// Check stack alignment.
|
1997
|
-
if (
|
2020
|
+
if (emit_debug_code()) {
|
1998
2021
|
CheckStackAlignment();
|
1999
2022
|
}
|
2000
2023
|
|
@@ -2002,13 +2025,15 @@ void MacroAssembler::CallCFunction(Register function,
|
|
2002
2025
|
if (OS::ActivationFrameAlignment() != 0) {
|
2003
2026
|
mov(esp, Operand(esp, num_arguments * kPointerSize));
|
2004
2027
|
} else {
|
2005
|
-
add(Operand(esp), Immediate(num_arguments *
|
2028
|
+
add(Operand(esp), Immediate(num_arguments * kPointerSize));
|
2006
2029
|
}
|
2007
2030
|
}
|
2008
2031
|
|
2009
2032
|
|
2010
2033
|
CodePatcher::CodePatcher(byte* address, int size)
|
2011
|
-
: address_(address),
|
2034
|
+
: address_(address),
|
2035
|
+
size_(size),
|
2036
|
+
masm_(Isolate::Current(), address, size + Assembler::kGap) {
|
2012
2037
|
// Create a new macro assembler pointing to the address of the code to patch.
|
2013
2038
|
// The size is adjusted with kGap on order for the assembler to generate size
|
2014
2039
|
// bytes of instructions without failing with buffer size constraints.
|