Issue 132473
Summary LLDB breaks on adding a breakpoint using python
Labels new issue
Assignees
Reporter abocquet
    Hello, 

I wanted a LLDB breakpoint callback to add another breakpoint on the next frame in the callstack, but LLDB raises an exception on running the next breakpoint. Here is a minimal working example.

I have a file trace_mvp.py with the following code:
```
import lldb

def syscall_callback(frame: lldb.SBFrame, bp_loc, internal_dict):
 print("[+] Entering syscall_callback")
    thread = frame.GetThread()

 # print backtrace for debug
    for frame in thread.get_thread_frames():
        print(frame)

    # address of the next frame
    next_frame_pc = thread.get_thread_frames()[1].GetPC()
   
 print("[+] Add breakpoint at : ", hex(next_frame_pc))
    target = thread.GetProcess().GetTarget()
    bp = target.BreakpointCreateByAddress(next_frame_pc)
 bp.SetScriptCallbackFunction("trace_mvp.bp_callback")
 print(bp)


def bp_callback(frame: lldb.SBFrame, bp_loc, internal_dict):
 print("[+] Hello from bp_callback")

def __lldb_init_module(debugger, internal_dict):
    debugger.HandleCommand('breakpoint set -n write')
 debugger.HandleCommand('breakpoint command add -s python -F trace_mvp.syscall_callback')
    debugger.HandleCommand('run') 
```

This code adds a breakpoint on all write syscall. Then, at each stop it is supposed to add another breakpoint on the frame above in the stack, and print a message when it reaches it.

On the side I have a small Python file with a single print
```
print("Hello world")
```

In the terminal I run
```
# in bash
lldb python hello_world.py
# inside LLDB
command script import trace_mvp.py
```

On running the syscall_callback the breakpoint is added to the right address (here 0x101328b74) but LLDB still raises an error
```
Breakpoint 1: 137 locations.
Process 8128 launched: '/Users/macm1/.venv/bin/python' (arm64)
14 locations added to breakpoint 1
frame #0: 0x0000000188f758ec libsystem_kernel.dylib`write
frame #1: 0x0000000101328b74 libpython3.11.dylib`_Py_write_impl + 128
[rest of the stack]
[+] Add breakpoint at :  0x101328b74
SBBreakpoint: id = 2, address = libpython3.11.dylib[0x0000000000174b74], locations = 1
Traceback (most recent call last):
  File "<string>", line 8, in lldb_autogen_python_bp_callback_func__0
KeyError: 'lldb_autogen_python_bp_callback_func__1'
Process 8128 stopped
```
When I set the wrong function name on purpose, the error is not raised.
I'm running on macOS 15.1 with LLDB lldb-1600.0.39.109

This is a repost from https://stackoverflow.com/questions/79520679/lldb-breaks-on-adding-a-breakpoint-using-python, where [Jim Ingham](https://stackoverflow.com/users/2465073/jim-ingham) told me this was likely a bug and that I should open an issue.
_______________________________________________
llvm-bugs mailing list
llvm-bugs@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-bugs

Reply via email to