1. 11 Aug, 2022 1 commit
  2. 10 Aug, 2022 1 commit
    • Camillo's avatar
      [runtime] Improve builtins PGO logging · 012fa899
      Camillo authored
      - Add explicit --turbo-profiling-output and --turbo-profiling-input
      - Rename --turbo-profiling-log-file to --turbo-profiling-input
      - No longer log PGO data to v8.log
      - Add runtime %GetAndResetTurboProfilingData helper function for
        more controlled logging within chrome
      - Rewrite generate.py script to use more python3
      
      Bug: v8:10470
      Change-Id: Ib817b5c3793a0a7ae77103075ea2d6f6d0282150
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3820381Reviewed-by: 's avatarIgor Sheludko <ishell@chromium.org>
      Commit-Queue: Camillo Bruni <cbruni@chromium.org>
      Cr-Commit-Position: refs/heads/main@{#82350}
      012fa899
  3. 09 Aug, 2022 2 commits
    • Tobias Tebbi's avatar
      Revert "Reland "[shared-struct] Add Atomics.Condition"" · 74d4f133
      Tobias Tebbi authored
      This reverts commit b1020a43.
      
      Reason for revert: Causes timeout for `condition-workers`: https://ci.chromium.org/ui/p/v8/builders/ci/V8%20Linux%20-%20debug/40516/overview
      
      Original change's description:
      > Reland "[shared-struct] Add Atomics.Condition"
      >
      > This is a reland of commit e2066ff6
      >
      > Changes since revert:
      > - Rebased against c9918524, which
      >   uses the external pointer table for the WaiterQueueNode stored
      >   in the state field when compressing pointers. This relaxes
      >   the alignment requirement of the state field to be 4-bytes when
      >   compressing pointers.
      > - Moved the state field into the JSSynchronizationPrimitive base
      >   class, since alignment and padding can now be made simpler.
      >
      > Original change's description:
      > > [shared-struct] Add Atomics.Condition
      > >
      > > Bug: v8:12547
      > > Change-Id: Id439aef9cab3348171a23378cdd47ede5f4d7288
      > > Cq-Include-Trybots: luci.v8.try:v8_linux_arm64_rel_ng,v8_linux64_tsan_rel_ng
      > > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3630350
      > > Reviewed-by: Dominik Inführ <dinfuehr@chromium.org>
      > > Reviewed-by: Adam Klein <adamk@chromium.org>
      > > Commit-Queue: Shu-yu Guo <syg@chromium.org>
      > > Cr-Commit-Position: refs/heads/main@{#81734}
      >
      > Bug: v8:12547
      > Change-Id: I638304c3d5722c64bd04708ed4cf84863cdebb81
      > Cq-Include-Trybots: luci.v8.try:v8_linux_arm64_rel_ng,v8_linux64_tsan_rel_ng
      > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3763787
      > Reviewed-by: Adam Klein <adamk@chromium.org>
      > Commit-Queue: Shu-yu Guo <syg@chromium.org>
      > Reviewed-by: Dominik Inführ <dinfuehr@chromium.org>
      > Cr-Commit-Position: refs/heads/main@{#82278}
      
      Bug: v8:12547
      Change-Id: I27c2aeb131f1b68c2240323189db88d552aa92f9
      Cq-Include-Trybots: luci.v8.try:v8_linux_arm64_rel_ng,v8_linux64_tsan_rel_ng
      No-Presubmit: true
      No-Tree-Checks: true
      No-Try: true
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3817187
      Bot-Commit: Rubber Stamper <rubber-stamper@appspot.gserviceaccount.com>
      Auto-Submit: Tobias Tebbi <tebbi@chromium.org>
      Owners-Override: Tobias Tebbi <tebbi@chromium.org>
      Commit-Queue: Rubber Stamper <rubber-stamper@appspot.gserviceaccount.com>
      Cr-Commit-Position: refs/heads/main@{#82292}
      74d4f133
    • Shu-yu Guo's avatar
      Reland "[shared-struct] Add Atomics.Condition" · b1020a43
      Shu-yu Guo authored
      This is a reland of commit e2066ff6
      
      Changes since revert:
      - Rebased against c9918524, which
        uses the external pointer table for the WaiterQueueNode stored
        in the state field when compressing pointers. This relaxes
        the alignment requirement of the state field to be 4-bytes when
        compressing pointers.
      - Moved the state field into the JSSynchronizationPrimitive base
        class, since alignment and padding can now be made simpler.
      
      Original change's description:
      > [shared-struct] Add Atomics.Condition
      >
      > Bug: v8:12547
      > Change-Id: Id439aef9cab3348171a23378cdd47ede5f4d7288
      > Cq-Include-Trybots: luci.v8.try:v8_linux_arm64_rel_ng,v8_linux64_tsan_rel_ng
      > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3630350
      > Reviewed-by: Dominik Inführ <dinfuehr@chromium.org>
      > Reviewed-by: Adam Klein <adamk@chromium.org>
      > Commit-Queue: Shu-yu Guo <syg@chromium.org>
      > Cr-Commit-Position: refs/heads/main@{#81734}
      
      Bug: v8:12547
      Change-Id: I638304c3d5722c64bd04708ed4cf84863cdebb81
      Cq-Include-Trybots: luci.v8.try:v8_linux_arm64_rel_ng,v8_linux64_tsan_rel_ng
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3763787Reviewed-by: 's avatarAdam Klein <adamk@chromium.org>
      Commit-Queue: Shu-yu Guo <syg@chromium.org>
      Reviewed-by: 's avatarDominik Inführ <dinfuehr@chromium.org>
      Cr-Commit-Position: refs/heads/main@{#82278}
      b1020a43
  4. 02 Aug, 2022 1 commit
    • Michael Lippautz's avatar
      Revert "[heap, api] Check assumptions for embedder fields on set" · bcd0fa55
      Michael Lippautz authored
      This reverts commit 61193620.
      
      Reason for revert: Blocking roll: https://chromium-review.googlesource.com/c/chromium/src/+/3802992/
      
      Original change's description:
      > [heap, api] Check assumptions for embedder fields on set
      >
      > Previously, we would set embedder fields and do type checks (on
      > embedder fields) in the GC. This does not work nicely as embedder
      > fields contain system pointers whereas we can only operate with
      > tag-aligned reads/writes. The end result of assembling pointers was
      > somtimes broken for concurrent marking.
      >
      > In this CL we reverse the mode and check assumptions when writing the
      > fields. From Blink we generally only write once and use the fields in
      > the GC and via reads multiple times.
      >
      > We assume, that when running with CppHeap, any pointer on an instance
      > field that points into CppHeap, also has the type field set with the
      > appropriate tracing information. In debug builds we also verify that
      > the embedder field indeed points to the start of an Oilpan object.
      >
      > Bug: chromium:1337690
      > Change-Id: I9f9a8e691cdcf666861a455dcf8f65f2fe80b034
      > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3788206
      > Commit-Queue: Michael Lippautz <mlippautz@chromium.org>
      > Reviewed-by: Dominik Inführ <dinfuehr@chromium.org>
      > Reviewed-by: Omer Katz <omerkatz@chromium.org>
      > Reviewed-by: Igor Sheludko <ishell@chromium.org>
      > Cr-Commit-Position: refs/heads/main@{#82120}
      
      Bug: chromium:1337690
      Change-Id: Iaece8f51883c7d001fb18ef48faaf271c48b8f11
      No-Presubmit: true
      No-Tree-Checks: true
      No-Try: true
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3804245
      Commit-Queue: Leszek Swirski <leszeks@chromium.org>
      Owners-Override: Leszek Swirski <leszeks@chromium.org>
      Bot-Commit: Rubber Stamper <rubber-stamper@appspot.gserviceaccount.com>
      Cr-Commit-Position: refs/heads/main@{#82127}
      bcd0fa55
  5. 01 Aug, 2022 1 commit
    • Michael Lippautz's avatar
      [heap, api] Check assumptions for embedder fields on set · 61193620
      Michael Lippautz authored
      Previously, we would set embedder fields and do type checks (on
      embedder fields) in the GC. This does not work nicely as embedder
      fields contain system pointers whereas we can only operate with
      tag-aligned reads/writes. The end result of assembling pointers was
      somtimes broken for concurrent marking.
      
      In this CL we reverse the mode and check assumptions when writing the
      fields. From Blink we generally only write once and use the fields in
      the GC and via reads multiple times.
      
      We assume, that when running with CppHeap, any pointer on an instance
      field that points into CppHeap, also has the type field set with the
      appropriate tracing information. In debug builds we also verify that
      the embedder field indeed points to the start of an Oilpan object.
      
      Bug: chromium:1337690
      Change-Id: I9f9a8e691cdcf666861a455dcf8f65f2fe80b034
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3788206
      Commit-Queue: Michael Lippautz <mlippautz@chromium.org>
      Reviewed-by: 's avatarDominik Inführ <dinfuehr@chromium.org>
      Reviewed-by: 's avatarOmer Katz <omerkatz@chromium.org>
      Reviewed-by: 's avatarIgor Sheludko <ishell@chromium.org>
      Cr-Commit-Position: refs/heads/main@{#82120}
      61193620
  6. 28 Jul, 2022 1 commit
  7. 27 Jul, 2022 2 commits
  8. 26 Jul, 2022 2 commits
  9. 22 Jul, 2022 1 commit
  10. 19 Jul, 2022 1 commit
  11. 15 Jul, 2022 2 commits
  12. 14 Jul, 2022 2 commits
  13. 12 Jul, 2022 2 commits
  14. 08 Jul, 2022 1 commit
  15. 05 Jul, 2022 1 commit
  16. 30 Jun, 2022 1 commit
  17. 24 Jun, 2022 1 commit
  18. 22 Jun, 2022 2 commits
  19. 20 Jun, 2022 1 commit
  20. 15 Jun, 2022 1 commit
  21. 09 Jun, 2022 1 commit
  22. 08 Jun, 2022 3 commits
  23. 03 Jun, 2022 1 commit
  24. 02 Jun, 2022 1 commit
  25. 01 Jun, 2022 2 commits
  26. 31 May, 2022 1 commit
    • Dominik Inführ's avatar
      [heap] Drop UPDATE_WEAK_WRITE_BARRIER write barrier mode · 94ca8fa8
      Dominik Inführ authored
      Replace all usages of UPDATE_WEAK_WRITE_BARRIER with
      UPDATE_WRITE_BARRIER. The barrier wasn't hot, so the additional branch
      for the marking barrier shouldn't be a problem.
      
      Performing the marking barrier could in theory cause more floating
      garbage. However in this case the write barrier is only run once
      directly after e.g. allocating a Code or NativeContext object. Since
      UPDATE_WEAK_WRITE_BARRIER only skips the marking barrier, we should only
      observe different behavior when marking is on. But since we already
      have black allocation for objects in old space, we will not cause
      additional floating garbage.
      
      In case of performance regression, we should also be able to replace
      those usages with SKIP_WRITE_BARRIER, since NativeContext and Code
      objects are never allocated in the young generation, so running the
      generational barrier shouldn't be necessary. It's just hard to DCHECK
      that SKIP_WRITE_BARRIER is valid here.
      
      Bug: v8:11708
      Change-Id: I25d760a46d1d7ec973cc589f51ddf80ca3b5419d
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3663080Reviewed-by: 's avatarLeszek Swirski <leszeks@chromium.org>
      Reviewed-by: 's avatarIgor Sheludko <ishell@chromium.org>
      Reviewed-by: 's avatarMichael Lippautz <mlippautz@chromium.org>
      Commit-Queue: Dominik Inführ <dinfuehr@chromium.org>
      Cr-Commit-Position: refs/heads/main@{#80839}
      94ca8fa8
  27. 28 May, 2022 3 commits
  28. 25 May, 2022 1 commit