1. 04 Feb, 2022 9 commits
  2. 03 Feb, 2022 22 commits
  3. 02 Feb, 2022 9 commits
    • Nikolaos Papaspyrou's avatar
      heap: Fix the tracing of GC cycles · 73a1c635
      Nikolaos Papaspyrou authored
      Conceptually, a full GC cycle completes when the sweeping phase is
      finished. As sweeping is performed concurrently, this happens after
      Heap::CollectGarbage has returned and, at the latest, before the next
      full GC cycle begins. However, an arbitrary number of young GC cycles
      may happen in the meantime. Tracing information for the sweeping phase
      must be added to the corresponding full GC cycle event. Until now, this
      was not done correctly: this information was added to the GCTracer's
      current event and could thus be attributed to a subsequent young or full
      GC cycle.
      
      This CL introduces methods GCTracer::(Start|Stop)Cycle to delimit a
      cycle (still allowing for full GC cycles to be interrupted by young GC
      cycles). These methods are different from (Start|Stop)ObservablePause,
      which delimit the observable pause of each GC. The events of "pending"
      full GC cycles are kept until they are properly amended and reported,
      when the sweeping phase is finished.
      
      This is a reland of 4ad20bff
      which was reviewed here: https://crrev.com/3404733
      
      Bug: v8:12503
      Bug: chromium:1154636
      Change-Id: Icc315b53cff1f3b19b8efe49db34340a5608bcd2
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3432211Reviewed-by: 's avatarOmer Katz <omerkatz@chromium.org>
      Reviewed-by: 's avatarMichael Lippautz <mlippautz@chromium.org>
      Commit-Queue: Nikolaos Papaspyrou <nikolaos@chromium.org>
      Cr-Commit-Position: refs/heads/main@{#78911}
      73a1c635
    • Milad Fa's avatar
      S390 [liftoff]: Implement simd i32 to fp32 conversion · e2bdbffb
      Milad Fa authored
      Change-Id: I251df1abd2f7facc1ee5adad7a7dbf70c1554d22
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3432985Reviewed-by: 's avatarJunliang Yan <junyan@redhat.com>
      Commit-Queue: Milad Farazmand <mfarazma@redhat.com>
      Cr-Commit-Position: refs/heads/main@{#78910}
      e2bdbffb
    • Gus Caplan's avatar
      fix overflow check in error formatting · cc9a8a37
      Gus Caplan authored
      Bug: v8:12494
      Change-Id: Iba2684173296aa236f1a1c73a5606c21472eff06
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3426634Reviewed-by: 's avatarJakob Kummerow <jkummerow@chromium.org>
      Commit-Queue: Gus Caplan <snek@chromium.org>
      Cr-Commit-Position: refs/heads/main@{#78909}
      cc9a8a37
    • Leszek Swirski's avatar
      Revert "heap: Fix the tracing of GC cycles" · 10e811c4
      Leszek Swirski authored
      This reverts commit 4ad20bff.
      
      Reason for revert: New test seems to be failing on TSAN/incremental marking stress (https://ci.chromium.org/ui/p/v8/builders/ci/V8%20Linux64%20TSAN%20-%20stress-incremental-marking/6346/overview)
      
      Original change's description:
      > heap: Fix the tracing of GC cycles
      >
      > Conceptually, a full GC cycle completes when the sweeping phase is
      > finished. As sweeping is performed concurrently, this happens after
      > Heap::CollectGarbage has returned and, at the latest, before the next
      > full GC cycle begins. However, an arbitrary number of young GC cycles
      > may happen in the meantime. Tracing information for the sweeping phase
      > must be added to the corresponding full GC cycle event. Until now, this
      > was not done correctly: this information was added to the GCTracer's
      > current event and could thus be attributed to a subsequent young or full
      > GC cycle.
      >
      > This CL introduces methods GCTracer::(Start|Stop)Cycle to delimit a
      > cycle (still allowing for full GC cycles to be interrupted by young GC
      > cycles). These methods are different from (Start|Stop)ObservablePause,
      > which delimit the observable pause of each GC. The events of "pending"
      > full GC cycles are kept until they are properly amended and reported,
      > when the sweeping phase is finished.
      >
      > Bug: chromium:1154636
      > Change-Id: I2fbc65d4807c78656d4abc8c451043f6f86211b1
      > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3404733
      > Reviewed-by: Michael Lippautz <mlippautz@chromium.org>
      > Reviewed-by: Omer Katz <omerkatz@chromium.org>
      > Commit-Queue: Nikolaos Papaspyrou <nikolaos@chromium.org>
      > Cr-Commit-Position: refs/heads/main@{#78905}
      
      Bug: chromium:1154636
      Change-Id: Id6688cfe982f9d8159c66d715b7079782a371bed
      No-Presubmit: true
      No-Tree-Checks: true
      No-Try: true
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3431489
      Auto-Submit: Leszek Swirski <leszeks@chromium.org>
      Bot-Commit: Rubber Stamper <rubber-stamper@appspot.gserviceaccount.com>
      Owners-Override: Leszek Swirski <leszeks@chromium.org>
      Commit-Queue: Leszek Swirski <leszeks@chromium.org>
      Cr-Commit-Position: refs/heads/main@{#78908}
      10e811c4
    • Milad Fa's avatar
      S390 [liftoff]: Implement simd fp32 to i32 conversion · 7f47473a
      Milad Fa authored
      I32x4UConvertF32x4 is also slightly optimized by removing 2
      instructions.
      
      Change-Id: Ie61fbd34628beb2410ae3ef916de7c3119c7ad9c
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3429463Reviewed-by: 's avatarJunliang Yan <junyan@redhat.com>
      Commit-Queue: Milad Farazmand <mfarazma@redhat.com>
      Cr-Commit-Position: refs/heads/main@{#78907}
      7f47473a
    • Benedikt Meurer's avatar
      [inspector] Make inspector tests independent of `Debugger.CallFrame.url`. · b3452045
      Benedikt Meurer authored
      This is the second step towards moving away from sending `url` with
      every call frame when emitting the `Debugger.paused` event.
      
      Bug: chromium:1270316, chromium:1271078
      Change-Id: Ib4f996024b5200cded155bd8a564d01d36856400
      Doc: https://bit.ly/devtools-debugger-callframe-url
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3431485
      Auto-Submit: Benedikt Meurer <bmeurer@chromium.org>
      Reviewed-by: 's avatarYang Guo <yangguo@chromium.org>
      Commit-Queue: Yang Guo <yangguo@chromium.org>
      Cr-Commit-Position: refs/heads/main@{#78906}
      b3452045
    • Nikolaos Papaspyrou's avatar
      heap: Fix the tracing of GC cycles · 4ad20bff
      Nikolaos Papaspyrou authored
      Conceptually, a full GC cycle completes when the sweeping phase is
      finished. As sweeping is performed concurrently, this happens after
      Heap::CollectGarbage has returned and, at the latest, before the next
      full GC cycle begins. However, an arbitrary number of young GC cycles
      may happen in the meantime. Tracing information for the sweeping phase
      must be added to the corresponding full GC cycle event. Until now, this
      was not done correctly: this information was added to the GCTracer's
      current event and could thus be attributed to a subsequent young or full
      GC cycle.
      
      This CL introduces methods GCTracer::(Start|Stop)Cycle to delimit a
      cycle (still allowing for full GC cycles to be interrupted by young GC
      cycles). These methods are different from (Start|Stop)ObservablePause,
      which delimit the observable pause of each GC. The events of "pending"
      full GC cycles are kept until they are properly amended and reported,
      when the sweeping phase is finished.
      
      Bug: chromium:1154636
      Change-Id: I2fbc65d4807c78656d4abc8c451043f6f86211b1
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3404733Reviewed-by: 's avatarMichael Lippautz <mlippautz@chromium.org>
      Reviewed-by: 's avatarOmer Katz <omerkatz@chromium.org>
      Commit-Queue: Nikolaos Papaspyrou <nikolaos@chromium.org>
      Cr-Commit-Position: refs/heads/main@{#78905}
      4ad20bff
    • Clemens Backes's avatar
      [wasm] Unhandlify UpdateDispatchTables · 078f7c4f
      Clemens Backes authored
      UpdateDispatchTables is the hottest function during Wasm instantiation,
      thus dehandlify it, as it does not allocate on the JS heap anyway. This
      saves ~20% of instantiation time locally.
      
      R=manoskouk@chromium.org
      
      Bug: v8:12593
      Cq-Include-Trybots: luci.v8.try:v8_linux_gc_stress_dbg_ng
      Cq-Include-Trybots: luci.v8.try:v8_mac64_gc_stress_dbg_ng
      Change-Id: Ifdd3f8fcd2e31950b591b179a62a0d397c41c339
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3429205Reviewed-by: 's avatarManos Koukoutos <manoskouk@chromium.org>
      Commit-Queue: Clemens Backes <clemensb@chromium.org>
      Cr-Commit-Position: refs/heads/main@{#78904}
      078f7c4f
    • Clemens Backes's avatar
      [wasm] Remove wrong signature definitions for numerics · 63c95e61
      Clemens Backes authored
      Some of the numeric opcodes have a variadic signature, e.g. table.grow
      or table.fill, and soon also the bulk memory opcodes because their
      consumed types depend on the memory type.
      
      For those opcodes, remove the signature definition from the opcode macro
      lists, because using it might result in bugs.
      
      R=thibaudm@chromium.org
      
      Bug: v8:10949, chromium:1281995
      Change-Id: I350e75db7197d97a561f8219cedba5fe85b5c9c9
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3424494Reviewed-by: 's avatarThibaud Michaud <thibaudm@chromium.org>
      Commit-Queue: Clemens Backes <clemensb@chromium.org>
      Cr-Commit-Position: refs/heads/main@{#78903}
      63c95e61