1. 18 Mar, 2020 16 commits
  2. 17 Mar, 2020 18 commits
  3. 16 Mar, 2020 6 commits
    • Milad Farazmand's avatar
      PPC/s390: [wasm] Load register values from DebugBreak frame · fcf5d2a7
      Milad Farazmand authored
      Port ae03752f
      
      Original Commit Message:
      
          This implements inspection of live registers on breakpoints in Liftoff.
          To that end, the frame pointer of the WasmDebugBreak frame is remembered
          when iterating the stack. Based on a platform-specific implementation of
          {WasmDebugBreakFrameConstants}, the offset of the respective register
          within that frame is computed, and the value is read from the frame.
      
          As a drive-by, the wasm debug side table is storing register codes as
          liftoff codes, which can also store register pairs (needed for i64 on
          32-bit platforms, and for SIMD, which is not supported yet).
      
      R=clemensb@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
      BUG=
      LOG=N
      
      Change-Id: I1f4a52c349bd57098f633c5fd641642695b6fe96
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2106294Reviewed-by: 's avatarJunliang Yan <jyan@ca.ibm.com>
      Commit-Queue: Milad Farazmand <miladfar@ca.ibm.com>
      Cr-Commit-Position: refs/heads/master@{#66737}
      fcf5d2a7
    • Milad Farazmand's avatar
      PPC/s390: [wasm] Fix registers spilled in DebugBreak frame · e54259ee
      Milad Farazmand authored
      Port e47f9a9d
      
      Original Commit Message:
      
          The set of registers to spill was wrong. Instead of spilling wasm
          parameter registers (like the WasmCompileLazy builtin), we should spill
          all registers that are being used as Liftoff cache registers.
          This CL defines platform-specific WasmDebugBreakFrameConstants which
          hold the set of registers to spill. This set is used in the builtin, and
          will later be used for inspecting the spilled registers.
      
          In order to iterate bit sets more easily in both direction (MSB to LSB
          or LSB to MSB), we add a base::bits::IterateBits{,Backwards} method
          which provides the respective iterators.
      
      R=clemensb@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
      BUG=
      LOG=N
      
      Change-Id: Ic308a7712f080e43a0c45f496b087ce8450f657a
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2105563Reviewed-by: 's avatarJunliang Yan <jyan@ca.ibm.com>
      Commit-Queue: Milad Farazmand <miladfar@ca.ibm.com>
      Cr-Commit-Position: refs/heads/master@{#66736}
      e54259ee
    • Ng Zhi An's avatar
      [wasm-simd][liftoff][arm][arm64] Implement extract_lane · b7971e95
      Ng Zhi An authored
      Implement all 8 extract_lane ops on ARM and ARM64.
      
      Bug: v8:9909
      Change-Id: I72e30b53c92933bd5830008ec02e1f4526e8b4c4
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2103169
      Commit-Queue: Zhi An Ng <zhin@chromium.org>
      Reviewed-by: 's avatarClemens Backes <clemensb@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66735}
      b7971e95
    • Joyee Cheung's avatar
      [class] error when accessing unused static private method at debug time · f2fd4923
      Joyee Cheung authored
      At the moment when the static private method is unused
      in source code (either explicitly or through eval) but is accessed
      at runtime through the debugger, and there are no other potential
      references to the class variable in the source code otherwise,
      the reference to the class variable is lost here since the class
      variable would not be context-allocated, then we could not rebuild
      a proper brand check for it.
      
      For now, a ReferenceError would be thrown and the method is considered
      "optimized away", similar to how unused ordinary methods in closures
      work. Before this patch it would DCHECK when generating bytecode
      for the debugger instead of throwing errors.
      
      Bug: v8:9839, v8:8330
      Change-Id: I5d63131a7bdba141d01a3e6459bc27d0f5953c1a
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2095637
      Commit-Queue: Joyee Cheung <joyee@igalia.com>
      Reviewed-by: 's avatarRoss McIlroy <rmcilroy@chromium.org>
      Reviewed-by: 's avatarShu-yu Guo <syg@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66734}
      f2fd4923
    • Ng Zhi An's avatar
      [wasm-simd][liftoff][arm][arm64] Implement adds · 817ba0a2
      Ng Zhi An authored
      Implement f64x2.add, i64x2.add, i8x16.add on ARM and ARM64.
      
      Bug: v8:9909
      Change-Id: Id41bb3c02c1873e1380463264a3e5fd31949c949
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2103107
      Commit-Queue: Zhi An Ng <zhin@chromium.org>
      Reviewed-by: 's avatarClemens Backes <clemensb@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66733}
      817ba0a2
    • Dominik Inführ's avatar
      [heap] Introduce safepoint mechanism · 64759d44
      Dominik Inführ authored
      Add safepoint mechanism to stop concurrent threads and bring them to a
      safepoint. Threads are stopped before the safepoint and after e.g. the
      GC resumed again. Each thread needs to be stopped in a safepoint, such
      that all roots can be iterated safely.
      
      Running threads need to be cooperative and are required to perform
      regular safepoint polls.
      
      The last version of this CL was reverted because safepoint_requested_
      wasn't initialized (see https://crrev.com/c/2105634).
      
      Bug: v8:10315
      Change-Id: I6ef244c0fb31c178589b5e3d1c62687a8dd65768
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2105635Reviewed-by: 's avatarUlan Degenbaev <ulan@chromium.org>
      Commit-Queue: Dominik Inführ <dinfuehr@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66732}
      64759d44