10

在GDB中,我可以使用“info line func_name”得到func_name的内存地址,然后使用“set $PC=memory_address”开始调试这个函数。我如何在 lldb 中做同样的事情?提前致谢!

4

1 回答 1

18

lldb 中的命令是“图像查找”。我认为最近将“信息功能”<->“图像查找”的示例添加到 lldb/gdb 命令页面 - http://lldb.llvm.org/lldb-gdb.html

例如

(lldb) im loo -n puts
1 match found in /usr/lib/system/libsystem_c.dylib:
        Address: libsystem_c.dylib[0x0000000000011d9a] (libsystem_c.dylib.__TEXT.__text + 69850)
        Summary: libsystem_c.dylib`puts
(lldb) 

虽然这仅向您显示 libsystem_c.dylib 中的偏移量 (0x11d9a) - 要查看实际加载地址,您需要使用“-v”选项进行图像查找,该选项将显示放​​置覆盖的地址范围。或者您可以更直接地使用 lldb 中的反勾号符号来执行此操作,

(lldb) reg read pc
     rip = 0x0000000100000f2b  a.out`main + 11 at a.c:3
(lldb) reg write pc `(void(*)())puts`
(lldb) reg read pc
     rip = 0x00007fff99ce1d9a  libsystem_c.dylib`puts

好的,我不得不转换 puts() 因为 lldb 在这里需要一个函数原型 - 不是超级方便,但如果它是你自己不需要的函数之一:

(lldb) reg write pc `main`
(lldb) reg read pc
     rip = 0x0000000100000f20  a.out`main at a.c:2
于 2012-09-23T10:46:35.333 回答