gdb调试--汇编指令处断点

GDB中断点使用都很简单,如果我们要断点在函数main开始,直接b main就行。

 

gdb调试--汇编指令处断点_第1张图片

 图1

 

如上图所示停留在断点1,main函数开始处。汇编看到是在第四条汇编指令,那前3条指令都做了些什么?

第一条指令是将rbp寄存器压栈,rbp寄存器保存的是栈帧的底部,这里是将调用main函数的函数(这里main是被调用函数)的栈帧底部压栈。

第二条汇编指令是将rsp寄存器的值存入rbp寄存器中,rsp寄存器是当前函数main的栈帧的顶部,

第三条指令是将rsp值减去0x10大小,这里是预留栈空间。第二条指令和第三条指令就是建立main函数的栈帧,新的栈帧底部地址存在rbp寄存器栈,顶部在rsp指向的位置。

 

 

那如果我们想将断点设在上图栈汇编的任意指令位置,例如我们想断点停留在第9条指令处,那该怎么做?

在上图可以看到蓝线处所标示的就是第九条汇编指令,首先看看我们如何断点在main函数的第一条汇编指令位置处?

gdb调试--汇编指令处断点_第2张图片

图2

 

如上图2所示b *main,这样就能够断点在main函数的第一条汇编指令的位置。

1中蓝线所在的汇编指令,偏移main函数的开始位置为30,那么如果想断点在这里,可以按如下操作。

gdb调试--汇编指令处断点_第3张图片

图3

 

你可能感兴趣的:(linux,gdb,调试)