[Lldb-commits] [PATCH] D149792: Add AArch64 MASK watchpoint support to debugserver

Jason Molenda via Phabricator via lldb-commits lldb-commits at lists.llvm.org
Wed May 3 15:11:43 PDT 2023


jasonmolenda created this revision.
jasonmolenda added a reviewer: JDevlieghere.
jasonmolenda added a project: LLDB.
Herald added subscribers: omjavaid, kristof.beyls.
Herald added a project: All.
jasonmolenda requested review of this revision.
Herald added a subscriber: lldb-commits.

AArch64 supports two types of watchpoints - 1-8 byte watchpoints, which can watch up to 8 contiguous bytes aligned to a doubleword boundary, and mask watchpoints that can watch any power-of-2 range of memory aligned to that boundary (BAS watchpoints and MASK watchpoints).  This patch adds support for MASK watchpoints when the user requests larger than 8 bytes be watched.

The major caveat with this is that there remains real work in lldb to support large watchpoints.  If a user asks to watch 192 bytes, aligned to a 256 byte boundary, we still need to watch 256 bytes.  Writes to the final 64 bytes will trap the watchpoint, and we need to work out how to silently skip these watchpoint hits.  Watchpoints have a type: "read", "write", and I expect I'll add a new type "modify" that is the default, and stops when the memory region being watched *changes*.

(this problem of a mask watchpoint watching a larger memory range than the user expected is exacerbated with a memory region not properly aligned to that power-of-2 size.  and it can come up easily with smaller objects, e.g. a 24 byte object requires a 32-byte watchpoint, or possibly two watchpoints if it's not aligned to a 32-byte boundary.)

The changes I did https://reviews.llvm.org/D149040 make this patch mostly a simple drop-in of the method for setting the debug control register properly for MASK watchpoints.  There are some extra changes to the method which takes a trap address and tries to find the hardware watchpoint register which resulted in that watchpoint hit.  (we further refine this later based on the user's watchpoint requests, using a "nearest wp wins" if no watched region correctly includes it, for AArch64 reasons.)

I added a test case with an array of uint32_t's, watch 256 of those unit32_t's, and a loop that modifies every 16th uint32_t.  The test confirms that we hit this 256-uint32_t's watchpoint 16 times.


Repository:
  rG LLVM Github Monorepo

https://reviews.llvm.org/D149792

Files:
  lldb/test/API/functionalities/watchpoint/large-watchpoint/Makefile
  lldb/test/API/functionalities/watchpoint/large-watchpoint/TestLargeWatchpoint.py
  lldb/test/API/functionalities/watchpoint/large-watchpoint/main.c
  lldb/test/API/python_api/watchpoint/watchlocation/TestTargetWatchAddress.py
  lldb/tools/debugserver/source/MacOSX/arm64/DNBArchImplARM64.cpp
  lldb/tools/debugserver/source/MacOSX/arm64/DNBArchImplARM64.h

-------------- next part --------------
A non-text attachment was scrubbed...
Name: D149792.519271.patch
Type: text/x-patch
Size: 13864 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/lldb-commits/attachments/20230503/ab1484d1/attachment-0001.bin>


More information about the lldb-commits mailing list