首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

GDB调试汇编分析

GDB调试汇编分析 代码 本次实践我参照了许多先做了的同学的博客,有卢肖明,高其,张梓靖同学。代码借用的是卢肖明同学的代码进行调试运行。...GCC编译 使用gcc -g gdbtest.c -o gdbtest -m32命令在64位的机器上产生32位汇编代码 在使用gdb进行调试运行时,有cgdb和gdb两种工具,我建议大家使用张梓靖同学使用的...分析过程 使用b main指令在main函数处设置断点,然后,使用r指令运行代码,使用disassemble指令获取汇编代码 ?...可见此时主函数的栈基址为0xffffd068,用x(examine)指令查看内存地址中的值,但目前%esp所指堆栈内容为0,%ebp所指内容也为0 用i r指令查看各寄存器的值 依次如下指令调试汇编代码...gdb调试分析汇总表 ? ?

3.2K21
您找到你想要的搜索结果了吗?
是的
没有找到

GDB 调试

本文链接:https://blog.csdn.net/weixin_40313634/article/details/88619906 实验楼值GDB常用命令实战课程学习记录 1....安装工具: sudo apt-get install gdb 2. 编译可调式程序: gcc bugging.c -o bugging -g -m32 -o: 生成的可执行文件的名字。...-g: 生成的程序允许gdb 调试。 -m32:生成32位的程序。默认,程序位数和OS位数相同。 编译32位程序时报错:fatal error: sys/cdefs.h: 没有那个文件或目录。...调试: 开始调试:gdb bugging 结束调试:quit 断点在循环中时: enable once Num // 断点hit 一次后,失效。...info locals 命令 简写 说明 list l 查看附近源码 next n 执行下一步 step s 一次执行一行,遇到函数会进入 break b 设置断点 info breakpoints 显示断点信息

1.5K30

GDB调试

通过cd命令可以更改目录,pwd显示当前所在目录 准备就绪后就可以真正开始用GDB来调试程序了。...nopass/ignore:收到信号时,GDB不会让程序看到整个信号 查询信号处理情况: info signals info handle 线程 info threads:显示所有线程 thread...配合的非常好),GDB提供了相应的命令来显示和查找源代码。...disassemble:反汇编代码,细节查看help disassemble 检查和设置变量 调试最终要查看程序运行的状态,通过观察当前各个变量或者表达式的值来判断程序当前是否符合预期,如果不符合预期,...x 按十六进制格式显示变量 d 按十进制格式显示变量 u 按无符号十进制显示变量 o 按八进制格式显示变量 t 按二进制格式显示变量 a address和x效果差不多 c 按字符格式显示变量 f 按浮点格式显示变量

2.1K10

GDB调试技巧】提高gdb的调试效率

GDB启动时,可以加上一些GDB的启动开关,详细的开关可以用gdb的help查看。 gdb技巧 1. gdb小技巧汇总 gdb技巧挺多的,比如说直接回车是继续执行上一次的代码 巧用tab补全 1....比如输入b连续按下两次tab,可以查看gdb的所有b开头的gdb指令 2....TUI 模式:GDB 的界面会分为几个窗格,包括源代码窗格、汇编窗格、寄存器窗格等。 按下ctrl x a会显示下图的窗口(可以上下滑动查看原代码),其中箭头表示【当前准备执行但还未执行的开始位置】。...list 查看代码内容 list list 与 l 等价 如果没有指定参数,list 命令默认会显示当前执行位置的附近源代码。也可以指定行号或者函数名作为参数,以显示特定位置的源代码。...list: 显示当前执行位置周围的源代码。 list function_name: 显示名为 function_name 的函数的源代码。 list line_number: 显示指定行号的源代码。

8910

GDB高级技巧

GDB高级技巧 yijian 2009-2-22 难得有雅兴,边动手边记录操作步骤,本文主要示例一些平常较少使用到的GDB功能,掌握这些用法有助于提高GDB调试和解决问题的能力。...1) 查看宏 默认情况下,在GDB中是不能查看宏的值及定义的,但通过如下方法,则可以达到目的: 编译源代码时,加上“-g3 -gdwarf-2”选项,请注意不是“-g”,必须为“-g3”,查看宏的值使用命令...假如想在print命令前显示一段“----------”,则: define hook-print echo ----------\n end 注意“hook-”后接的必须是命令全称,不能是缩写...如果想在命令执行完,再执行某个或某些命令,则: #define hookpost-print echo ----------\n end 7) GDB中循环 GDB支持if/else/while.../loop_break/loop_continue,如: (gdb) set $x=1 (gdb) while $x==1  >p $x  >set $x=0  >p $x  >end -

1.4K10

全志D1s裸机开发之体验第一个程序

next n 执行下一行 nexti ni 执行下一行(以汇编代码为单位) step s 一次执行一行,包括函数内部 setpi si 执行下一行 list l 显示函数或行 print p 显示表达式...-tui benos_payload.elf 执行上述命令后,可以得到如下界面(源码窗口里的汉字是乱码,暂时无法解决): 使用 TUI 的便利在于可以方便地观看源码、反汇编码、寄存器,显示这些信息的窗口被称为...使用以下命令可以显示这些 layout : ① layout src:显示源码窗口 ② layout asm:显示汇编窗口 ③ layout regs:在之前的窗口上再显示寄存器窗口 ④ layout...split:显示源码、汇编窗口 ⑤ layout next:显示下一个 layout ⑥ layout prev:显示上一个 layout 能输入各类 GDB 命令的窗口是 命令窗口 ,它总是显示的。...要同时显示源码和寄存器,可以执行如下 2 个命令: layout src layout regs 要同时显示汇编码和寄存器,可以执行如下 2 个命令: layout asm layout regs 要同时显示源码和反汇编

13410

gdb 基础命令

命令 解释 示例 file 加载被调试的可执行文件 如果执行gdb与被调试的程序不在同个目录,则需要带上路径 (gdb) file gdb_sample l List 的缩写,打印源码...在gcc/g++ 编译程序时,需要加上-g 选项 (gdb) l 1 r Run 的缩写,运行程序 (gdb) r c Continue 的缩写,继续执行程序,直到下一个断点或程序结束 (gdb...(gdb) n p Print 的缩写, 打印变量的值 (gdb) p i bt Backtrace 的缩写,查看堆栈信息 (gdb) bt q Quit 的缩写,退出gdb 调试环境...月 9 17:19 gdb_sample 可以用 gdb gdb_sample 直接进入调试环境,也可以先启动gdb,再打开可执行文件: GNU gdb (GDB) Red Hat Enterprise...(gdb) 上面表示可执行文件已经加载成功,(gdb) 是gdb内部命令引导符,等待用户输入命令 下面使用l 命令来查看源码,可以指定行号,回车可以继续往下查看: (gdb) l 1 1

1.1K220

gdb基本用法

列出从第几行开始的源代码 list 函数名 列出某个函数的源代码 next(或n) 执行下一行语句 print(或p) 打印表达式的值,通过表达式可以修改变量的值或者调用函数 quit(或q) 退出gdb...break … if … 设置条件断点 continue(或c) 从当前位置开始连续运行程序 delete breakpoints 断点号 删除断点 display 变量名 跟踪查看某个变量,每次停下来都显示它的值...breakpoints 断点号 禁用断点 enable 断点号 启用断点 info(或i) breakpoints 查看当前设置了哪些断点 run(或r) 从头开始连续运行程序 undisplay 跟踪显示号...取消跟踪显示 观察点 命令 描述 watch 设置观察点 info(或i) watchpoints 查看当前设置了哪些观察点 x 从某个位置开始打印存储单元的内容,全部当成字节来看,而不区分哪个字节属于哪个变量...资料 gdb使用

66620

使用gdb调试程序

g++ test.cpp -g -o test gdb test #调试程序 gdb test -tui #显示代码窗口 另一种方式: gdb #启动gdb file test #用file命令来启动对...,如果显示不全再点个回车 list 行号 #显示以该行为中心的一段代码 控制调试进程 n #单步执行,不跳入函数,next的简写(vs中F10) s #真正的单步执行,跳入函数,step(vs中F11)...layout asm #显示汇编窗口 layout regs #显示源码\反汇编\寄存器窗口 layout split #显示源码和反汇编窗口 调试coredump core文件相关设置 #查看资源相关限制信息...#跳转到1号栈帧 f 1 #打开该帧函数的反汇编代码 disassemble 调试多线程 几个常用命令 #打印线程信息 info threads #查看所有线程的堆栈信息 thread apply...q #退出gdb bt #查看堆栈,backtrace简写 info locals #显示当前函数中的所有变量值 cgdb test #一个可视化调试工具.

61210
领券