1. 20 Jul, 2019 2 commits
  2. 19 Jul, 2019 22 commits
  3. 18 Jul, 2019 16 commits
    • Andreas Haas's avatar
      [wasm][bulk-memory] Adjust memory.fill to recent spec changes · f8047441
      Andreas Haas authored
      R=binji@chromium.org
      
      Change-Id: I01721c708b1e40cdef4bd48a1f9ca68b31c8f49d
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1708470Reviewed-by: 's avatarBen Smith <binji@chromium.org>
      Commit-Queue: Andreas Haas <ahaas@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62814}
      f8047441
    • Z Nguyen-Huu's avatar
      Implement proxy trap deleteProperty in Torque, apply to reflect · 269c279e
      Z Nguyen-Huu authored
      Reflect.deleteProperty now is a Torque builtins, also containing fast
      path for proxy object.
      
      Bug: v8:6664
      Change-Id: I76d6fba2c9d05d991132957783d987a190585ec8
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1704943
      Commit-Queue: Z Nguyen-Huu <duongn@microsoft.com>
      Reviewed-by: 's avatarSimon Zünd <szuend@chromium.org>
      Reviewed-by: 's avatarMaya Lekova <mslekova@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62813}
      269c279e
    • Adam Klein's avatar
      [builtins] Allow API callbacks to return BigInts · 33789183
      Adam Klein authored
      This fixes the debug code which checks that API callbacks
      return only valid JS values: BigInt was missing from the list
      of allowable types.
      
      Bug: chromium:985115
      Change-Id: I8b3db409bd99e9e9b936d520d0fdbe75654e7602
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1706623Reviewed-by: 's avatarJakob Gruber <jgruber@chromium.org>
      Commit-Queue: Adam Klein <adamk@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62812}
      33789183
    • Clemens Hammacher's avatar
      Revert "Reland "[arraybuffer] Rearchitect backing store ownership"" · 6e0473f3
      Clemens Hammacher authored
      This reverts commit bc33f5ae.
      
      Reason for revert: Still failing (OOM on win32): https://ci.chromium.org/p/v8/builders/ci/V8%20Win32/22210
      
      Original change's description:
      > Reland "[arraybuffer] Rearchitect backing store ownership"
      > 
      > This is a reland of 31cd5d83
      > 
      > Original change's description:
      > > [arraybuffer] Rearchitect backing store ownership
      > > 
      > > This CL completely rearchitects the ownership of array buffer backing stores,
      > > consolidating ownership into a {BackingStore} C++ object that is tracked
      > > throughout V8 using unique_ptr and shared_ptr where appropriate.
      > > 
      > > Overall, lifetime management is simpler and more explicit. The numerous
      > > ways that array buffers were initialized have been streamlined to one
      > > Attach() method on JSArrayBuffer. The array buffer tracker in the
      > > GC implementation now manages std::shared_ptr<BackingStore> pointers,
      > > and the construction and destruction of the BackingStore object itself
      > > handles the underlying page or embedder-allocated memory.
      > > 
      > > The embedder API remains unchanged for now. We use the
      > > v8::ArrayBuffer::Contents struct to hide an additional shared_ptr to
      > > keep the backing store alive properly, even in the case of aliases
      > > from live heap objects. Thus the embedder has a lower chance of making
      > > a mistake. Long-term, we should move the embedder to a model where they
      > > manage backing stores using shared_ptr to an opaque backing store object.
      > > 
      > > R=mlippautz@chromium.org
      > > BUG=v8:9380,v8:9221
      > > 
      > > Change-Id: I48fae5ac85dcf6172a83f252439e77e7c1a16ccd
      > > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1584323
      > > Commit-Queue: Ben Titzer <titzer@chromium.org>
      > > Reviewed-by: Ben Titzer <titzer@chromium.org>
      > > Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
      > > Reviewed-by: Yang Guo <yangguo@chromium.org>
      > > Reviewed-by: Deepti Gandluri <gdeepti@chromium.org>
      > > Reviewed-by: Ulan Degenbaev <ulan@chromium.org>
      > > Reviewed-by: Michael Lippautz <mlippautz@chromium.org>
      > > Cr-Commit-Position: refs/heads/master@{#62572}
      > 
      > Bug: v8:9380, v8:9221
      > Change-Id: If3f72967a8ebeb067c0edcfc16ed631e36829dbc
      > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1691906
      > Commit-Queue: Ben Titzer <titzer@chromium.org>
      > Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
      > Reviewed-by: Michael Lippautz <mlippautz@chromium.org>
      > Reviewed-by: Deepti Gandluri <gdeepti@chromium.org>
      > Reviewed-by: Yang Guo <yangguo@chromium.org>
      > Reviewed-by: Ulan Degenbaev <ulan@chromium.org>
      > Cr-Commit-Position: refs/heads/master@{#62809}
      
      TBR=ulan@chromium.org,yangguo@chromium.org,mstarzinger@chromium.org,titzer@chromium.org,gdeepti@chromium.org,mlippautz@chromium.org
      
      Change-Id: Iea755df9aaa1e95d284135bd0a6681b1340b6832
      No-Presubmit: true
      No-Tree-Checks: true
      No-Try: true
      Bug: v8:9380, v8:9221
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1708487Reviewed-by: 's avatarClemens Hammacher <clemensh@chromium.org>
      Commit-Queue: Clemens Hammacher <clemensh@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62811}
      6e0473f3
    • Peter Marshall's avatar
      [tracing] Separate tracing implementations and add perfetto tests · 317b72b2
      Peter Marshall authored
      Previously both tracing implementations would be run side-by-side when
      perfetto was enabled with the V8_USE_PERFETTO build flag. This CL
      makes them run separately.
      
      Both implementations now use the trace file provided by the user in D8
      or the default v8_trace.json.
      
      Add tests for perfetto events (which must be tested differently
      due to the proto output format).
      
      Drive-by fix: Fix pass-by non-const ref in GetJSONStrings.
      
      Remove the TraceEvent struct for testing; we can just store a copy of
      the protobuf directly.
      
      Bug: v8:8339
      Change-Id: Id50003e0f96e44b99a63a26693da6bdaca989504
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1702619Reviewed-by: 's avatarYang Guo <yangguo@chromium.org>
      Reviewed-by: 's avatarJakob Gruber <jgruber@chromium.org>
      Commit-Queue: Peter Marshall <petermarshall@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62810}
      317b72b2
    • Ben L. Titzer's avatar
      Reland "[arraybuffer] Rearchitect backing store ownership" · bc33f5ae
      Ben L. Titzer authored
      This is a reland of 31cd5d83
      
      Original change's description:
      > [arraybuffer] Rearchitect backing store ownership
      > 
      > This CL completely rearchitects the ownership of array buffer backing stores,
      > consolidating ownership into a {BackingStore} C++ object that is tracked
      > throughout V8 using unique_ptr and shared_ptr where appropriate.
      > 
      > Overall, lifetime management is simpler and more explicit. The numerous
      > ways that array buffers were initialized have been streamlined to one
      > Attach() method on JSArrayBuffer. The array buffer tracker in the
      > GC implementation now manages std::shared_ptr<BackingStore> pointers,
      > and the construction and destruction of the BackingStore object itself
      > handles the underlying page or embedder-allocated memory.
      > 
      > The embedder API remains unchanged for now. We use the
      > v8::ArrayBuffer::Contents struct to hide an additional shared_ptr to
      > keep the backing store alive properly, even in the case of aliases
      > from live heap objects. Thus the embedder has a lower chance of making
      > a mistake. Long-term, we should move the embedder to a model where they
      > manage backing stores using shared_ptr to an opaque backing store object.
      > 
      > R=mlippautz@chromium.org
      > BUG=v8:9380,v8:9221
      > 
      > Change-Id: I48fae5ac85dcf6172a83f252439e77e7c1a16ccd
      > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1584323
      > Commit-Queue: Ben Titzer <titzer@chromium.org>
      > Reviewed-by: Ben Titzer <titzer@chromium.org>
      > Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
      > Reviewed-by: Yang Guo <yangguo@chromium.org>
      > Reviewed-by: Deepti Gandluri <gdeepti@chromium.org>
      > Reviewed-by: Ulan Degenbaev <ulan@chromium.org>
      > Reviewed-by: Michael Lippautz <mlippautz@chromium.org>
      > Cr-Commit-Position: refs/heads/master@{#62572}
      
      Bug: v8:9380, v8:9221
      Change-Id: If3f72967a8ebeb067c0edcfc16ed631e36829dbc
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1691906
      Commit-Queue: Ben Titzer <titzer@chromium.org>
      Reviewed-by: 's avatarMichael Starzinger <mstarzinger@chromium.org>
      Reviewed-by: 's avatarMichael Lippautz <mlippautz@chromium.org>
      Reviewed-by: 's avatarDeepti Gandluri <gdeepti@chromium.org>
      Reviewed-by: 's avatarYang Guo <yangguo@chromium.org>
      Reviewed-by: 's avatarUlan Degenbaev <ulan@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62809}
      bc33f5ae
    • Clemens Hammacher's avatar
      [x64] Fix {Assembler::Nop} for large inputs · 8d758abc
      Clemens Hammacher authored
      {Assembler::Nop} currently fails if {n} is bigger than {kGap} (the
      destructor of {EnsureSpace} checks that not more than {kGap} bytes have
      been emitted).
      This CL fixes this by repeatedly using {EnsureSpace}, and also
      optimizes the implementation of {Assembler::Nop} a bit.
      It also removes stray cases for 10 and 11 nop bytes which have been
      added in https://crrev.com/8773039 without further comment, and are not
      documented in the Intel manual.
      
      R=mstarzinger@chromium.org
      
      Bug: v8:9477
      Change-Id: I07bbe311d2daa75dc27b91a0ccb503427c52841f
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1708476
      Commit-Queue: Clemens Hammacher <clemensh@chromium.org>
      Reviewed-by: 's avatarMichael Starzinger <mstarzinger@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62808}
      8d758abc
    • Sathya Gunasekaran's avatar
      Revert "[runtime] Fix protector invalidation" · 050ad1d8
      Sathya Gunasekaran authored
      This reverts commit e55e0aa5.
      
      Reason for revert: speculative revert for tsan breakage
      https://logs.chromium.org/logs/v8/buildbucket/cr-buildbucket.appspot.com/8907588363297935904/+/steps/Check__flakes_/0/logs/regress-437713/0
      
      Original change's description:
      > [runtime] Fix protector invalidation
      > 
      > Protectors trigger when special properties are modified or masked. Previously
      > we would check whether the property stored on the holder would invalidate the
      > protector. Stores to to the receiver rather than the holder, however, so this
      > CL changes holder for receiver, and adds additional checks that were missing.
      > 
      > Bug: v8:9466
      > Change-Id: I81bc3d73f91381da0d254e9eb79365ae2d25d998
      > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1708468
      > Commit-Queue: Leszek Swirski <leszeks@chromium.org>
      > Reviewed-by: Leszek Swirski <leszeks@chromium.org>
      > Cr-Commit-Position: refs/heads/master@{#62805}
      
      TBR=leszeks@chromium.org,verwaest@chromium.org
      
      Change-Id: Id8fc36525b7c5631589a67073ad1fd5815ea2775
      No-Presubmit: true
      No-Tree-Checks: true
      No-Try: true
      Bug: v8:9466
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1708482Reviewed-by: 's avatarSathya Gunasekaran <gsathya@chromium.org>
      Commit-Queue: Sathya Gunasekaran <gsathya@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62807}
      050ad1d8
    • Yang Guo's avatar
      Debugger: expose local scope for class member initializer · 50b996f2
      Yang Guo authored
      R=gsathya@chromium.org
      
      Change-Id: I892b96d5749066df476ace705f45a801a795c0a0
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1706060
      Auto-Submit: Yang Guo <yangguo@chromium.org>
      Reviewed-by: 's avatarSathya Gunasekaran <gsathya@chromium.org>
      Commit-Queue: Yang Guo <yangguo@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62806}
      50b996f2
    • Toon Verwaest's avatar
      [runtime] Fix protector invalidation · e55e0aa5
      Toon Verwaest authored
      Protectors trigger when special properties are modified or masked. Previously
      we would check whether the property stored on the holder would invalidate the
      protector. Stores to to the receiver rather than the holder, however, so this
      CL changes holder for receiver, and adds additional checks that were missing.
      
      Bug: v8:9466
      Change-Id: I81bc3d73f91381da0d254e9eb79365ae2d25d998
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1708468
      Commit-Queue: Leszek Swirski <leszeks@chromium.org>
      Reviewed-by: 's avatarLeszek Swirski <leszeks@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62805}
      e55e0aa5
    • Clemens Hammacher's avatar
      [wasm][gc] Fix deadlock during shutdown · 777d5084
      Clemens Hammacher authored
      The destructor of the {WasmGCForegroundTask} can be called immediately
      when scheduling that task (if the platform determines that the task can
      never execute anyway). In that case, we deregister the task from the
      wasm engine so we do not access it later (which would be UAF). This
      deregistration leads to recursively taking a mutex now.
      The only later access to the task happens to cancel the task. For this
      purpose, we can also use the {CancelableTaskManager} of the isolate,
      and avoid all code in the destructor. This should fix the reentrant
      mutex, which leads to a DCHECK failure in debug builds and deadlock
      in release builds.
      
      R=mstarzinger@chromium.org
      
      Bug: chromium:984970, v8:8217
      Change-Id: I14f05a21ea961ecc391dc59af3b5eebf31e0f873
      Cq-Include-Trybots: luci.v8.try:v8_linux_blink_rel
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1706480Reviewed-by: 's avatarMichael Starzinger <mstarzinger@chromium.org>
      Commit-Queue: Clemens Hammacher <clemensh@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62804}
      777d5084
    • Pierre Langlois's avatar
      [turbofan][arm64] Relax immediate offset conditions on stores with barriers. · 074fdf1f
      Pierre Langlois authored
      With a write barrier, stores with negative offsets would allocate a temporary
      register to hold the offset when the `str` instruction is able to encode it.
      
      For instance, when writing the object map:
      
      ```
      ;; This could be 'str x2, [x5, #-1]'
      movn x4, #0x0
      str x2, [x5, x4]
      and x16, x5, #0xfffffffffffc0000
      ldr x16, [x16, #8]
      tbnz w16, #2, #+0xba8  ; Jump out-of-line
      ```
      
      The reason behind this is that the out-of-line code uses an 'add' instruction on
      the offset to compute the field address, putting pressure on the instruction
      selector to make sure the immediate fits in both 'str' and 'add'.
      
      But, this is not necessary since the macro-assembler is able to turn the 'add'
      into a 'sub' or use a temporary register if needed.
      
      Change-Id: I8838e4b81a0c0c1f90aa3d67861a9da1a6dfed06
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1708471Reviewed-by: 's avatarRoss McIlroy <rmcilroy@chromium.org>
      Reviewed-by: 's avatarSigurd Schneider <sigurds@chromium.org>
      Commit-Queue: Pierre Langlois <pierre.langlois@arm.com>
      Cr-Commit-Position: refs/heads/master@{#62803}
      074fdf1f
    • Ben L. Titzer's avatar
      [mjsunit] Nerf shared-memory-worker-stress a little · ee16525e
      Ben L. Titzer authored
      This test fails in --stress-opt mode because backing stores of
      memories/arraybuffers that are postMessage()'d leak in d8. In normal
      mode, only ~16 memories are allocated, which is not enough to OOM,
      but in stress mode, it can be 5x that number. Should be fixed
      by upcoming ownership changes.
      
      BUG=v8:9380
      R=clemensh@chromium.org
      
      Change-Id: Iecec07d15339cf43b23f128f13d570dfe3b32130
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1708475Reviewed-by: 's avatarClemens Hammacher <clemensh@chromium.org>
      Commit-Queue: Ben Titzer <titzer@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62802}
      ee16525e
    • Ulan Degenbaev's avatar
      [ptr-compr][heap] Fix Heap::kPointerMultiplier · 4cf6baf5
      Ulan Degenbaev authored
      The multiplier should depend on the kTaggedSize.
      
      Bug: v8:7703
      Change-Id: I3a13e51d06c31b70f6191b23b1913e7bc35cdb8f
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1708473
      Commit-Queue: Ulan Degenbaev <ulan@chromium.org>
      Reviewed-by: 's avatarRoss McIlroy <rmcilroy@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62801}
      4cf6baf5
    • Ross McIlroy's avatar
      [Compile] Ensure we don't reuse a feedback vector with a different layout than expected. · b06a134c
      Ross McIlroy authored
      If we flush the bytecode from a SFI we might recompile a JSFunction while the function
      still has its old feedback vector. This should usually be fine since the new and old
      feedback vectors have the same layout, however some bugs in the parser mean that it's
      possible for eagerly and lazily compiled eval functions to have different bytecode and
      so potentially different feedback vector layouts.
      
      For now reset the feedback vector if it doesn't have the same size when we compile the
      JSFunction, and recreate a new one of the correct layout. This will be replaced with a
      CHECK once the parser bugs are fixed.
      
      BUG=chromium:984344,v8:9511
      
      Change-Id: Ib8976f2541516f7a07e4d4ab7dc3c750dfe9b5d4
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1708474
      Commit-Queue: Ross McIlroy <rmcilroy@chromium.org>
      Commit-Queue: Ulan Degenbaev <ulan@chromium.org>
      Reviewed-by: 's avatarUlan Degenbaev <ulan@chromium.org>
      Auto-Submit: Ross McIlroy <rmcilroy@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62800}
      b06a134c
    • Georg Neis's avatar
      Reland "Revert "Temporarily remove --concurrent-inlining from --future"" · b4964540
      Georg Neis authored
      This is a reland of 6805395d, after
      resolving another issue.
      
      Original change's description:
      > Revert "Temporarily remove --concurrent-inlining from --future"
      >
      > This reverts commit 060b9ec4, as the
      > issue has been resolved.
      >
      > Bug: v8:7790
      > Change-Id: Id8a56ad50a508eacd191f2777cc5afc0b838364f
      > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1700078
      > Commit-Queue: Georg Neis <neis@chromium.org>
      > Commit-Queue: Michael Stanton <mvstanton@chromium.org>
      > Reviewed-by: Michael Stanton <mvstanton@chromium.org>
      > Reviewed-by: Maya Lekova <mslekova@chromium.org>
      > Auto-Submit: Georg Neis <neis@chromium.org>
      > Cr-Commit-Position: refs/heads/master@{#62713}
      
      TBR=neis@chromium.org
      
      Bug: v8:7790
      Change-Id: Ibc5991787982197d08942eb067c83001d91050ec
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1708472Reviewed-by: 's avatarGeorg Neis <neis@chromium.org>
      Commit-Queue: Georg Neis <neis@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#62799}
      b4964540