mustang 0.0.1 → 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.rspec +1 -0
- data/Isolate +9 -0
- data/README.md +6 -12
- data/Rakefile +30 -4
- data/TODO.md +9 -0
- data/ext/v8/extconf.rb +56 -0
- data/ext/v8/v8.cpp +37 -0
- data/ext/v8/v8_array.cpp +161 -0
- data/ext/v8/v8_array.h +17 -0
- data/ext/v8/v8_base.cpp +147 -0
- data/ext/v8/v8_base.h +23 -0
- data/ext/v8/v8_cast.cpp +151 -0
- data/ext/v8/v8_cast.h +64 -0
- data/ext/v8/v8_context.cpp +174 -0
- data/ext/v8/v8_context.h +12 -0
- data/ext/v8/v8_date.cpp +61 -0
- data/ext/v8/v8_date.h +16 -0
- data/ext/v8/v8_errors.cpp +147 -0
- data/ext/v8/v8_errors.h +19 -0
- data/ext/v8/v8_external.cpp +66 -0
- data/ext/v8/v8_external.h +16 -0
- data/ext/v8/v8_function.cpp +182 -0
- data/ext/v8/v8_function.h +14 -0
- data/ext/v8/v8_integer.cpp +70 -0
- data/ext/v8/v8_integer.h +16 -0
- data/ext/v8/v8_macros.h +30 -0
- data/ext/v8/v8_main.cpp +53 -0
- data/ext/v8/v8_main.h +13 -0
- data/ext/v8/v8_number.cpp +62 -0
- data/ext/v8/v8_number.h +16 -0
- data/ext/v8/v8_object.cpp +172 -0
- data/ext/v8/v8_object.h +17 -0
- data/ext/v8/v8_ref.cpp +72 -0
- data/ext/v8/v8_ref.h +43 -0
- data/ext/v8/v8_regexp.cpp +148 -0
- data/ext/v8/v8_regexp.h +16 -0
- data/ext/v8/v8_string.cpp +78 -0
- data/ext/v8/v8_string.h +16 -0
- data/ext/v8/v8_value.cpp +370 -0
- data/ext/v8/v8_value.h +19 -0
- data/gemspec.yml +2 -1
- data/lib/core_ext/class.rb +14 -0
- data/lib/core_ext/object.rb +12 -0
- data/lib/core_ext/symbol.rb +23 -0
- data/lib/mustang.rb +44 -0
- data/lib/mustang/context.rb +69 -0
- data/lib/mustang/errors.rb +36 -0
- data/lib/support/delegated.rb +25 -0
- data/lib/v8/array.rb +21 -0
- data/lib/v8/context.rb +13 -0
- data/lib/v8/date.rb +20 -0
- data/lib/v8/error.rb +15 -0
- data/lib/v8/external.rb +16 -0
- data/lib/v8/function.rb +11 -0
- data/lib/v8/integer.rb +16 -0
- data/lib/v8/number.rb +16 -0
- data/lib/v8/object.rb +66 -0
- data/lib/v8/regexp.rb +23 -0
- data/lib/v8/string.rb +27 -0
- data/mustang.gemspec +3 -0
- data/spec/core_ext/class_spec.rb +19 -0
- data/spec/core_ext/object_spec.rb +19 -0
- data/spec/core_ext/symbol_spec.rb +27 -0
- data/spec/fixtures/test1.js +2 -0
- data/spec/fixtures/test2.js +2 -0
- data/spec/spec_helper.rb +20 -0
- data/spec/v8/array_spec.rb +88 -0
- data/spec/v8/cast_spec.rb +151 -0
- data/spec/v8/context_spec.rb +78 -0
- data/spec/v8/data_spec.rb +39 -0
- data/spec/v8/date_spec.rb +45 -0
- data/spec/v8/empty_spec.rb +27 -0
- data/spec/v8/errors_spec.rb +142 -0
- data/spec/v8/external_spec.rb +44 -0
- data/spec/v8/function_spec.rb +170 -0
- data/spec/v8/integer_spec.rb +41 -0
- data/spec/v8/main_spec.rb +18 -0
- data/spec/v8/null_spec.rb +27 -0
- data/spec/v8/number_spec.rb +40 -0
- data/spec/v8/object_spec.rb +79 -0
- data/spec/v8/primitive_spec.rb +9 -0
- data/spec/v8/regexp_spec.rb +65 -0
- data/spec/v8/string_spec.rb +48 -0
- data/spec/v8/undefined_spec.rb +27 -0
- data/spec/v8/value_spec.rb +215 -0
- data/vendor/v8/.gitignore +2 -0
- data/vendor/v8/AUTHORS +3 -1
- data/vendor/v8/ChangeLog +117 -0
- data/vendor/v8/SConstruct +334 -53
- data/vendor/v8/include/v8-debug.h +21 -11
- data/vendor/v8/include/v8-preparser.h +1 -1
- data/vendor/v8/include/v8-profiler.h +122 -43
- data/vendor/v8/include/v8-testing.h +5 -0
- data/vendor/v8/include/v8.h +171 -17
- data/vendor/v8/preparser/SConscript +38 -0
- data/vendor/v8/preparser/preparser-process.cc +77 -114
- data/vendor/v8/samples/shell.cc +232 -46
- data/vendor/v8/src/SConscript +29 -5
- data/vendor/v8/src/accessors.cc +70 -211
- data/vendor/v8/{test/cctest/test-mips.cc → src/allocation-inl.h} +15 -18
- data/vendor/v8/src/allocation.cc +0 -82
- data/vendor/v8/src/allocation.h +9 -42
- data/vendor/v8/src/api.cc +1645 -1156
- data/vendor/v8/src/api.h +76 -12
- data/vendor/v8/src/apiutils.h +0 -7
- data/vendor/v8/src/arguments.h +15 -4
- data/vendor/v8/src/arm/assembler-arm-inl.h +10 -9
- data/vendor/v8/src/arm/assembler-arm.cc +62 -23
- data/vendor/v8/src/arm/assembler-arm.h +76 -11
- data/vendor/v8/src/arm/builtins-arm.cc +39 -33
- data/vendor/v8/src/arm/code-stubs-arm.cc +1182 -402
- data/vendor/v8/src/arm/code-stubs-arm.h +20 -54
- data/vendor/v8/src/arm/codegen-arm.cc +159 -106
- data/vendor/v8/src/arm/codegen-arm.h +6 -6
- data/vendor/v8/src/arm/constants-arm.h +16 -1
- data/vendor/v8/src/arm/cpu-arm.cc +7 -5
- data/vendor/v8/src/arm/debug-arm.cc +6 -4
- data/vendor/v8/src/arm/deoptimizer-arm.cc +51 -14
- data/vendor/v8/src/arm/disasm-arm.cc +47 -15
- data/vendor/v8/src/arm/frames-arm.h +1 -1
- data/vendor/v8/src/arm/full-codegen-arm.cc +724 -408
- data/vendor/v8/src/arm/ic-arm.cc +90 -85
- data/vendor/v8/src/arm/lithium-arm.cc +140 -69
- data/vendor/v8/src/arm/lithium-arm.h +161 -46
- data/vendor/v8/src/arm/lithium-codegen-arm.cc +567 -297
- data/vendor/v8/src/arm/lithium-codegen-arm.h +21 -9
- data/vendor/v8/src/arm/lithium-gap-resolver-arm.cc +2 -0
- data/vendor/v8/src/arm/macro-assembler-arm.cc +457 -96
- data/vendor/v8/src/arm/macro-assembler-arm.h +115 -18
- data/vendor/v8/src/arm/regexp-macro-assembler-arm.cc +20 -13
- data/vendor/v8/src/arm/regexp-macro-assembler-arm.h +1 -0
- data/vendor/v8/src/arm/simulator-arm.cc +184 -101
- data/vendor/v8/src/arm/simulator-arm.h +26 -21
- data/vendor/v8/src/arm/stub-cache-arm.cc +450 -467
- data/vendor/v8/src/arm/virtual-frame-arm.cc +14 -12
- data/vendor/v8/src/arm/virtual-frame-arm.h +11 -8
- data/vendor/v8/src/array.js +35 -18
- data/vendor/v8/src/assembler.cc +186 -92
- data/vendor/v8/src/assembler.h +106 -69
- data/vendor/v8/src/ast-inl.h +5 -0
- data/vendor/v8/src/ast.cc +46 -35
- data/vendor/v8/src/ast.h +107 -50
- data/vendor/v8/src/atomicops.h +2 -0
- data/vendor/v8/src/atomicops_internals_mips_gcc.h +169 -0
- data/vendor/v8/src/bootstrapper.cc +649 -399
- data/vendor/v8/src/bootstrapper.h +94 -27
- data/vendor/v8/src/builtins.cc +359 -227
- data/vendor/v8/src/builtins.h +157 -123
- data/vendor/v8/src/checks.cc +2 -2
- data/vendor/v8/src/checks.h +4 -0
- data/vendor/v8/src/code-stubs.cc +27 -17
- data/vendor/v8/src/code-stubs.h +38 -17
- data/vendor/v8/src/codegen-inl.h +5 -1
- data/vendor/v8/src/codegen.cc +27 -17
- data/vendor/v8/src/codegen.h +9 -9
- data/vendor/v8/src/compilation-cache.cc +92 -206
- data/vendor/v8/src/compilation-cache.h +205 -30
- data/vendor/v8/src/compiler.cc +107 -120
- data/vendor/v8/src/compiler.h +17 -2
- data/vendor/v8/src/contexts.cc +22 -15
- data/vendor/v8/src/contexts.h +14 -8
- data/vendor/v8/src/conversions.cc +86 -30
- data/vendor/v8/src/counters.cc +19 -4
- data/vendor/v8/src/counters.h +28 -16
- data/vendor/v8/src/cpu-profiler-inl.h +4 -3
- data/vendor/v8/src/cpu-profiler.cc +123 -72
- data/vendor/v8/src/cpu-profiler.h +33 -19
- data/vendor/v8/src/cpu.h +2 -0
- data/vendor/v8/src/d8-debug.cc +3 -3
- data/vendor/v8/src/d8-debug.h +7 -6
- data/vendor/v8/src/d8-posix.cc +2 -0
- data/vendor/v8/src/d8.cc +22 -12
- data/vendor/v8/src/d8.gyp +3 -0
- data/vendor/v8/src/d8.js +618 -0
- data/vendor/v8/src/data-flow.h +3 -3
- data/vendor/v8/src/dateparser.h +4 -2
- data/vendor/v8/src/debug-agent.cc +10 -9
- data/vendor/v8/src/debug-agent.h +9 -11
- data/vendor/v8/src/debug-debugger.js +121 -0
- data/vendor/v8/src/debug.cc +331 -227
- data/vendor/v8/src/debug.h +248 -219
- data/vendor/v8/src/deoptimizer.cc +173 -62
- data/vendor/v8/src/deoptimizer.h +119 -19
- data/vendor/v8/src/disasm.h +3 -0
- data/vendor/v8/src/disassembler.cc +10 -9
- data/vendor/v8/src/execution.cc +185 -129
- data/vendor/v8/src/execution.h +47 -78
- data/vendor/v8/src/extensions/experimental/break-iterator.cc +250 -0
- data/vendor/v8/src/extensions/experimental/break-iterator.h +89 -0
- data/vendor/v8/src/extensions/experimental/experimental.gyp +2 -0
- data/vendor/v8/src/extensions/experimental/i18n-extension.cc +22 -2
- data/vendor/v8/src/extensions/externalize-string-extension.cc +2 -2
- data/vendor/v8/src/extensions/gc-extension.cc +1 -1
- data/vendor/v8/src/factory.cc +261 -154
- data/vendor/v8/src/factory.h +162 -158
- data/vendor/v8/src/flag-definitions.h +17 -11
- data/vendor/v8/src/frame-element.cc +0 -5
- data/vendor/v8/src/frame-element.h +9 -13
- data/vendor/v8/src/frames-inl.h +7 -0
- data/vendor/v8/src/frames.cc +56 -46
- data/vendor/v8/src/frames.h +36 -25
- data/vendor/v8/src/full-codegen.cc +15 -24
- data/vendor/v8/src/full-codegen.h +13 -41
- data/vendor/v8/src/func-name-inferrer.cc +7 -6
- data/vendor/v8/src/func-name-inferrer.h +1 -1
- data/vendor/v8/src/gdb-jit.cc +1 -0
- data/vendor/v8/src/global-handles.cc +118 -56
- data/vendor/v8/src/global-handles.h +98 -40
- data/vendor/v8/src/globals.h +2 -2
- data/vendor/v8/src/handles-inl.h +106 -9
- data/vendor/v8/src/handles.cc +220 -157
- data/vendor/v8/src/handles.h +38 -59
- data/vendor/v8/src/hashmap.h +3 -3
- data/vendor/v8/src/heap-inl.h +141 -25
- data/vendor/v8/src/heap-profiler.cc +117 -63
- data/vendor/v8/src/heap-profiler.h +38 -21
- data/vendor/v8/src/heap.cc +805 -564
- data/vendor/v8/src/heap.h +640 -594
- data/vendor/v8/src/hydrogen-instructions.cc +216 -73
- data/vendor/v8/src/hydrogen-instructions.h +259 -124
- data/vendor/v8/src/hydrogen.cc +996 -1171
- data/vendor/v8/src/hydrogen.h +163 -144
- data/vendor/v8/src/ia32/assembler-ia32-inl.h +12 -11
- data/vendor/v8/src/ia32/assembler-ia32.cc +85 -39
- data/vendor/v8/src/ia32/assembler-ia32.h +82 -16
- data/vendor/v8/src/ia32/builtins-ia32.cc +64 -58
- data/vendor/v8/src/ia32/code-stubs-ia32.cc +248 -324
- data/vendor/v8/src/ia32/code-stubs-ia32.h +3 -44
- data/vendor/v8/src/ia32/codegen-ia32.cc +217 -165
- data/vendor/v8/src/ia32/codegen-ia32.h +3 -0
- data/vendor/v8/src/ia32/cpu-ia32.cc +6 -5
- data/vendor/v8/src/ia32/debug-ia32.cc +8 -5
- data/vendor/v8/src/ia32/deoptimizer-ia32.cc +124 -14
- data/vendor/v8/src/ia32/disasm-ia32.cc +85 -62
- data/vendor/v8/src/ia32/frames-ia32.h +1 -1
- data/vendor/v8/src/ia32/full-codegen-ia32.cc +348 -435
- data/vendor/v8/src/ia32/ic-ia32.cc +91 -91
- data/vendor/v8/src/ia32/lithium-codegen-ia32.cc +500 -255
- data/vendor/v8/src/ia32/lithium-codegen-ia32.h +13 -4
- data/vendor/v8/src/ia32/lithium-gap-resolver-ia32.cc +6 -0
- data/vendor/v8/src/ia32/lithium-ia32.cc +122 -45
- data/vendor/v8/src/ia32/lithium-ia32.h +128 -41
- data/vendor/v8/src/ia32/macro-assembler-ia32.cc +109 -84
- data/vendor/v8/src/ia32/macro-assembler-ia32.h +18 -9
- data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.cc +26 -15
- data/vendor/v8/src/ia32/regexp-macro-assembler-ia32.h +1 -0
- data/vendor/v8/src/ia32/register-allocator-ia32.cc +30 -30
- data/vendor/v8/src/ia32/simulator-ia32.h +4 -4
- data/vendor/v8/src/ia32/stub-cache-ia32.cc +383 -400
- data/vendor/v8/src/ia32/virtual-frame-ia32.cc +36 -13
- data/vendor/v8/src/ia32/virtual-frame-ia32.h +11 -5
- data/vendor/v8/src/ic-inl.h +12 -2
- data/vendor/v8/src/ic.cc +304 -221
- data/vendor/v8/src/ic.h +115 -58
- data/vendor/v8/src/interpreter-irregexp.cc +25 -21
- data/vendor/v8/src/interpreter-irregexp.h +2 -1
- data/vendor/v8/src/isolate.cc +883 -0
- data/vendor/v8/src/isolate.h +1304 -0
- data/vendor/v8/src/json.js +10 -10
- data/vendor/v8/src/jsregexp.cc +111 -80
- data/vendor/v8/src/jsregexp.h +6 -7
- data/vendor/v8/src/jump-target-heavy.cc +5 -8
- data/vendor/v8/src/jump-target-heavy.h +0 -6
- data/vendor/v8/src/jump-target-inl.h +1 -1
- data/vendor/v8/src/jump-target-light.cc +3 -3
- data/vendor/v8/src/lithium-allocator-inl.h +2 -0
- data/vendor/v8/src/lithium-allocator.cc +42 -30
- data/vendor/v8/src/lithium-allocator.h +8 -22
- data/vendor/v8/src/lithium.cc +1 -0
- data/vendor/v8/src/liveedit.cc +141 -99
- data/vendor/v8/src/liveedit.h +7 -2
- data/vendor/v8/src/liveobjectlist-inl.h +90 -0
- data/vendor/v8/src/liveobjectlist.cc +2537 -1
- data/vendor/v8/src/liveobjectlist.h +245 -35
- data/vendor/v8/src/log-utils.cc +122 -35
- data/vendor/v8/src/log-utils.h +33 -36
- data/vendor/v8/src/log.cc +299 -241
- data/vendor/v8/src/log.h +177 -110
- data/vendor/v8/src/mark-compact.cc +612 -470
- data/vendor/v8/src/mark-compact.h +153 -80
- data/vendor/v8/src/messages.cc +16 -14
- data/vendor/v8/src/messages.js +30 -7
- data/vendor/v8/src/mips/assembler-mips-inl.h +155 -35
- data/vendor/v8/src/mips/assembler-mips.cc +1093 -219
- data/vendor/v8/src/mips/assembler-mips.h +552 -153
- data/vendor/v8/src/mips/builtins-mips.cc +43 -100
- data/vendor/v8/src/mips/code-stubs-mips.cc +752 -0
- data/vendor/v8/src/mips/code-stubs-mips.h +511 -0
- data/vendor/v8/src/mips/codegen-mips-inl.h +8 -14
- data/vendor/v8/src/mips/codegen-mips.cc +672 -896
- data/vendor/v8/src/mips/codegen-mips.h +271 -69
- data/vendor/v8/src/mips/constants-mips.cc +44 -20
- data/vendor/v8/src/mips/constants-mips.h +238 -40
- data/vendor/v8/src/mips/cpu-mips.cc +20 -3
- data/vendor/v8/src/mips/debug-mips.cc +35 -7
- data/vendor/v8/src/mips/deoptimizer-mips.cc +91 -0
- data/vendor/v8/src/mips/disasm-mips.cc +329 -93
- data/vendor/v8/src/mips/frames-mips.cc +2 -50
- data/vendor/v8/src/mips/frames-mips.h +24 -9
- data/vendor/v8/src/mips/full-codegen-mips.cc +473 -23
- data/vendor/v8/src/mips/ic-mips.cc +81 -45
- data/vendor/v8/src/mips/jump-target-mips.cc +11 -106
- data/vendor/v8/src/mips/lithium-codegen-mips.h +65 -0
- data/vendor/v8/src/mips/lithium-mips.h +304 -0
- data/vendor/v8/src/mips/macro-assembler-mips.cc +2391 -390
- data/vendor/v8/src/mips/macro-assembler-mips.h +718 -121
- data/vendor/v8/src/mips/regexp-macro-assembler-mips.cc +478 -0
- data/vendor/v8/src/mips/regexp-macro-assembler-mips.h +250 -0
- data/vendor/v8/src/mips/register-allocator-mips-inl.h +0 -3
- data/vendor/v8/src/mips/register-allocator-mips.h +3 -2
- data/vendor/v8/src/mips/simulator-mips.cc +1009 -221
- data/vendor/v8/src/mips/simulator-mips.h +119 -36
- data/vendor/v8/src/mips/stub-cache-mips.cc +331 -148
- data/vendor/v8/src/mips/{fast-codegen-mips.cc → virtual-frame-mips-inl.h} +11 -30
- data/vendor/v8/src/mips/virtual-frame-mips.cc +137 -149
- data/vendor/v8/src/mips/virtual-frame-mips.h +294 -312
- data/vendor/v8/src/mirror-debugger.js +9 -8
- data/vendor/v8/src/mksnapshot.cc +2 -2
- data/vendor/v8/src/objects-debug.cc +16 -16
- data/vendor/v8/src/objects-inl.h +421 -195
- data/vendor/v8/src/objects-printer.cc +7 -7
- data/vendor/v8/src/objects-visiting.cc +1 -1
- data/vendor/v8/src/objects-visiting.h +33 -12
- data/vendor/v8/src/objects.cc +935 -658
- data/vendor/v8/src/objects.h +234 -139
- data/vendor/v8/src/parser.cc +484 -439
- data/vendor/v8/src/parser.h +35 -14
- data/vendor/v8/src/platform-cygwin.cc +173 -107
- data/vendor/v8/src/platform-freebsd.cc +224 -72
- data/vendor/v8/src/platform-linux.cc +234 -95
- data/vendor/v8/src/platform-macos.cc +215 -82
- data/vendor/v8/src/platform-nullos.cc +9 -3
- data/vendor/v8/src/platform-openbsd.cc +22 -7
- data/vendor/v8/src/platform-posix.cc +30 -5
- data/vendor/v8/src/platform-solaris.cc +120 -38
- data/vendor/v8/src/platform-tls-mac.h +62 -0
- data/vendor/v8/src/platform-tls-win32.h +62 -0
- data/vendor/v8/src/platform-tls.h +50 -0
- data/vendor/v8/src/platform-win32.cc +195 -97
- data/vendor/v8/src/platform.h +72 -15
- data/vendor/v8/src/preparse-data.cc +2 -0
- data/vendor/v8/src/preparser-api.cc +8 -2
- data/vendor/v8/src/preparser.cc +1 -1
- data/vendor/v8/src/prettyprinter.cc +43 -52
- data/vendor/v8/src/prettyprinter.h +1 -1
- data/vendor/v8/src/profile-generator-inl.h +0 -28
- data/vendor/v8/src/profile-generator.cc +942 -685
- data/vendor/v8/src/profile-generator.h +210 -176
- data/vendor/v8/src/property.cc +6 -0
- data/vendor/v8/src/property.h +14 -3
- data/vendor/v8/src/regexp-macro-assembler-irregexp.cc +1 -1
- data/vendor/v8/src/regexp-macro-assembler.cc +28 -19
- data/vendor/v8/src/regexp-macro-assembler.h +11 -6
- data/vendor/v8/src/regexp-stack.cc +18 -10
- data/vendor/v8/src/regexp-stack.h +45 -21
- data/vendor/v8/src/regexp.js +3 -3
- data/vendor/v8/src/register-allocator-inl.h +3 -3
- data/vendor/v8/src/register-allocator.cc +1 -7
- data/vendor/v8/src/register-allocator.h +5 -15
- data/vendor/v8/src/rewriter.cc +2 -1
- data/vendor/v8/src/runtime-profiler.cc +158 -128
- data/vendor/v8/src/runtime-profiler.h +131 -15
- data/vendor/v8/src/runtime.cc +2409 -1692
- data/vendor/v8/src/runtime.h +93 -17
- data/vendor/v8/src/safepoint-table.cc +3 -0
- data/vendor/v8/src/safepoint-table.h +9 -3
- data/vendor/v8/src/scanner-base.cc +21 -28
- data/vendor/v8/src/scanner-base.h +22 -11
- data/vendor/v8/src/scanner.cc +3 -5
- data/vendor/v8/src/scanner.h +4 -2
- data/vendor/v8/src/scopeinfo.cc +11 -16
- data/vendor/v8/src/scopeinfo.h +26 -15
- data/vendor/v8/src/scopes.cc +67 -37
- data/vendor/v8/src/scopes.h +26 -12
- data/vendor/v8/src/serialize.cc +193 -154
- data/vendor/v8/src/serialize.h +41 -36
- data/vendor/v8/src/small-pointer-list.h +163 -0
- data/vendor/v8/src/snapshot-common.cc +1 -1
- data/vendor/v8/src/snapshot.h +3 -1
- data/vendor/v8/src/spaces-inl.h +30 -25
- data/vendor/v8/src/spaces.cc +263 -370
- data/vendor/v8/src/spaces.h +178 -166
- data/vendor/v8/src/string-search.cc +4 -3
- data/vendor/v8/src/string-search.h +21 -20
- data/vendor/v8/src/string-stream.cc +32 -24
- data/vendor/v8/src/string.js +7 -7
- data/vendor/v8/src/stub-cache.cc +324 -248
- data/vendor/v8/src/stub-cache.h +181 -155
- data/vendor/v8/src/token.cc +3 -3
- data/vendor/v8/src/token.h +3 -3
- data/vendor/v8/src/top.cc +218 -390
- data/vendor/v8/src/type-info.cc +98 -32
- data/vendor/v8/src/type-info.h +10 -3
- data/vendor/v8/src/unicode.cc +1 -1
- data/vendor/v8/src/unicode.h +1 -1
- data/vendor/v8/src/utils.h +3 -0
- data/vendor/v8/src/v8-counters.cc +18 -11
- data/vendor/v8/src/v8-counters.h +34 -13
- data/vendor/v8/src/v8.cc +66 -121
- data/vendor/v8/src/v8.h +7 -4
- data/vendor/v8/src/v8globals.h +18 -12
- data/vendor/v8/src/{memory.h → v8memory.h} +0 -0
- data/vendor/v8/src/v8natives.js +59 -18
- data/vendor/v8/src/v8threads.cc +127 -114
- data/vendor/v8/src/v8threads.h +42 -35
- data/vendor/v8/src/v8utils.h +2 -39
- data/vendor/v8/src/variables.h +1 -1
- data/vendor/v8/src/version.cc +26 -5
- data/vendor/v8/src/version.h +4 -0
- data/vendor/v8/src/virtual-frame-heavy-inl.h +2 -4
- data/vendor/v8/src/virtual-frame-light-inl.h +5 -4
- data/vendor/v8/src/vm-state-inl.h +21 -17
- data/vendor/v8/src/vm-state.h +7 -5
- data/vendor/v8/src/win32-headers.h +1 -0
- data/vendor/v8/src/x64/assembler-x64-inl.h +12 -11
- data/vendor/v8/src/x64/assembler-x64.cc +80 -40
- data/vendor/v8/src/x64/assembler-x64.h +67 -17
- data/vendor/v8/src/x64/builtins-x64.cc +34 -33
- data/vendor/v8/src/x64/code-stubs-x64.cc +636 -377
- data/vendor/v8/src/x64/code-stubs-x64.h +14 -48
- data/vendor/v8/src/x64/codegen-x64-inl.h +1 -1
- data/vendor/v8/src/x64/codegen-x64.cc +158 -136
- data/vendor/v8/src/x64/codegen-x64.h +4 -1
- data/vendor/v8/src/x64/cpu-x64.cc +7 -5
- data/vendor/v8/src/x64/debug-x64.cc +8 -6
- data/vendor/v8/src/x64/deoptimizer-x64.cc +195 -20
- data/vendor/v8/src/x64/disasm-x64.cc +42 -23
- data/vendor/v8/src/x64/frames-x64.cc +1 -1
- data/vendor/v8/src/x64/frames-x64.h +2 -2
- data/vendor/v8/src/x64/full-codegen-x64.cc +780 -218
- data/vendor/v8/src/x64/ic-x64.cc +77 -79
- data/vendor/v8/src/x64/jump-target-x64.cc +1 -1
- data/vendor/v8/src/x64/lithium-codegen-x64.cc +698 -181
- data/vendor/v8/src/x64/lithium-codegen-x64.h +31 -6
- data/vendor/v8/src/x64/lithium-x64.cc +136 -54
- data/vendor/v8/src/x64/lithium-x64.h +142 -51
- data/vendor/v8/src/x64/macro-assembler-x64.cc +456 -187
- data/vendor/v8/src/x64/macro-assembler-x64.h +166 -34
- data/vendor/v8/src/x64/regexp-macro-assembler-x64.cc +44 -28
- data/vendor/v8/src/x64/regexp-macro-assembler-x64.h +8 -4
- data/vendor/v8/src/x64/register-allocator-x64-inl.h +3 -3
- data/vendor/v8/src/x64/register-allocator-x64.cc +12 -8
- data/vendor/v8/src/x64/simulator-x64.h +5 -5
- data/vendor/v8/src/x64/stub-cache-x64.cc +299 -344
- data/vendor/v8/src/x64/virtual-frame-x64.cc +37 -13
- data/vendor/v8/src/x64/virtual-frame-x64.h +13 -7
- data/vendor/v8/src/zone-inl.h +49 -3
- data/vendor/v8/src/zone.cc +42 -41
- data/vendor/v8/src/zone.h +37 -34
- data/vendor/v8/test/benchmarks/testcfg.py +100 -0
- data/vendor/v8/test/cctest/SConscript +5 -4
- data/vendor/v8/test/cctest/cctest.h +3 -2
- data/vendor/v8/test/cctest/cctest.status +6 -11
- data/vendor/v8/test/cctest/test-accessors.cc +3 -3
- data/vendor/v8/test/cctest/test-alloc.cc +39 -33
- data/vendor/v8/test/cctest/test-api.cc +1092 -205
- data/vendor/v8/test/cctest/test-assembler-arm.cc +39 -25
- data/vendor/v8/test/cctest/test-assembler-ia32.cc +36 -37
- data/vendor/v8/test/cctest/test-assembler-mips.cc +1098 -40
- data/vendor/v8/test/cctest/test-assembler-x64.cc +32 -25
- data/vendor/v8/test/cctest/test-ast.cc +1 -0
- data/vendor/v8/test/cctest/test-circular-queue.cc +8 -5
- data/vendor/v8/test/cctest/test-compiler.cc +24 -24
- data/vendor/v8/test/cctest/test-cpu-profiler.cc +140 -5
- data/vendor/v8/test/cctest/test-dataflow.cc +1 -0
- data/vendor/v8/test/cctest/test-debug.cc +136 -77
- data/vendor/v8/test/cctest/test-decls.cc +1 -1
- data/vendor/v8/test/cctest/test-deoptimization.cc +25 -24
- data/vendor/v8/test/cctest/test-disasm-arm.cc +9 -4
- data/vendor/v8/test/cctest/test-disasm-ia32.cc +10 -8
- data/vendor/v8/test/cctest/test-func-name-inference.cc +10 -4
- data/vendor/v8/test/cctest/test-heap-profiler.cc +226 -164
- data/vendor/v8/test/cctest/test-heap.cc +240 -217
- data/vendor/v8/test/cctest/test-liveedit.cc +1 -0
- data/vendor/v8/test/cctest/test-log-stack-tracer.cc +18 -20
- data/vendor/v8/test/cctest/test-log.cc +114 -108
- data/vendor/v8/test/cctest/test-macro-assembler-x64.cc +247 -177
- data/vendor/v8/test/cctest/test-mark-compact.cc +129 -90
- data/vendor/v8/test/cctest/test-parsing.cc +15 -14
- data/vendor/v8/test/cctest/test-platform-linux.cc +1 -0
- data/vendor/v8/test/cctest/test-platform-tls.cc +66 -0
- data/vendor/v8/test/cctest/test-platform-win32.cc +1 -0
- data/vendor/v8/test/cctest/test-profile-generator.cc +1 -1
- data/vendor/v8/test/cctest/test-regexp.cc +53 -41
- data/vendor/v8/test/cctest/test-reloc-info.cc +18 -11
- data/vendor/v8/test/cctest/test-serialize.cc +44 -43
- data/vendor/v8/test/cctest/test-sockets.cc +8 -3
- data/vendor/v8/test/cctest/test-spaces.cc +47 -29
- data/vendor/v8/test/cctest/test-strings.cc +20 -20
- data/vendor/v8/test/cctest/test-thread-termination.cc +8 -3
- data/vendor/v8/test/cctest/test-threads.cc +5 -3
- data/vendor/v8/test/cctest/test-utils.cc +5 -4
- data/vendor/v8/test/cctest/testcfg.py +7 -3
- data/vendor/v8/test/es5conform/es5conform.status +2 -77
- data/vendor/v8/test/es5conform/testcfg.py +1 -1
- data/vendor/v8/test/message/testcfg.py +1 -1
- data/vendor/v8/test/mjsunit/accessors-on-global-object.js +3 -3
- data/vendor/v8/test/mjsunit/array-concat.js +43 -1
- data/vendor/v8/test/mjsunit/array-join.js +25 -0
- data/vendor/v8/test/mjsunit/bitops-info.js +7 -1
- data/vendor/v8/test/mjsunit/compiler/array-length.js +2 -2
- data/vendor/v8/test/mjsunit/compiler/global-accessors.js +47 -0
- data/vendor/v8/test/mjsunit/compiler/pic.js +1 -1
- data/vendor/v8/test/mjsunit/compiler/regress-loadfield.js +65 -0
- data/vendor/v8/test/mjsunit/math-sqrt.js +5 -1
- data/vendor/v8/test/mjsunit/mjsunit.js +59 -8
- data/vendor/v8/test/mjsunit/mjsunit.status +0 -12
- data/vendor/v8/test/mjsunit/mul-exhaustive.js +129 -11
- data/vendor/v8/test/mjsunit/negate-zero.js +1 -1
- data/vendor/v8/test/mjsunit/object-freeze.js +5 -13
- data/vendor/v8/test/mjsunit/object-prevent-extensions.js +9 -50
- data/vendor/v8/test/mjsunit/object-seal.js +4 -13
- data/vendor/v8/test/mjsunit/override-eval-with-non-function.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-1145.js +54 -0
- data/vendor/v8/test/mjsunit/regress/regress-1172-bis.js +37 -0
- data/vendor/v8/test/mjsunit/regress/regress-1181.js +54 -0
- data/vendor/v8/test/mjsunit/regress/regress-1207.js +35 -0
- data/vendor/v8/test/mjsunit/regress/regress-1209.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-1210.js +48 -0
- data/vendor/v8/test/mjsunit/regress/regress-1213.js +43 -0
- data/vendor/v8/test/mjsunit/regress/regress-1218.js +29 -0
- data/vendor/v8/test/mjsunit/regress/regress-1229.js +79 -0
- data/vendor/v8/test/mjsunit/regress/regress-1233.js +47 -0
- data/vendor/v8/test/mjsunit/regress/regress-1236.js +34 -0
- data/vendor/v8/test/mjsunit/regress/regress-1237.js +36 -0
- data/vendor/v8/test/mjsunit/regress/regress-1240.js +39 -0
- data/vendor/v8/test/mjsunit/regress/regress-1257.js +58 -0
- data/vendor/v8/test/mjsunit/regress/regress-1278.js +69 -0
- data/vendor/v8/test/mjsunit/regress/regress-create-exception.js +1 -0
- data/vendor/v8/test/mjsunit/regress/regress-lazy-deopt-reloc.js +52 -0
- data/vendor/v8/test/mjsunit/sin-cos.js +15 -10
- data/vendor/v8/test/mjsunit/smi-negative-zero.js +2 -2
- data/vendor/v8/test/mjsunit/str-to-num.js +1 -1
- data/vendor/v8/test/mjsunit/strict-mode.js +435 -0
- data/vendor/v8/test/mjsunit/testcfg.py +23 -6
- data/vendor/v8/test/mozilla/mozilla.status +0 -2
- data/vendor/v8/test/mozilla/testcfg.py +1 -1
- data/vendor/v8/test/preparser/empty.js +28 -0
- data/vendor/v8/test/preparser/functions-only.js +38 -0
- data/vendor/v8/test/preparser/non-alphanum.js +34 -0
- data/vendor/v8/test/preparser/symbols-only.js +49 -0
- data/vendor/v8/test/preparser/testcfg.py +90 -0
- data/vendor/v8/test/sputnik/testcfg.py +1 -1
- data/vendor/v8/test/test262/README +16 -0
- data/vendor/v8/test/test262/harness-adapt.js +80 -0
- data/vendor/v8/test/test262/test262.status +1506 -0
- data/vendor/v8/test/test262/testcfg.py +123 -0
- data/vendor/v8/tools/freebsd-tick-processor +10 -0
- data/vendor/v8/tools/gyp/v8.gyp +8 -33
- data/vendor/v8/tools/linux-tick-processor +5 -3
- data/vendor/v8/tools/test.py +37 -14
- data/vendor/v8/tools/tickprocessor.js +22 -8
- data/vendor/v8/tools/visual_studio/v8_base.vcproj +13 -1
- data/vendor/v8/tools/visual_studio/v8_base_arm.vcproj +5 -1
- data/vendor/v8/tools/visual_studio/v8_base_x64.vcproj +5 -1
- data/vendor/v8/tools/visual_studio/x64.vsprops +1 -0
- metadata +1495 -1341
- data/ext/extconf.rb +0 -22
- data/ext/mustang.cpp +0 -58
- data/vendor/v8/src/top.h +0 -608
@@ -1,4 +1,4 @@
|
|
1
|
-
// Copyright
|
1
|
+
// Copyright 2011 the V8 project authors. All rights reserved.
|
2
2
|
// Redistribution and use in source and binary forms, with or without
|
3
3
|
// modification, are permitted provided that the following conditions are
|
4
4
|
// met:
|
@@ -113,7 +113,7 @@ void VirtualFrame::AllocateStackSlots() {
|
|
113
113
|
// them later. First sync everything above the stack pointer so we can
|
114
114
|
// use pushes to allocate and initialize the locals.
|
115
115
|
SyncRange(stack_pointer_ + 1, element_count() - 1);
|
116
|
-
Handle<Object> undefined =
|
116
|
+
Handle<Object> undefined = FACTORY->undefined_value();
|
117
117
|
FrameElement initial_value =
|
118
118
|
FrameElement::ConstantElement(undefined, FrameElement::SYNCED);
|
119
119
|
if (count < kLocalVarBound) {
|
@@ -274,6 +274,24 @@ void VirtualFrame::Push(Expression* expr) {
|
|
274
274
|
}
|
275
275
|
|
276
276
|
|
277
|
+
void VirtualFrame::Push(Handle<Object> value) {
|
278
|
+
if (ConstantPoolOverflowed()) {
|
279
|
+
Result temp = cgen()->allocator()->Allocate();
|
280
|
+
ASSERT(temp.is_valid());
|
281
|
+
if (value->IsSmi()) {
|
282
|
+
__ Move(temp.reg(), Smi::cast(*value));
|
283
|
+
} else {
|
284
|
+
__ movq(temp.reg(), value, RelocInfo::EMBEDDED_OBJECT);
|
285
|
+
}
|
286
|
+
Push(&temp);
|
287
|
+
} else {
|
288
|
+
FrameElement element =
|
289
|
+
FrameElement::ConstantElement(value, FrameElement::NOT_SYNCED);
|
290
|
+
elements_.Add(element);
|
291
|
+
}
|
292
|
+
}
|
293
|
+
|
294
|
+
|
277
295
|
void VirtualFrame::Drop(int count) {
|
278
296
|
ASSERT(count >= 0);
|
279
297
|
ASSERT(height() >= count);
|
@@ -1001,7 +1019,7 @@ void VirtualFrame::SyncRange(int begin, int end) {
|
|
1001
1019
|
//------------------------------------------------------------------------------
|
1002
1020
|
// Virtual frame stub and IC calling functions.
|
1003
1021
|
|
1004
|
-
Result VirtualFrame::CallRuntime(Runtime::Function* f, int arg_count) {
|
1022
|
+
Result VirtualFrame::CallRuntime(const Runtime::Function* f, int arg_count) {
|
1005
1023
|
PrepareForCall(arg_count, arg_count);
|
1006
1024
|
ASSERT(cgen()->HasValidEntryRegisters());
|
1007
1025
|
__ CallRuntime(f, arg_count);
|
@@ -1097,7 +1115,8 @@ void VirtualFrame::MoveResultsToRegisters(Result* a,
|
|
1097
1115
|
Result VirtualFrame::CallLoadIC(RelocInfo::Mode mode) {
|
1098
1116
|
// Name and receiver are on the top of the frame. Both are dropped.
|
1099
1117
|
// The IC expects name in rcx and receiver in rax.
|
1100
|
-
Handle<Code> ic(
|
1118
|
+
Handle<Code> ic(Isolate::Current()->builtins()->builtin(
|
1119
|
+
Builtins::kLoadIC_Initialize));
|
1101
1120
|
Result name = Pop();
|
1102
1121
|
Result receiver = Pop();
|
1103
1122
|
PrepareForCall(0, 0);
|
@@ -1114,7 +1133,8 @@ Result VirtualFrame::CallKeyedLoadIC(RelocInfo::Mode mode) {
|
|
1114
1133
|
PrepareForCall(0, 0);
|
1115
1134
|
MoveResultsToRegisters(&key, &receiver, rax, rdx);
|
1116
1135
|
|
1117
|
-
Handle<Code> ic(
|
1136
|
+
Handle<Code> ic(Isolate::Current()->builtins()->builtin(
|
1137
|
+
Builtins::kKeyedLoadIC_Initialize));
|
1118
1138
|
return RawCallCodeObject(ic, mode);
|
1119
1139
|
}
|
1120
1140
|
|
@@ -1124,9 +1144,9 @@ Result VirtualFrame::CallStoreIC(Handle<String> name,
|
|
1124
1144
|
StrictModeFlag strict_mode) {
|
1125
1145
|
// Value and (if not contextual) receiver are on top of the frame.
|
1126
1146
|
// The IC expects name in rcx, value in rax, and receiver in rdx.
|
1127
|
-
Handle<Code> ic(
|
1128
|
-
? Builtins::
|
1129
|
-
|
1147
|
+
Handle<Code> ic(Isolate::Current()->builtins()->builtin(
|
1148
|
+
(strict_mode == kStrictMode) ? Builtins::kStoreIC_Initialize_Strict
|
1149
|
+
: Builtins::kStoreIC_Initialize));
|
1130
1150
|
Result value = Pop();
|
1131
1151
|
RelocInfo::Mode mode;
|
1132
1152
|
if (is_contextual) {
|
@@ -1146,7 +1166,7 @@ Result VirtualFrame::CallStoreIC(Handle<String> name,
|
|
1146
1166
|
}
|
1147
1167
|
|
1148
1168
|
|
1149
|
-
Result VirtualFrame::CallKeyedStoreIC() {
|
1169
|
+
Result VirtualFrame::CallKeyedStoreIC(StrictModeFlag strict_mode) {
|
1150
1170
|
// Value, key, and receiver are on the top of the frame. The IC
|
1151
1171
|
// expects value in rax, key in rcx, and receiver in rdx.
|
1152
1172
|
Result value = Pop();
|
@@ -1190,7 +1210,9 @@ Result VirtualFrame::CallKeyedStoreIC() {
|
|
1190
1210
|
receiver.Unuse();
|
1191
1211
|
}
|
1192
1212
|
|
1193
|
-
Handle<Code> ic(
|
1213
|
+
Handle<Code> ic(Isolate::Current()->builtins()->builtin(
|
1214
|
+
(strict_mode == kStrictMode) ? Builtins::kKeyedStoreIC_Initialize_Strict
|
1215
|
+
: Builtins::kKeyedStoreIC_Initialize));
|
1194
1216
|
return RawCallCodeObject(ic, RelocInfo::CODE_TARGET);
|
1195
1217
|
}
|
1196
1218
|
|
@@ -1202,7 +1224,8 @@ Result VirtualFrame::CallCallIC(RelocInfo::Mode mode,
|
|
1202
1224
|
// and dropped by the call. The IC expects the name in rcx and the rest
|
1203
1225
|
// on the stack, and drops them all.
|
1204
1226
|
InLoopFlag in_loop = loop_nesting > 0 ? IN_LOOP : NOT_IN_LOOP;
|
1205
|
-
Handle<Code> ic =
|
1227
|
+
Handle<Code> ic =
|
1228
|
+
ISOLATE->stub_cache()->ComputeCallInitialize(arg_count, in_loop);
|
1206
1229
|
Result name = Pop();
|
1207
1230
|
// Spill args, receiver, and function. The call will drop args and
|
1208
1231
|
// receiver.
|
@@ -1221,7 +1244,7 @@ Result VirtualFrame::CallKeyedCallIC(RelocInfo::Mode mode,
|
|
1221
1244
|
// on the stack, and drops them all.
|
1222
1245
|
InLoopFlag in_loop = loop_nesting > 0 ? IN_LOOP : NOT_IN_LOOP;
|
1223
1246
|
Handle<Code> ic =
|
1224
|
-
|
1247
|
+
ISOLATE->stub_cache()->ComputeKeyedCallInitialize(arg_count, in_loop);
|
1225
1248
|
Result name = Pop();
|
1226
1249
|
// Spill args, receiver, and function. The call will drop args and
|
1227
1250
|
// receiver.
|
@@ -1236,7 +1259,8 @@ Result VirtualFrame::CallConstructor(int arg_count) {
|
|
1236
1259
|
// Arguments, receiver, and function are on top of the frame. The
|
1237
1260
|
// IC expects arg count in rax, function in rdi, and the arguments
|
1238
1261
|
// and receiver on the stack.
|
1239
|
-
Handle<Code> ic(
|
1262
|
+
Handle<Code> ic(Isolate::Current()->builtins()->builtin(
|
1263
|
+
Builtins::kJSConstructCall));
|
1240
1264
|
// Duplicate the function before preparing the frame.
|
1241
1265
|
PushElementAt(arg_count);
|
1242
1266
|
Result function = Pop();
|
@@ -1,4 +1,4 @@
|
|
1
|
-
// Copyright
|
1
|
+
// Copyright 2011 the V8 project authors. All rights reserved.
|
2
2
|
// Redistribution and use in source and binary forms, with or without
|
3
3
|
// modification, are permitted provided that the following conditions are
|
4
4
|
// met:
|
@@ -67,7 +67,9 @@ class VirtualFrame : public ZoneObject {
|
|
67
67
|
private:
|
68
68
|
bool previous_state_;
|
69
69
|
|
70
|
-
CodeGenerator* cgen() {
|
70
|
+
CodeGenerator* cgen() {
|
71
|
+
return CodeGeneratorScope::Current(Isolate::Current());
|
72
|
+
}
|
71
73
|
};
|
72
74
|
|
73
75
|
// An illegal index into the virtual frame.
|
@@ -79,7 +81,10 @@ class VirtualFrame : public ZoneObject {
|
|
79
81
|
// Construct a virtual frame as a clone of an existing one.
|
80
82
|
explicit inline VirtualFrame(VirtualFrame* original);
|
81
83
|
|
82
|
-
CodeGenerator* cgen() {
|
84
|
+
CodeGenerator* cgen() {
|
85
|
+
return CodeGeneratorScope::Current(Isolate::Current());
|
86
|
+
}
|
87
|
+
|
83
88
|
MacroAssembler* masm() { return cgen()->masm(); }
|
84
89
|
|
85
90
|
// Create a duplicate of an existing valid frame element.
|
@@ -315,7 +320,7 @@ class VirtualFrame : public ZoneObject {
|
|
315
320
|
|
316
321
|
// Call runtime given the number of arguments expected on (and
|
317
322
|
// removed from) the stack.
|
318
|
-
Result CallRuntime(Runtime::Function* f, int arg_count);
|
323
|
+
Result CallRuntime(const Runtime::Function* f, int arg_count);
|
319
324
|
Result CallRuntime(Runtime::FunctionId id, int arg_count);
|
320
325
|
|
321
326
|
#ifdef ENABLE_DEBUGGER_SUPPORT
|
@@ -342,8 +347,7 @@ class VirtualFrame : public ZoneObject {
|
|
342
347
|
StrictModeFlag strict_mode);
|
343
348
|
|
344
349
|
// Call keyed store IC. Value, key, and receiver are found on top
|
345
|
-
|
346
|
-
Result CallKeyedStoreIC();
|
350
|
+
Result CallKeyedStoreIC(StrictModeFlag strict_mode);
|
347
351
|
|
348
352
|
// Call call IC. Function name, arguments, and receiver are found on top
|
349
353
|
// of the frame and dropped by the call.
|
@@ -400,9 +404,11 @@ class VirtualFrame : public ZoneObject {
|
|
400
404
|
// Uses kScratchRegister, emits appropriate relocation info.
|
401
405
|
void EmitPush(Handle<Object> value);
|
402
406
|
|
407
|
+
inline bool ConstantPoolOverflowed();
|
408
|
+
|
403
409
|
// Push an element on the virtual frame.
|
410
|
+
void Push(Handle<Object> value);
|
404
411
|
inline void Push(Register reg, TypeInfo info = TypeInfo::Unknown());
|
405
|
-
inline void Push(Handle<Object> value);
|
406
412
|
inline void Push(Smi* value);
|
407
413
|
|
408
414
|
// Pushing a result invalidates it (its contents become owned by the
|
data/vendor/v8/src/zone-inl.h
CHANGED
@@ -28,6 +28,7 @@
|
|
28
28
|
#ifndef V8_ZONE_INL_H_
|
29
29
|
#define V8_ZONE_INL_H_
|
30
30
|
|
31
|
+
#include "isolate.h"
|
31
32
|
#include "zone.h"
|
32
33
|
#include "v8-counters.h"
|
33
34
|
|
@@ -35,8 +36,19 @@ namespace v8 {
|
|
35
36
|
namespace internal {
|
36
37
|
|
37
38
|
|
39
|
+
AssertNoZoneAllocation::AssertNoZoneAllocation()
|
40
|
+
: prev_(Isolate::Current()->zone_allow_allocation()) {
|
41
|
+
Isolate::Current()->set_zone_allow_allocation(false);
|
42
|
+
}
|
43
|
+
|
44
|
+
|
45
|
+
AssertNoZoneAllocation::~AssertNoZoneAllocation() {
|
46
|
+
Isolate::Current()->set_zone_allow_allocation(prev_);
|
47
|
+
}
|
48
|
+
|
49
|
+
|
38
50
|
inline void* Zone::New(int size) {
|
39
|
-
ASSERT(
|
51
|
+
ASSERT(Isolate::Current()->zone_allow_allocation());
|
40
52
|
ASSERT(ZoneScope::nesting() > 0);
|
41
53
|
// Round up the requested size to fit the alignment.
|
42
54
|
size = RoundUp(size, kAlignment);
|
@@ -54,7 +66,7 @@ inline void* Zone::New(int size) {
|
|
54
66
|
|
55
67
|
template <typename T>
|
56
68
|
T* Zone::NewArray(int length) {
|
57
|
-
return static_cast<T*>(
|
69
|
+
return static_cast<T*>(New(length * sizeof(T)));
|
58
70
|
}
|
59
71
|
|
60
72
|
|
@@ -65,7 +77,7 @@ bool Zone::excess_allocation() {
|
|
65
77
|
|
66
78
|
void Zone::adjust_segment_bytes_allocated(int delta) {
|
67
79
|
segment_bytes_allocated_ += delta;
|
68
|
-
|
80
|
+
isolate_->counters()->zone_segment_bytes()->Set(segment_bytes_allocated_);
|
69
81
|
}
|
70
82
|
|
71
83
|
|
@@ -78,6 +90,40 @@ ZoneSplayTree<Config>::~ZoneSplayTree() {
|
|
78
90
|
}
|
79
91
|
|
80
92
|
|
93
|
+
// TODO(isolates): for performance reasons, this should be replaced with a new
|
94
|
+
// operator that takes the zone in which the object should be
|
95
|
+
// allocated.
|
96
|
+
void* ZoneObject::operator new(size_t size) {
|
97
|
+
return ZONE->New(static_cast<int>(size));
|
98
|
+
}
|
99
|
+
|
100
|
+
void* ZoneObject::operator new(size_t size, Zone* zone) {
|
101
|
+
return zone->New(static_cast<int>(size));
|
102
|
+
}
|
103
|
+
|
104
|
+
|
105
|
+
inline void* ZoneListAllocationPolicy::New(int size) {
|
106
|
+
return ZONE->New(size);
|
107
|
+
}
|
108
|
+
|
109
|
+
|
110
|
+
ZoneScope::ZoneScope(ZoneScopeMode mode)
|
111
|
+
: isolate_(Isolate::Current()),
|
112
|
+
mode_(mode) {
|
113
|
+
isolate_->zone()->scope_nesting_++;
|
114
|
+
}
|
115
|
+
|
116
|
+
|
117
|
+
bool ZoneScope::ShouldDeleteOnExit() {
|
118
|
+
return isolate_->zone()->scope_nesting_ == 1 && mode_ == DELETE_ON_EXIT;
|
119
|
+
}
|
120
|
+
|
121
|
+
|
122
|
+
int ZoneScope::nesting() {
|
123
|
+
return Isolate::Current()->zone()->scope_nesting_;
|
124
|
+
}
|
125
|
+
|
126
|
+
|
81
127
|
} } // namespace v8::internal
|
82
128
|
|
83
129
|
#endif // V8_ZONE_INL_H_
|
data/vendor/v8/src/zone.cc
CHANGED
@@ -34,20 +34,28 @@ namespace v8 {
|
|
34
34
|
namespace internal {
|
35
35
|
|
36
36
|
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
37
|
+
Zone::Zone()
|
38
|
+
: zone_excess_limit_(256 * MB),
|
39
|
+
segment_bytes_allocated_(0),
|
40
|
+
position_(0),
|
41
|
+
limit_(0),
|
42
|
+
scope_nesting_(0),
|
43
|
+
segment_head_(NULL) {
|
44
|
+
}
|
41
45
|
unsigned Zone::allocation_size_ = 0;
|
42
46
|
|
43
|
-
bool AssertNoZoneAllocation::allow_allocation_ = true;
|
44
47
|
|
45
|
-
|
48
|
+
ZoneScope::~ZoneScope() {
|
49
|
+
ASSERT_EQ(Isolate::Current(), isolate_);
|
50
|
+
if (ShouldDeleteOnExit()) isolate_->zone()->DeleteAll();
|
51
|
+
isolate_->zone()->scope_nesting_--;
|
52
|
+
}
|
53
|
+
|
46
54
|
|
47
55
|
// Segments represent chunks of memory: They have starting address
|
48
56
|
// (encoded in the this pointer) and a size in bytes. Segments are
|
49
57
|
// chained together forming a LIFO structure with the newest segment
|
50
|
-
// available as
|
58
|
+
// available as segment_head_. Segments are allocated using malloc()
|
51
59
|
// and de-allocated using free().
|
52
60
|
|
53
61
|
class Segment {
|
@@ -61,45 +69,38 @@ class Segment {
|
|
61
69
|
Address start() const { return address(sizeof(Segment)); }
|
62
70
|
Address end() const { return address(size_); }
|
63
71
|
|
64
|
-
static Segment* head() { return head_; }
|
65
|
-
static void set_head(Segment* head) { head_ = head; }
|
66
|
-
|
67
|
-
// Creates a new segment, sets it size, and pushes it to the front
|
68
|
-
// of the segment chain. Returns the new segment.
|
69
|
-
static Segment* New(int size) {
|
70
|
-
Segment* result = reinterpret_cast<Segment*>(Malloced::New(size));
|
71
|
-
Zone::adjust_segment_bytes_allocated(size);
|
72
|
-
if (result != NULL) {
|
73
|
-
result->next_ = head_;
|
74
|
-
result->size_ = size;
|
75
|
-
head_ = result;
|
76
|
-
}
|
77
|
-
return result;
|
78
|
-
}
|
79
|
-
|
80
|
-
// Deletes the given segment. Does not touch the segment chain.
|
81
|
-
static void Delete(Segment* segment, int size) {
|
82
|
-
Zone::adjust_segment_bytes_allocated(-size);
|
83
|
-
Malloced::Delete(segment);
|
84
|
-
}
|
85
|
-
|
86
|
-
static int bytes_allocated() { return bytes_allocated_; }
|
87
|
-
|
88
72
|
private:
|
89
73
|
// Computes the address of the nth byte in this segment.
|
90
74
|
Address address(int n) const {
|
91
75
|
return Address(this) + n;
|
92
76
|
}
|
93
77
|
|
94
|
-
static Segment* head_;
|
95
|
-
static int bytes_allocated_;
|
96
78
|
Segment* next_;
|
97
79
|
int size_;
|
80
|
+
|
81
|
+
friend class Zone;
|
98
82
|
};
|
99
83
|
|
100
84
|
|
101
|
-
|
102
|
-
|
85
|
+
// Creates a new segment, sets it size, and pushes it to the front
|
86
|
+
// of the segment chain. Returns the new segment.
|
87
|
+
Segment* Zone::NewSegment(int size) {
|
88
|
+
Segment* result = reinterpret_cast<Segment*>(Malloced::New(size));
|
89
|
+
adjust_segment_bytes_allocated(size);
|
90
|
+
if (result != NULL) {
|
91
|
+
result->next_ = segment_head_;
|
92
|
+
result->size_ = size;
|
93
|
+
segment_head_ = result;
|
94
|
+
}
|
95
|
+
return result;
|
96
|
+
}
|
97
|
+
|
98
|
+
|
99
|
+
// Deletes the given segment. Does not touch the segment chain.
|
100
|
+
void Zone::DeleteSegment(Segment* segment, int size) {
|
101
|
+
adjust_segment_bytes_allocated(-size);
|
102
|
+
Malloced::Delete(segment);
|
103
|
+
}
|
103
104
|
|
104
105
|
|
105
106
|
void Zone::DeleteAll() {
|
@@ -109,14 +110,14 @@ void Zone::DeleteAll() {
|
|
109
110
|
#endif
|
110
111
|
|
111
112
|
// Find a segment with a suitable size to keep around.
|
112
|
-
Segment* keep =
|
113
|
+
Segment* keep = segment_head_;
|
113
114
|
while (keep != NULL && keep->size() > kMaximumKeptSegmentSize) {
|
114
115
|
keep = keep->next();
|
115
116
|
}
|
116
117
|
|
117
118
|
// Traverse the chained list of segments, zapping (in debug mode)
|
118
119
|
// and freeing every segment except the one we wish to keep.
|
119
|
-
Segment* current =
|
120
|
+
Segment* current = segment_head_;
|
120
121
|
while (current != NULL) {
|
121
122
|
Segment* next = current->next();
|
122
123
|
if (current == keep) {
|
@@ -128,7 +129,7 @@ void Zone::DeleteAll() {
|
|
128
129
|
// Zap the entire current segment (including the header).
|
129
130
|
memset(current, kZapDeadByte, size);
|
130
131
|
#endif
|
131
|
-
|
132
|
+
DeleteSegment(current, size);
|
132
133
|
}
|
133
134
|
current = next;
|
134
135
|
}
|
@@ -150,7 +151,7 @@ void Zone::DeleteAll() {
|
|
150
151
|
}
|
151
152
|
|
152
153
|
// Update the head segment to be the kept segment (if any).
|
153
|
-
|
154
|
+
segment_head_ = keep;
|
154
155
|
}
|
155
156
|
|
156
157
|
|
@@ -164,7 +165,7 @@ Address Zone::NewExpand(int size) {
|
|
164
165
|
// strategy, where we increase the segment size every time we expand
|
165
166
|
// except that we employ a maximum segment size when we delete. This
|
166
167
|
// is to avoid excessive malloc() and free() overhead.
|
167
|
-
Segment* head =
|
168
|
+
Segment* head = segment_head_;
|
168
169
|
int old_size = (head == NULL) ? 0 : head->size();
|
169
170
|
static const int kSegmentOverhead = sizeof(Segment) + kAlignment;
|
170
171
|
int new_size = kSegmentOverhead + size + (old_size << 1);
|
@@ -177,7 +178,7 @@ Address Zone::NewExpand(int size) {
|
|
177
178
|
// requested size.
|
178
179
|
new_size = Max(kSegmentOverhead + size, kMaximumSegmentSize);
|
179
180
|
}
|
180
|
-
Segment* segment =
|
181
|
+
Segment* segment = NewSegment(new_size);
|
181
182
|
if (segment == NULL) {
|
182
183
|
V8::FatalProcessOutOfMemory("Zone");
|
183
184
|
return NULL;
|
data/vendor/v8/src/zone.h
CHANGED
@@ -39,6 +39,7 @@ enum ZoneScopeMode {
|
|
39
39
|
DONT_DELETE_ON_EXIT
|
40
40
|
};
|
41
41
|
|
42
|
+
class Segment;
|
42
43
|
|
43
44
|
// The Zone supports very fast allocation of small chunks of
|
44
45
|
// memory. The chunks cannot be deallocated individually, but instead
|
@@ -57,23 +58,25 @@ class Zone {
|
|
57
58
|
public:
|
58
59
|
// Allocate 'size' bytes of memory in the Zone; expands the Zone by
|
59
60
|
// allocating new segments of memory on demand using malloc().
|
60
|
-
|
61
|
+
inline void* New(int size);
|
61
62
|
|
62
63
|
template <typename T>
|
63
|
-
|
64
|
+
inline T* NewArray(int length);
|
64
65
|
|
65
66
|
// Delete all objects and free all memory allocated in the Zone.
|
66
|
-
|
67
|
+
void DeleteAll();
|
67
68
|
|
68
69
|
// Returns true if more memory has been allocated in zones than
|
69
70
|
// the limit allows.
|
70
|
-
|
71
|
+
inline bool excess_allocation();
|
71
72
|
|
72
|
-
|
73
|
+
inline void adjust_segment_bytes_allocated(int delta);
|
73
74
|
|
74
75
|
static unsigned allocation_size_;
|
75
76
|
|
76
77
|
private:
|
78
|
+
friend class Isolate;
|
79
|
+
friend class ZoneScope;
|
77
80
|
|
78
81
|
// All pointers returned from New() have this alignment.
|
79
82
|
static const int kAlignment = kPointerSize;
|
@@ -88,30 +91,39 @@ class Zone {
|
|
88
91
|
static const int kMaximumKeptSegmentSize = 64 * KB;
|
89
92
|
|
90
93
|
// Report zone excess when allocation exceeds this limit.
|
91
|
-
|
94
|
+
int zone_excess_limit_;
|
92
95
|
|
93
96
|
// The number of bytes allocated in segments. Note that this number
|
94
97
|
// includes memory allocated from the OS but not yet allocated from
|
95
98
|
// the zone.
|
96
|
-
|
97
|
-
|
98
|
-
// The Zone is intentionally a singleton; you should not try to
|
99
|
-
// allocate instances of the class.
|
100
|
-
Zone() { UNREACHABLE(); }
|
99
|
+
int segment_bytes_allocated_;
|
101
100
|
|
101
|
+
// Each isolate gets its own zone.
|
102
|
+
Zone();
|
102
103
|
|
103
104
|
// Expand the Zone to hold at least 'size' more bytes and allocate
|
104
105
|
// the bytes. Returns the address of the newly allocated chunk of
|
105
106
|
// memory in the Zone. Should only be called if there isn't enough
|
106
107
|
// room in the Zone already.
|
107
|
-
|
108
|
+
Address NewExpand(int size);
|
109
|
+
|
110
|
+
// Creates a new segment, sets it size, and pushes it to the front
|
111
|
+
// of the segment chain. Returns the new segment.
|
112
|
+
Segment* NewSegment(int size);
|
108
113
|
|
114
|
+
// Deletes the given segment. Does not touch the segment chain.
|
115
|
+
void DeleteSegment(Segment* segment, int size);
|
109
116
|
|
110
117
|
// The free region in the current (front) segment is represented as
|
111
118
|
// the half-open interval [position, limit). The 'position' variable
|
112
119
|
// is guaranteed to be aligned as dictated by kAlignment.
|
113
|
-
|
114
|
-
|
120
|
+
Address position_;
|
121
|
+
Address limit_;
|
122
|
+
|
123
|
+
int scope_nesting_;
|
124
|
+
|
125
|
+
Segment* segment_head_;
|
126
|
+
Isolate* isolate_;
|
115
127
|
};
|
116
128
|
|
117
129
|
|
@@ -120,7 +132,8 @@ class Zone {
|
|
120
132
|
class ZoneObject {
|
121
133
|
public:
|
122
134
|
// Allocate a new ZoneObject of 'size' bytes in the Zone.
|
123
|
-
void* operator new(size_t size)
|
135
|
+
inline void* operator new(size_t size);
|
136
|
+
inline void* operator new(size_t size, Zone* zone);
|
124
137
|
|
125
138
|
// Ideally, the delete operator should be private instead of
|
126
139
|
// public, but unfortunately the compiler sometimes synthesizes
|
@@ -136,14 +149,10 @@ class ZoneObject {
|
|
136
149
|
|
137
150
|
class AssertNoZoneAllocation {
|
138
151
|
public:
|
139
|
-
AssertNoZoneAllocation()
|
140
|
-
|
141
|
-
}
|
142
|
-
~AssertNoZoneAllocation() { allow_allocation_ = prev_; }
|
143
|
-
static bool allow_allocation() { return allow_allocation_; }
|
152
|
+
inline AssertNoZoneAllocation();
|
153
|
+
inline ~AssertNoZoneAllocation();
|
144
154
|
private:
|
145
155
|
bool prev_;
|
146
|
-
static bool allow_allocation_;
|
147
156
|
};
|
148
157
|
|
149
158
|
|
@@ -153,7 +162,7 @@ class AssertNoZoneAllocation {
|
|
153
162
|
class ZoneListAllocationPolicy {
|
154
163
|
public:
|
155
164
|
// Allocate 'size' bytes of memory in the zone.
|
156
|
-
static void* New(int size)
|
165
|
+
static inline void* New(int size);
|
157
166
|
|
158
167
|
// De-allocation attempts are silently ignored.
|
159
168
|
static void Delete(void* p) { }
|
@@ -189,18 +198,12 @@ typedef ZoneList<Handle<Map> > ZoneMapList;
|
|
189
198
|
// outer-most scope.
|
190
199
|
class ZoneScope BASE_EMBEDDED {
|
191
200
|
public:
|
192
|
-
|
193
|
-
|
194
|
-
}
|
201
|
+
// TODO(isolates): pass isolate pointer here.
|
202
|
+
inline explicit ZoneScope(ZoneScopeMode mode);
|
195
203
|
|
196
|
-
virtual ~ZoneScope()
|
197
|
-
if (ShouldDeleteOnExit()) Zone::DeleteAll();
|
198
|
-
--nesting_;
|
199
|
-
}
|
204
|
+
virtual ~ZoneScope();
|
200
205
|
|
201
|
-
bool ShouldDeleteOnExit()
|
202
|
-
return nesting_ == 1 && mode_ == DELETE_ON_EXIT;
|
203
|
-
}
|
206
|
+
inline bool ShouldDeleteOnExit();
|
204
207
|
|
205
208
|
// For ZoneScopes that do not delete on exit by default, call this
|
206
209
|
// method to request deletion on exit.
|
@@ -208,11 +211,11 @@ class ZoneScope BASE_EMBEDDED {
|
|
208
211
|
mode_ = DELETE_ON_EXIT;
|
209
212
|
}
|
210
213
|
|
211
|
-
static int nesting()
|
214
|
+
inline static int nesting();
|
212
215
|
|
213
216
|
private:
|
217
|
+
Isolate* isolate_;
|
214
218
|
ZoneScopeMode mode_;
|
215
|
-
static int nesting_;
|
216
219
|
};
|
217
220
|
|
218
221
|
|