1. 25 Nov, 2016 1 commit
  2. 24 Nov, 2016 1 commit
  3. 23 Nov, 2016 4 commits
    • gdeepti's avatar
      [wasm] WebAssembly.Memory object can be referenced by multiple Instance objects. · e108f90d
      gdeepti authored
      Add support for WebAssembly.Memory objects to be simultaneously referenced by multiple Instance objects. GrowingMemory should maintain a consistent view of memory across instances.
       - Store a link to instances that share WebAssembly.Memory in the WasmMemoryObject, updated on instantiate.
       - Implement WasmInstanceWrapper as a wrapper around the instance object to keep track of previous/next instances, instance object is stored as a WeakCell that can be garbage collected.
       - MemoryInstanceFinalizer maintains a valid list of instances when an instance is garbage collected.
       - Refactor GrowInstanceMemory to GrowMemoryBuffer that allocates a new buffer, and UncheckedUpdateInstanceMemory that updates memory references for an instance.
      
       R=titzer@chromium.org, mtrofin@chromium.org, bradnelson@chromium.org
      
      Committed: https://crrev.com/30ef8e33f3a199a27ca8512bcee314c9522d03f6
      Committed: https://crrev.com/3c98e339599b068f1ed630afb7601ff942424d31
      Review-Url: https://codereview.chromium.org/2471883003
      Cr-Original-Original-Commit-Position: refs/heads/master@{#41121}
      Cr-Original-Commit-Position: refs/heads/master@{#41198}
      Cr-Commit-Position: refs/heads/master@{#41234}
      e108f90d
    • rmcilroy's avatar
      [compiler] Ensure code unsupported by Crankshaft goes to Ignition. · 5f5300a6
      rmcilroy authored
      BUG=v8:4280,v8:5657
      
      Review-Url: https://codereview.chromium.org/2505933008
      Cr-Commit-Position: refs/heads/master@{#41209}
      5f5300a6
    • hablich's avatar
      Revert of [wasm] WebAssembly.Memory object can be referenced by multiple... · de330e13
      hablich authored
      Revert of [wasm] WebAssembly.Memory object can be referenced by multiple Instance objects. (patchset #13 id:240001 of https://codereview.chromium.org/2471883003/ )
      
      Reason for revert:
      Test crashes after an unrelated revert: https://chromegw.corp.google.com/i/client.v8/builders/V8%20Linux%20-%20gc%20stress/builds/7189
      
      Reverting because of recommendation from WASM team.
      
      Original issue's description:
      > [wasm] WebAssembly.Memory object can be referenced by multiple Instance objects.
      >
      > Add support for WebAssembly.Memory objects to be simultaneously referenced by multiple Instance objects. GrowingMemory should maintain a consistent view of memory across instances.
      >  - Store a link to instances that share WebAssembly.Memory in the WasmMemoryObject, updated on instantiate.
      >  - Implement WasmInstanceWrapper as a wrapper around the instance object to keep track of previous/next instances, instance object is stored as a WeakCell that can be garbage collected.
      >  - MemoryInstanceFinalizer maintains a valid list of instances when an instance is garbage collected.
      >  - Refactor GrowInstanceMemory to GrowMemoryBuffer that allocates a new buffer, and UncheckedUpdateInstanceMemory that updates memory references for an instance.
      >
      >  R=titzer@chromium.org, mtrofin@chromium.org, bradnelson@chromium.org
      >
      > Committed: https://crrev.com/30ef8e33f3a199a27ca8512bcee314c9522d03f6
      > Committed: https://crrev.com/3c98e339599b068f1ed630afb7601ff942424d31
      > Cr-Original-Commit-Position: refs/heads/master@{#41121}
      > Cr-Commit-Position: refs/heads/master@{#41198}
      
      TBR=bradnelson@chromium.org,mtrofin@chromium.org,titzer@chromium.org,gdeepti@chromium.org
      # Skipping CQ checks because original CL landed less than 1 days ago.
      NOPRESUBMIT=true
      NOTREECHECKS=true
      NOTRY=true
      
      Review-Url: https://codereview.chromium.org/2529573002
      Cr-Commit-Position: refs/heads/master@{#41208}
      de330e13
    • gdeepti's avatar
      [wasm] WebAssembly.Memory object can be referenced by multiple Instance objects. · 3c98e339
      gdeepti authored
      Add support for WebAssembly.Memory objects to be simultaneously referenced by multiple Instance objects. GrowingMemory should maintain a consistent view of memory across instances.
       - Store a link to instances that share WebAssembly.Memory in the WasmMemoryObject, updated on instantiate.
       - Implement WasmInstanceWrapper as a wrapper around the instance object to keep track of previous/next instances, instance object is stored as a WeakCell that can be garbage collected.
       - MemoryInstanceFinalizer maintains a valid list of instances when an instance is garbage collected.
       - Refactor GrowInstanceMemory to GrowMemoryBuffer that allocates a new buffer, and UncheckedUpdateInstanceMemory that updates memory references for an instance.
      
       R=titzer@chromium.org, mtrofin@chromium.org, bradnelson@chromium.org
      
      Committed: https://crrev.com/30ef8e33f3a199a27ca8512bcee314c9522d03f6
      Review-Url: https://codereview.chromium.org/2471883003
      Cr-Original-Commit-Position: refs/heads/master@{#41121}
      Cr-Commit-Position: refs/heads/master@{#41198}
      3c98e339
  4. 22 Nov, 2016 1 commit
  5. 21 Nov, 2016 5 commits
    • mstarzinger's avatar
      [runtime] Rename {JSGeneratorObject::operand_stack} field. · 71c5904f
      mstarzinger authored
      This renames the {operand_stack} field to {register_file}, to refelct
      how said field is used on all {JSGeneratorObject} instances by now. This
      is a pure refactoring CL, not changes in semantics.
      
      R=neis@chromium.org
      
      Review-Url: https://codereview.chromium.org/2520913002
      Cr-Commit-Position: refs/heads/master@{#41140}
      71c5904f
    • mstarzinger's avatar
      [runtime] Ensure {JSGeneratorObject} is created for bytecode. · 2405ab11
      mstarzinger authored
      This removes some outdated code that allocates a {JSGeneratorObject} for
      baseline code. We no longer support such a representation of generators
      and can rely on bytecode being available for all generators.
      
      R=neis@chromium.org
      
      Review-Url: https://codereview.chromium.org/2515253003
      Cr-Commit-Position: refs/heads/master@{#41137}
      2405ab11
    • mstarzinger's avatar
      [fullcodegen] Remove deprecated generator implementation. · 09255541
      mstarzinger authored
      This removes the deprecated generator support for resumable functions
      from {FullCodeGenerator}. The existing {AstNumbering} heuristic already
      triggers Ignition for most resumable functions, with this change we make
      said heuristic a hard choice and remove the deprecated code. This also
      has the advantage that any suspended {JSGeneratorObject} instance on the
      heap is guaranteed to have code based on a bytecode array.
      
      R=bmeurer@chromium.org
      
      Review-Url: https://codereview.chromium.org/2504223002
      Cr-Commit-Position: refs/heads/master@{#41135}
      09255541
    • yangguo's avatar
      [debugger] step-next across yield should not leave the generator. · 416e423f
      yangguo authored
      Stepping in a generator now behaves similar to stepping inside an
      async function. Stepping in or next at a yield expression will result in
      a break inside the same generator when we return to the generator.
      Behavior of step-out does not change.
      
      R=jgruber@chromium.org, neis@chromium.org
      BUG=chromium:496865
      
      Review-Url: https://codereview.chromium.org/2519853002
      Cr-Commit-Position: refs/heads/master@{#41132}
      416e423f
    • jgruber's avatar
      [debug-wrapper] Adapt tests, breakpoint.actual_location · 1834ab72
      jgruber authored
      Adapted various tests to restrictions of inspector protocol:
      
      * osr-typing-debug-change: Don't set function variable value.
      * debug-evaluate-locals: Add variable introduced by eval, run typeof
        inside evaluate().
      * regress-419663: Don't set duplicate breakpoints.
      * regress-crbug-465298: Compare against function name instead of value.
      * regress-crbug-621361: Make evaluate return string results.
      * debug-script: Various counts were off due to new way tests are called.
                      Added new inspector script type.
      
      Breakpoints now contain the actual break position, and remote object
      reconstruction has been extended a bit.
      
      BUG=v8:5530
      
      Review-Url: https://codereview.chromium.org/2505363002
      Cr-Commit-Position: refs/heads/master@{#41129}
      1834ab72
  6. 19 Nov, 2016 2 commits
    • machenbach's avatar
      Revert of [wasm] WebAssembly.Memory object can be referenced by multiple... · 682f6500
      machenbach authored
      Revert of [wasm] WebAssembly.Memory object can be referenced by multiple Instance objects. (patchset #10 id:180001 of https://codereview.chromium.org/2471883003/ )
      
      Reason for revert:
      Breaks gc stress:
      https://build.chromium.org/p/client.v8/builders/V8%20Linux%20-%20gc%20stress/builds/7114
      
      Original issue's description:
      > [wasm] WebAssembly.Memory object can be referenced by multiple Instance objects.
      >
      > Add support for WebAssembly.Memory objects to be simultaneously referenced by multiple Instance objects. GrowingMemory should maintain a consistent view of memory across instances.
      >  - Store a link to instances that share WebAssembly.Memory in the WasmMemoryObject, updated on instantiate.
      >  - Implement WasmInstanceWrapper as a wrapper around the instance object to keep track of previous/next instances, instance object is stored as a WeakCell that can be garbage collected.
      >  - MemoryInstanceFinalizer maintains a valid list of instances when an instance is garbage collected.
      >  - Refactor GrowInstanceMemory to GrowMemoryBuffer that allocates a new buffer, and UncheckedUpdateInstanceMemory that updates memory references for an instance.
      >
      >  R=titzer@chromium.org, mtrofin@chromium.org, bradnelson@chromium.org
      >
      > Committed: https://crrev.com/30ef8e33f3a199a27ca8512bcee314c9522d03f6
      > Cr-Commit-Position: refs/heads/master@{#41121}
      
      TBR=bradnelson@chromium.org,mtrofin@chromium.org,titzer@chromium.org,gdeepti@chromium.org
      # Skipping CQ checks because original CL landed less than 1 days ago.
      NOPRESUBMIT=true
      NOTREECHECKS=true
      NOTRY=true
      
      Review-Url: https://codereview.chromium.org/2512323004
      Cr-Commit-Position: refs/heads/master@{#41122}
      682f6500
    • gdeepti's avatar
      [wasm] WebAssembly.Memory object can be referenced by multiple Instance objects. · 30ef8e33
      gdeepti authored
      Add support for WebAssembly.Memory objects to be simultaneously referenced by multiple Instance objects. GrowingMemory should maintain a consistent view of memory across instances.
       - Store a link to instances that share WebAssembly.Memory in the WasmMemoryObject, updated on instantiate.
       - Implement WasmInstanceWrapper as a wrapper around the instance object to keep track of previous/next instances, instance object is stored as a WeakCell that can be garbage collected.
       - MemoryInstanceFinalizer maintains a valid list of instances when an instance is garbage collected.
       - Refactor GrowInstanceMemory to GrowMemoryBuffer that allocates a new buffer, and UncheckedUpdateInstanceMemory that updates memory references for an instance.
      
       R=titzer@chromium.org, mtrofin@chromium.org, bradnelson@chromium.org
      
      Review-Url: https://codereview.chromium.org/2471883003
      Cr-Commit-Position: refs/heads/master@{#41121}
      30ef8e33
  7. 18 Nov, 2016 4 commits
  8. 17 Nov, 2016 2 commits
    • clemensh's avatar
      [wasm] Remove two obsolete functions · a80d4d03
      clemensh authored
      With the new wasm object types, the GetCompiledModule and GetWasmBytes
      functions are not needed any more. The same functions are already
      public on the wasm objects.
      In order to use them properly, I changed a few more locations to make
      use of the new types.
      
      R=ahaas@chromium.org, titzer@chromium.org
      
      Review-Url: https://codereview.chromium.org/2503403005
      Cr-Commit-Position: refs/heads/master@{#41085}
      a80d4d03
    • yangguo's avatar
      Refactor SharedFunctionInfo::IsBuiltin. · 45cb0fc7
      yangguo authored
      This method is a slight misnomer. What we actually want to know is
      whether the function was defined in a user-provided script.
      
      Also remove redundant Script::hide_source flag.
      
      R=bmeurer@chromium.org, ulan@chromium.org
      
      Review-Url: https://codereview.chromium.org/2505853003
      Cr-Commit-Position: refs/heads/master@{#41065}
      45cb0fc7
  9. 16 Nov, 2016 4 commits
  10. 15 Nov, 2016 4 commits
    • cbruni's avatar
      [elements] Precisely estimate elements size as last resort · 14c6a651
      cbruni authored
      In case of an allocation failure in for-in over holey elements, use precise
      number of elements to allocate a smaller buffer for the collected indices.
      
      Drive-by-fix: make is_the_hole accept the isolate for faster checks.
      
      BUG=chromium:609761
      
      Review-Url: https://codereview.chromium.org/2041963003
      Cr-Commit-Position: refs/heads/master@{#41010}
      14c6a651
    • jshin's avatar
      Use a regular ICU API for el-Upper · 4f224b39
      jshin authored
      ICU now supports uppercasing in Greek via its regular uppercasing API.
      So, there's no need to use a slow transliteration API for uppercasing
      in Greek.
      
      This CL includes rolling ICU to ICU 58.1.
      
      Besides, drop intl402/Intl/getCanonicalLocales/weird-cases from
      test262.status because it passes now with ICU 58.1.
      
      BUG=chromium:637001,v8:5012
      
      Review-Url: https://codereview.chromium.org/2491333003
      Cr-Commit-Position: refs/heads/master@{#41009}
      4f224b39
    • clemensh's avatar
      [wasm] Allocate a single script per wasm module · 32077e01
      clemensh authored
      Before, we allocated one script per function per instance, and each
      script referenced the wasm instance and the function index. Now we only
      allocate one script per compiled wasm module, so the script also only
      references this WasmCompiledModule, which causes changes to many interfaces.
      
      Instead of fixing the disassemble API only used via debug.js, I decided
      to drop it for now. Some later CL will reintroduce it via
      DebugInterface.
      
      BUG=v8:5530,chromium:659715
      R=yangguo@chromium.org, titzer@chromium.org
      CC=jgruber@chromium.org
      
      Review-Url: https://codereview.chromium.org/2493823003
      Cr-Commit-Position: refs/heads/master@{#41004}
      32077e01
    • petermarshall's avatar
      Fastpath some spread-call desugaring. · a63eeb48
      petermarshall authored
      Avoid using the iterator for arrays with fast elements where the iterator has
      not been modified.
      
      Only deals with the case where there is a single spread argument.
      
      Improves the six-speed "spread" benchmark to 1.5x slower than baseline es5 implementation, compared to 19x slower previously.
      
      BUG=v8:5511
      
      Review-Url: https://codereview.chromium.org/2465253011
      Cr-Commit-Position: refs/heads/master@{#40998}
      a63eeb48
  11. 14 Nov, 2016 2 commits
    • tebbi's avatar
      This CL enables precise source positions for all V8 compilers. It merges... · c3a6ca68
      tebbi authored
      This CL enables precise source positions for all V8 compilers. It merges compiler::SourcePosition and internal::SourcePosition to a single class used throughout the codebase. The new internal::SourcePosition instances store an id identifying an inlined function in addition to a script offset.
      SourcePosition::InliningId() refers to a the new table DeoptimizationInputData::InliningPositions(), which provides the following data for every inlining id:
       - The inlined SharedFunctionInfo as an offset into DeoptimizationInfo::LiteralArray
       - The SourcePosition of the inlining. Recursively, this yields the full inlining stack.
      Before the Code object is created, the same information can be found in CompilationInfo::inlined_functions().
      
      If SourcePosition::InliningId() is SourcePosition::kNotInlined, it refers to the outer (non-inlined) function.
      So every SourcePosition has full information about its inlining stack, as long as the corresponding Code object is known. The internal represenation of a source position is a positive 64bit integer.
      
      All compilers create now appropriate source positions for inlined functions. In the case of Turbofan, this required using AstGraphBuilderWithPositions for inlined functions too. So this class is now moved to a header file.
      
      At the moment, the additional information in source positions is only used in --trace-deopt and --code-comments. The profiler needs to be updated, at the moment it gets the correct script offsets from the deopt info, but the wrong script id from the reconstructed deopt stack, which can lead to wrong outputs. This should be resolved by making the profiler use the new inlining information for deopts.
      
      I activated the inlined deoptimization tests in test-cpu-profiler.cc for Turbofan, changing them to a case where the deopt stack and the inlining position agree. It is currently still broken for other cases.
      
      The following additional changes were necessary:
       - The source position table (internal::SourcePositionTableBuilder etc.) supports now 64bit source positions. Encoding source positions in a single 64bit int together with the difference encoding in the source position table results in very little overhead for the inlining id, since only 12% of the source positions in Octane have a changed inlining id.
       - The class HPositionInfo was effectively dead code and is now removed.
       - SourcePosition has new printing and information facilities, including computing a full inlining stack.
       - I had to rename compiler/source-position.{h,cc} to compiler/compiler-source-position-table.{h,cc} to avoid clashes with the new src/source-position.cc file.
       - I wrote the new wrapper PodArray for ByteArray. It is a template working with any POD-type. This is used in DeoptimizationInputData::InliningPositions().
       - I removed HInlinedFunctionInfo and HGraph::inlined_function_infos, because they were only used for the now obsolete Crankshaft inlining ids.
       - Crankshaft managed a list of inlined functions in Lithium: LChunk::inlined_functions. This is an analog structure to CompilationInfo::inlined_functions. So I removed LChunk::inlined_functions and made Crankshaft use CompilationInfo::inlined_functions instead, because this was necessary to register the offsets into the literal array in a uniform way. This is a safe change because LChunk::inlined_functions has no other uses and the functions in CompilationInfo::inlined_functions have a strictly longer lifespan, being created earlier (in Hydrogen already).
      
      BUG=v8:5432
      
      Review-Url: https://codereview.chromium.org/2451853002
      Cr-Commit-Position: refs/heads/master@{#40975}
      c3a6ca68
    • caitp's avatar
      [builtins] implement JSBuiltinReducer for ArrayIteratorNext() · 7f21e67b
      caitp authored
      Adds a protector cell to prevent inlining (which will likely lead to deopt
      loops) when a JSArrayIterator's array transitions from a fast JSArray to a
      slow JSArray (such as, when the array is touched during iteration in a way
      which triggers a map transition).
      
      Also adds TODO comments relating to the spec update proposed by Dan at
      https://github.com/tc39/ecma262/pull/724
      
      BUG=v8:5388
      R=bmeurer@chromium.org, mstarzinger@chromium.org
      TBR=hpayer@chromium.org, ulan@chromium.org
      
      Review-Url: https://codereview.chromium.org/2484003002
      Cr-Commit-Position: refs/heads/master@{#40970}
      7f21e67b
  12. 11 Nov, 2016 5 commits
  13. 10 Nov, 2016 2 commits
  14. 07 Nov, 2016 1 commit
    • neis's avatar
      [modules] Maintain array of cells for imports and local exports. · 21463f73
      neis authored
      This makes use of the newly introduced cell indices to speed up variable
      accesses. Imports and local exports are now directly stored in (separate)
      arrays. In the future, we may merge the two arrays into a single one, or
      even into the module context.
      
      This CL also replaces the LoadImport and LoadExport runtime functions with
      a single LoadVariable taking a variable index as argument (rather than a
      name).
      
      BUG=v8:1569
      
      Review-Url: https://codereview.chromium.org/2465283004
      Cr-Commit-Position: refs/heads/master@{#40808}
      21463f73
  15. 28 Oct, 2016 1 commit
    • jgruber's avatar
      [debugger] Various break-related functionality in test wrapper · 83b560b0
      jgruber authored
      This CL adds simple implementation of break and stepping-related functionality
      as required by the debug-step.js test. This includes
      
      * stepOver, stepInto, stepOut
      * setBreakPoint
      * clearBreakPoint
      * evaluate
      
      Some of these, e.g. setBreakPoint are not fully implemented for all cases but
      only for the ones we need right now.
      
      One interesting result of this is that using the inspector protocol is roughly
      14x slower for debug-step.js (14s instead of 0.5s). One cause of this seems to
      be iteration over all object properties in toProtocolValue, which is used to
      serialize JS objects before being sent over the wire (e.g. FrameMirrors).  This
      is something that should be fixed at some point. In the meantime, the test now
      runs 100 instead of 1000 iterations.
      
      BUG=v8:5530
      
      Review-Url: https://codereview.chromium.org/2447073007
      Cr-Commit-Position: refs/heads/master@{#40636}
      83b560b0
  16. 27 Oct, 2016 1 commit