[lldb-dev] [Bug 30789] New: Watchpoint::SetEnabled & therefore SBWatchpoint::SetEnabled don't actually disable a watchpoint

via lldb-dev lldb-dev at lists.llvm.org
Tue Oct 25 13:43:30 PDT 2016


https://llvm.org/bugs/show_bug.cgi?id=30789

            Bug ID: 30789
           Summary: Watchpoint::SetEnabled & therefore
                    SBWatchpoint::SetEnabled don't actually disable a
                    watchpoint
           Product: lldb
           Version: unspecified
          Hardware: All
                OS: All
            Status: NEW
          Severity: normal
          Priority: P
         Component: All Bugs
          Assignee: lldb-dev at lists.llvm.org
          Reporter: jingham at apple.com
                CC: llvm-bugs at lists.llvm.org
    Classification: Unclassified

This is on MacOS x86_64:

Build the test case in functionalities/watchpoint/watchpoint_command/command
and do:

(lldb) b s -p "Set break"
Breakpoint 2: where = a.out`main + 63 at main.cpp:22, address =
0x0000000100000ecf
(lldb) run
Process 98597 launched: 'a.out' (x86_64)
&global=0x100001018
Process 98597 stopped
* thread #1: tid = 0x1740788, function: main , stop reason = breakpoint 2.1
    frame #0: 0x0000000100000ecf a.out`main at main.cpp:22
   19      int main(int argc, char** argv) {
   20          int local = 0;
   21          printf("&global=%p\n", &global);
-> 22          printf("about to write to 'global'...\n"); // Set break point at
this line.
   23          for (int i = 0; i < 10; ++i)
   24              modify(global);
   25      
(lldb) watch set variable global
Watchpoint created: Watchpoint 1: addr = 0x100001018 size = 4 state = enabled
type = w
    declare @ 'main.cpp:12'
    watchpoint spec = 'global'
    new value: 0
(lldb) c
Process 98597 resuming
about to write to 'global'...

Watchpoint 1 hit:
old value: 0
new value: 1
Process 98597 stopped
* thread #1: tid = 0x1740788, function: modify(int&) , stop reason = watchpoint
1
    frame #0: 0x0000000100000f53 a.out`modify(int&) at main.cpp:17
   14      
   15      static void modify(int32_t &var) {
   16          ++var;
-> 17      }
   18      
   19      int main(int argc, char** argv) {
   20          int local = 0;
(lldb) script lldb.target.FindWatchpointByID(1).SetEnabled(False)
(lldb) watch list
Number of supported hardware watchpoints: 4
Current watchpoints:
Watchpoint 1: addr = 0x100001018 size = 4 state = disabled type = w
    declare @ 'main.cpp:12'
    watchpoint spec = 'global'
    old value: 0
    new value: 1
(lldb) c
Process 98597 resuming
Process 98597 stopped
* thread #1: tid = 0x1740788, function: modify(int&) , stop reason =
EXC_BREAKPOINT (code=EXC_I386_SGL, subcode=0x100001018)
    frame #0: 0x0000000100000f53 a.out`modify(int&) at main.cpp:17
   14      
   15      static void modify(int32_t &var) {
   16          ++var;
-> 17      }
   18      
   19      int main(int argc, char** argv) {
   20          int local = 0;

So the watchpoint says it was disabled, but it actually didn't get disabled,
and we hit it on continue.

-- 
You are receiving this mail because:
You are the assignee for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/lldb-dev/attachments/20161025/9481276a/attachment.html>


More information about the lldb-dev mailing list