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

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

 

  • 11
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值