GDB中断点使用都很简单,如果我们要断点在函数main开始,直接b main就行。
图1
如上图所示停留在断点1,main函数开始处。汇编看到是在第四条汇编指令,那前3条指令都做了些什么?
第一条指令是将rbp寄存器压栈,rbp寄存器保存的是栈帧的底部,这里是将调用main函数的函数(这里main是被调用函数)的栈帧底部压栈。
第二条汇编指令是将rsp寄存器的值存入rbp寄存器中,rsp寄存器是当前函数main的栈帧的顶部,
第三条指令是将rsp值减去0x10大小,这里是预留栈空间。第二条指令和第三条指令就是建立main函数的栈帧,新的栈帧底部地址存在rbp寄存器栈,顶部在rsp指向的位置。
那如果我们想将断点设在上图栈汇编的任意指令位置,例如我们想断点停留在第9条指令处,那该怎么做?
在上图可以看到蓝线处所标示的就是第九条汇编指令,首先看看我们如何断点在main函数的第一条汇编指令位置处?
图2
如上图2所示b *main,这样就能够断点在main函数的第一条汇编指令的位置。
图1中蓝线所在的汇编指令,偏移main函数的开始位置为30,那么如果想断点在这里,可以按如下操作。
图3