汇编 - 无法设置断点lldb

时间:2016-04-22 22:02:21

标签: macos assembly nasm x86-64 lldb

我收集了这些选项nasm -O0 -g -f macho64,但lldb抱怨"无法解决任何实际位置的断点。"当我尝试在文件中的行号设置任何断点时。

我已经开始尝试为OS X学习64位程序集,但它到目前为止证明是一个真正的挑战,似乎几乎没有任何学习资源。

1 个答案:

答案 0 :(得分:2)

您的汇编程序可能没有为您创建的二进制文件发出任何调试信息。您可以通过在dwarfdump --debug-line文件或.o捆绑包上运行.dSYM来查找二进制文件(如果有)。

将二进制文件加载到lldb并运行disassemble -n function-name命令。这将显示程序集 - 然后您可以使用breakpoint set -a address设置断点。默认情况下,lldb将关闭地址空间随机化(ASLR)来运行二进制文件 - 因此二进制文件每次都在同一地址运行,而不是将程序加载到随机地址。

一个简单的例子:

%  echo 'int main () { }' > a.c
% clang a.c
% lldb a.out
(lldb) target create "a.out"
Current executable set to 'a.out' (x86_64).
(lldb) disass -n main
a.out`main:
a.out[0x100000fb0] <+0>: pushq  %rbp
a.out[0x100000fb1] <+1>: movq   %rsp, %rbp
a.out[0x100000fb4] <+4>: xorl   %eax, %eax
a.out[0x100000fb6] <+6>: popq   %rbp
a.out[0x100000fb7] <+7>: retq   

(lldb) br s -a 0x100000fb4
Breakpoint 1: address = 0x0000000100000fb4
(lldb) r
Process 32406 launched: '/private/tmp/a.out' (x86_64)
Process 32406 stopped
* thread #1: tid = 0x145576, 0x0000000100000fb4 a.out`main + 4, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
    frame #0: 0x0000000100000fb4 a.out`main + 4
a.out`main:
->  0x100000fb4 <+4>: xorl   %eax, %eax
    0x100000fb6 <+6>: popq   %rbp
    0x100000fb7 <+7>: retq   
    0x100000fb8:      addl   %eax, (%rax)
(lldb)