当前位置: 首页 > 编程日记 > 正文

GDB调试--以汇编语言为例

#rpm -qa |grep  gdb

下载:

安装

#tar -zxvf

#./configure

#make

使用GDB

以汇编语言调试为例

汇编语言实现CPUID指令

CPUID

cpuid是Intel  Pentinum以上级CPU内置的一个指令(486级以下的CPU不支持),他用于识别某一类型的CPU,

它能返回CPU级别,型号,CPU步进以及CPU字串信息,从此命令也可以得到CPU的缓存和TLB信息


CPUID返回数据类型是在EAX寄存器里定义的,而指令返回的数值则存储在EAX,EBX,ECX和EDX寄存器中。

返回的信息分两部分:基本信息与扩展信息。

在EAX输入0-3参数时,它返回CPU基本信息;

而在EAX输入0x8000000至ox800000x,他返回的是CPU扩展信息。扩展信息只包括在Pentinum4及以后的CPU上。


CPU级别         基本信息   扩展信息
486及以前的CPU      不可用    不可用
Pentium        0x1    不可用
Pentium Pro,Pentium 2    0x2    不可用
Pentium 3      0x3    不可用
Pentium 4      0x2    0x80000004
Xeon(至强)      0x2    0x80000004


代码

cpuid.s

#cpuid.s Sample program to extract the processor Vendor ID                
.section .data                
output:                   .ascii "The processor Vendor ID is 'xxxxxxxxxxxx'\n"
.section .text                
.globl _start                
_start:                   movl $0, %eax                   cpuid                   movl $output, %edi                   movl %ebx, 28(%edi)                   movl %edx, 32(%edi)                   movl %ecx, 36(%edi)                   movl $4, %eax                   movl $1, %ebx                   movl $output, %ecx                   movl $42, %edx                   int $0x80                   movl $1, %eax                   movl $0, %ebx                   int $0x80

汇编

使用GNU汇编器

#as -o cpuid.o cpuid.s

使用GNU链接器

#ld -o cpuid cpuid.o

运行程序

#./cpuid

输出


调试

为了调试汇编语言程序,必须使用-gstabs参数重新汇编代码

#as -gstabs -o cpuid.o cpuid.s

#ld -o cpuid cpuid.o

使用-gstabs参数在可执行文件中添加了附加信息,所以新产生的文件会大些

如果没有必要不要使用调试信息


运行

在gdb内运行

#gdb cupid

GNU调试器启动,把程序加载到内存,使用run命令(简化r也可以)从gdb内运行程序


可见调试器内的运行和从命令行直接运行一样


断点

汇编语言中指定断点时,必须指定对于最近的标签的相对位置,上述代码中只有一个标签,所以每个断点必须依据_start指定。

break(简化的b)命令格式 break * label+offset

break 函数名

break 行号

break 文件名:行号

break 文件名:函数名

break +偏移量

break -偏移量

break *地址

label是被引用的源代码中的标签

offset是应该停止的地方距离标签的行数

break * _start

*_start参数指定了断点,该参数指定_start标签后的第一条指令码。

run或者(简化的r)启动程序,暂停在第一条指令码处。

单步

使用next(简化的n)或者step(简化的s)命令单步调试

注意:s会步入调用的函数,类似于VS中的F11,而n类似于VS中的F10

每个next或者step命令执行下一行代码

继续运行

使用continue(或者c)按正常方式继续运行,类似于VS中的F5


查看数据

info  registers   查看所有寄存器的值

print (或者p)   显示特定寄存器或者来自程序的变量值

p $eax            显示寄存器的内容

p/格式  变量

格式

p/t    显示为2进制数

p/o   显示为8进制数

p/d   显示为10进制数

p/u   显示为无符号10进制数

p/x   显示为16进制数

p/a   地址

p/c   显示为字符

p/s   显示为字符串

p/f    浮点小数

p/i    显示为机器语言(仅在显示内存的x命令中可用)

程序指针可以写为$pc或者$eip,因为Intel IA-32架构中的程序指针名为eip

p $pc

p $eip

x         显示特定的内存位置内容

x/格式 地址

x命令显示特定内存位置的值。

x命令的格式 x/nyz

n是要显示的字段数;

y是输出格式同之前的p

z是要显示的字段长度:

b        字节

h        半字(2字节)

w       字(4字节)默认值

g        双字(8字节)

例如:

x $pc

x/i $pc

此处x/i意为显示汇编指令

也有反汇编命令disassemble(或者disas)

格式:

disas

disas       程序计数器

disas       开始地址  结束地址

由此可见,在cpuid指令执行之前,EBX,ECX,EDX寄存器都是0,之后他们包含从厂商ID字符串来的值。


使用x命令显示位于output变量前42个字节的内存位置的值(&符号表明是一个内存位置):

GDB的数据显示格式

x 按十六进制格式显示变量。
d 按十进制格式显示变量。
u 按十六进制格式显示无符号整型。
o 按八进制格式显示变量。
t 按二进制格式显示变量。
a 按十六进制格式显示变量。
c 按字符格式显示变量。
f 按浮点数格式显示变量。


查看寄存器和内存

1) info args
打印出当前函数的参数名及其值。
2)info locals
打印出当前函数中所有局部变量及其值。
3)info catch
打印出当前的函数中的异常处理信息。
4)源代码的内存
你可以使用info line命令来查看源代码在内存中的地址。info line后面可以跟“行号”,“函数名”,“文件名:行号”,“文件名:函
数名”,这个命令会打印出所指定的源码在运行时的内存地址,如:
(gdb) info line tst.c:func
Line 5 of "tst.c" starts at address 0x8048456 <func+6> and ends at 0x804845d <func+13>.
5)info break
查看断点信息。
6)info threads
看正在运行程序中的线程信息
7)info registers
查看寄存器的情况。(除了浮点寄存器)
8)info all-registers
查看所有寄存器的情况。(包括浮点寄存器)
9)info registers <regname >
查看所指定的寄存器的情况。

例如:info registers ebp

10)info frame或者i f
这个命令会打印出更为详细的当前栈层的信息,只不过,大多数都是运行时的内内
地址。比如:函数地址,调用函数的地址,被调用函数的地址,目前的函数是由什么
样的程序语言写成的、函数参数地址及值、局部变量的地址等等

11)(gdb) disassemble func

disassemble可以查看源程序的当前执行时的机器码,这个命令
会把目前内存中的指令dump出来

12)list

用list命令来打印程序的源代码

13)x

可以使用examine命令(简写是x)来查看内存地址中的值.

x/3uh 0x54320表示,从内存地址0x54320读取内容,h表示以双字节为一个单位,3表示三个单位,u表示按十六进制显示。

x/48xw  $ebp   也可以一样显示改寄存器或者用上述方法按寄存器的地址

参考:GDB查看栈信息

查看进程

info proc

查看栈帧

bt

backtrace

info stack

where

都是一样的只是别名而已

bt  显示所有栈帧

bt N  显示开头N个栈帧

bt -N 显示最后N个栈帧

bt full 显示栈帧+局部变量

bt full N  N同前

监视

eatch <表达式>

<表达式>发生变化时暂停运行,此处<表达式>是常量或变量等

awatch <表达式>

<表达式>被访问,改变时暂停运行

nwatch <表达式>

<表达式>被访问时暂停运行

delete<编号>

删除监视点

改变变量的值

set variable <变量><表达式>

例如:

(gdb) p  options

$7=1

(gdb)set variable options=0

(gdb)print options

$8=0

GDB命令

1)单步调试:

n (next),

ni(nexti) 执行下一行(以汇编代码为单位)

s(step 跟n的区别,s进入到函数内)

si(stepi) 执行下一行(以汇编代码为单位)

u(until)执行到指定行

2)恢复操作:c(continue或者cont) 直到遇到下个断点

3)临时断点: tbreak 有效期,第一次遇到

4)检查变量:p (printf)  显示表达式

x   显示内存内容

5)监视点:watch 当监视点的值发生变化时停止

6)查看栈:bt(backtrace,where) 显示整个栈的内容。

f(frame)选择要显示的栈帧

do(down) 在当前调用的栈帧中选择要显示的栈帧

7)看已经设的断点: ib(info break)

8)设置断点:break(b)

break function, break line_number, break filename:line_number, break filename:function

info break 查看断点信息。

9)删除断点: d(delete),delete+数值标识符(从第7点可得到) (不加参数,删除所有断点), clear使用跟第8点对应

10)禁用断点:disable+数值标识符 (重新启用 enable)

11)在单步时跳出函数:finish

12)在单步时跳出循环:until

13)条件断点:break break-arg if (condition),例: break main if argc > 1

14)断点命令列表(到断点自动执行):

commands breakpoint-number 例子:commands 1

... >printf "i = %d", i

commands >end

...

end

a) 在commands 中加入silent,过滤到其他无用的输出。

b) 最后一个commands是continue的话,自动continue。

例:comands 1

> silent

> printf "i = %d", i

> continue

> end

15)查看局部变量:info locals 得到当前栈中所有局部变量的值列表

16)设置变量:set x=12

17)GDB线程命令:

a) info threads(给出当前所有的线程信息)

b) thread 3(切换查看线程)

c) break 88 thread 3(当线程3到达源代码行88时停止执行)

d) break 88 thread 3 if x == y

e) thread apply all bt,查看所有的线程的栈信息。

18) 您可以以进程ID作为第二个参数,以调式一个正在运行的进程

gdb 程序名 1234

19)finish运行到函数结束

20)forward-search(或者fo)  向前搜索

21)generate-core-file(或者gcore)  生成内核转储

22edit 编辑文件或函数

23)directory(或者dir)插入目录

24)list(或者l)显示函数或者行

25)info (或者i)显示信息

26)help (或者h)显示帮助

注意

1)重新编译文件时不要退出gdb,断点可以保存着。

2)在调试时不要开启优化代码的选项,不然经过了优化,设置的断点的位置跟编译后的位置相差可能很大。


《深入理解计算机系统(原书第2版)》

更高级的GDB调试:

GDB attach到进程

相关文章:

汇编语言系统调用过程

以printf为例&#xff0c;详细解析一个简单的printf调用里头&#xff0c;系统究竟做了什么&#xff0c;各寄存器究竟如何变化。 如何在汇编调用glibc的函数&#xff1f;其实也很简单&#xff0c;根据c convention call的规则&#xff0c;参数反向压栈&#xff0c;call&#xf…

switch语句中在case块里声明变量会遇到提示“Expected expression before...的问题

switch语句中在case块里声明变量会遇到提示“Expected expression before..."的问题 例如在如下代码中 1case constant:2 int i 1;3 int j 2;4 self.sum i j;5 break;GCC在case语句之后的第一行中声明变量时遇到问题。 这时需要在case块两端添加花括号&am…

帮AI体检看病一条龙服务,阿里发布“AI安全诊断大师”

如同一些出生免疫力就有缺陷的人一样&#xff0c;AI也存在免疫力缺陷。基于从源头打造安全免疫力的新一代安全架构理念&#xff0c;最近&#xff0c;阿里安全研究发布了一项核心技术“AI安全诊断大师”&#xff0c;可对AI模型全面体检&#xff0c;“看诊开方”&#xff0c;让AI…

Spring学习总结(7)——applicationContext.xml 配置文详解

web.xml中classpath:和classpath*: 有什么区别? classpath&#xff1a;只会到你的class路径中查找找文件; classpath*&#xff1a;不仅包含class路径&#xff0c;还包括jar文件中(class路径)进行查找. 存放位置&#xff1a; 1&#xff1a;src下面 需要在web.xml中定义如下&…

GDB查看栈信息

栈&#xff1a;是程序存放数据内存区域之一&#xff0c;特点是LIFO&#xff08;后进先出&#xff09;。 PUSH&#xff1a;入栈 POP&#xff1a;出战 使用场景&#xff1a; 1.保存动态分配的自动变量使用栈 2.函数调用时&#xff0c;用栈传递函数参数&#xff0c;半寸返回地址…

数据库学习之路

今天迎来入冬的第二场雪&#xff0c;闲来无事就整理了下总结下工作以来所有数据库方面的书籍和资料&#xff0c;发现了不少&#xff0c;很多已经读过或者正在读的书籍&#xff0c;oracle真的很强大&#xff0c;直到现在发现才入门的水平&#xff0c;当然很多书读一遍是不行的&a…

为什么铺天盖地都是Python的广告?

最近&#xff0c;知乎关于Python有一个热议问题&#xff1a; 甚至在抖音上&#xff0c;笔者有一次还看到Python占领了热搜&#xff01;应该有很多不懂技术的吃瓜群众也被Python的热度炒懵了……但是&#xff0c;Python真的值得学吗&#xff1f;真的值得花这么多钱去学吗&#x…

python3正则表达式符号和用法

转载于:https://www.cnblogs.com/wumac/p/5441322.html

从寄存器看I386和x64位中函数调用中参数传递

x86_64基本使用寄存器存储函数参数&#xff0c;寄存器不够才入栈&#xff1b; 而i386将所有参数保存在栈上&#xff0c;通过gcc的扩展功能__attribute__((regparm()))即可实现部分参数的寄存器传递。 调试语法&#xff1a; --《深入理解计算机系统(原书第2版)》 代码 #incl…

转:去掉Flex4生成的SWF加载时的进度条

方法一&#xff1a; <?xml version"1.0" encoding"utf-8"?> <s:Application xmlns:fx"http://ns.adobe.com/mxml/2009" xmlns:s"library://ns.adobe.com/flex/spark" xmlns:mx"library://ns.adobe.com/f…

饿了么交易系统5年演化史

作者 | 挽晴来源 | 阿里巴巴中间件&#xff08;ID&#xff1a;Aliware_2018&#xff09;个人简介:2014年12月加入饿了么&#xff0c;当时参与后台系统的研发(WalisJavis>Walle)&#xff0c;主要面向客服和BD。2015年5月开始接触订单系统的研发&#xff0c;7月负责订单研发组…

Python迁移MySQL数据到MongoDB脚本

MongoDB是一个文档数据库&#xff0c;在存储小文件方面存在天然优势。随着业务求的变化&#xff0c;需要将线上MySQL数据库中的行记录&#xff0c;导入到MongoDB中文档记录。 一、场景&#xff1a;线上MySQL数据库某表迁移到MongoDB&#xff0c;字段无变化。 二、Python模块&am…

使用valgrind分析C程序调用线路图

Valgrind可以检测内存泄漏和内存违例&#xff0c;但是用Valgrind生成的日志信息结合kcachegrind就可以查看C程序的执行线路图&#xff0c;调用时间&#xff0c;是做性能优化和查看代码的非常好的工具。 1.下载安装 Valgrind 安装 到www.valgrind.org下载最新版valgrind # wg…

纯CSS实现蓝色圆角下拉菜单

代码简介&#xff1a; 这个菜单没有使用任何的图片&#xff0c;完全是用CSS实现的&#xff0c;包括圆角效果也同样是&#xff0c;而且还考虑了多浏览器的兼容性&#xff0c;可以说非常不错&#xff0c;既兼容性好&#xff0c;又外观漂亮&#xff0c;下拉导航菜单目前比较流行&a…

生产型机器学习已经没那么困难了?

作者 | Caleb Kaiser译者 | 香槟超新星出品 | CSDN&#xff08;ID:CSDNnews&#xff09;封面图源自视觉中国在软件工程的诸多领域内&#xff0c;生产用例是相当标准化的。以Web开发为例&#xff0c;要在Web应用中实现身份认证&#xff0c;你不会去创造一个数据库&#xff0c;自…

poj1330Nearest Common Ancestors 1470 Closest Common Ancestors(LCA算法)

LCA思想&#xff1a;http://www.cnblogs.com/hujunzheng/p/3945885.html 在求解最近公共祖先为问题上&#xff0c;用到的是Tarjan的思想&#xff0c;从根结点开始形成一棵深搜树&#xff0c;非常好的处理技巧就是在回溯到结点u的时候&#xff0c;u的子树已经遍历&#xff0c;这…

干货 | 时间序列预测类问题下的建模方案探索实践

作者 | 陆春晖责编 | Carol出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;背景时间序列类问题是数据分析领域中一类常见的问题&#xff0c;人们有时需要通过观察某种现象一段时间的状态&#xff0c;来判断其未来一段时间的状态。而时间序列就是该种现象某一个统计指…

Redis安装与源码调试

linux版本&#xff1a;64位CentOS 6.5 Redis版本&#xff1a;redis-3.0.6 (更新到2016年1月22日) Redis官网&#xff1a;http://redis.io/ Redis常用命令&#xff1a;http://redis.io/commands 1.安装Redis # wget http://download.redis.io/releases/redis-3.2.6.tar.g…

system pause in C#

方法一&#xff1a; Console.Write("Press any key to continue . . . "); Console.ReadKey(true); 注&#xff1a;也可用ReadLine()或Read()&#xff0c;但是只能对回车进行响应&#xff0c;不能达到anykey的效果。 方法二&#xff1a; 1) 在源文件using处加入using…

C#设置当前程序通过IE代理服务器上网

注意&#xff1a;以下设置只在当前程序中有效&#xff0c;对IE浏览器无效&#xff0c;且关闭程序后&#xff0c;自动释放代码。 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Runtime.InteropServices;public static …

计算机科学精彩帖子收集

linux源码 LXR 源自“the Linux Cross Referencer”&#xff0c;中间的“X”形象地代表了“Cross”。与 Source Navigator 类似&#xff0c;它也是分析阅读源代码的好工具。不同的是&#xff0c;它将源代码借助浏览器展示出来&#xff0c;文件间的跳转过程成了我熟悉的点击超链…

挑战王者荣耀“绝悟” AI,我输了!

作者 | 马超责编 | 伍杏玲出品 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09;腾讯 AI Lab 与王者荣耀联合研发的策略协作型AI&#xff0c;“绝悟”首次开放大规模开放&#xff1a;5月1日至4日&#xff0c;玩家从王者荣耀大厅入口&#xff0c;进入“挑战绝悟”测试&…

java 注解类说明

一、类中注解 SuppressWarnings ("serial"); 关键字 用途deprecation使用了不赞成使用的类或方法时的警告unchecked执行了未检查的转换时的警告&#xff0c;例如当使用集合时没有用泛型 (Generics) 来指定集合保存的类型。fallthrough当 Switch 程序块直接通往下一种…

《ArcGIS Runtime SDK for Android开发笔记》——(13)、图层扩展方式加载Google地图...

1、前言 http://mt2.google.cn/vt/lyrsm225000000&hlzh-CN&glcn&x420&y193&z9&sGalil 通过图层扩展类的方式加载Google地图的是我们通常获取Google地图的一种方式&#xff0c;根据这种方式我们可以通过拼接地图瓦片Url字符串获取瓦片数据&#xff0c;关…

调试JDK源码-一步一步看HashMap怎么Hash和扩容

调试JDK源码-一步一步看HashMap怎么Hash和扩容 调试JDK源码-ConcurrentHashMap实现原理 调试JDK源码-HashSet实现原理 调试JDK源码-调试JDK源码-Hashtable实现原理以及线程安全的原因 还是调试源码最好。 开发环境 JDK1.8NetBeans8.1 说明&#xff1a;调试HashMap的 publ…

开源一年,阿里轻量级AI推理引擎MNN 1.0.0正式发布

在经过充分的行业调研后&#xff0c;阿里淘系技术部认为当时的推理引擎如TFLite不足以满足手机淘宝这样一个亿级用户与日活的超级App。于是&#xff0c;他们从零开始自己搭建了属于阿里巴巴的推理引擎MNN。1年前&#xff0c;MNN在Github上开源&#xff0c;截止目前获得了3.9k S…

人生在成败中进步

参考文献《佛经》 人生在成败中进步佛经中有云&#xff1a;“菩萨者&#xff0c;福慧深利&#xff0c;道观双流。”“福慧双修”、“福慧双全”是众生成佛的必由之道&#xff0c;也是众生修行的理想追求。人生中&#xff0c;虽然不可能人人都能成佛&#xff0c;但是佛经有云&am…

【原】YUI压缩与CSS media queries下的bug

大概是上个月&#xff0c;使用YUI压缩一个css文件后&#xff0c;发现只要是被压缩后的css文件有部分根本无法工作&#xff0c;一直都不知啥问题引起的&#xff0c;让我感到头疼。 今天发现了只要是在媒体查询中的样式无法起作用&#xff0c;于是才开始怀疑是media被压缩后引起的…

Spring源码分析【4】-Spring扫描basePackages注解

org.springframework.beans.factory.support.DefaultListableBeanFactory 重要数据结构 /** Map of bean definition objects, keyed by bean name */private final Map<String, BeanDefinition> beanDefinitionMap new ConcurrentHashMap<String, BeanDefinition&…

c语言c++语言中静态变量,函数详解

静态变量&#xff0c;静态函数对于一些c&#xff0c;c的初学者来说&#xff0c;造成了不少的困扰。昨晚和寝室的室友讨论到这 个问题&#xff0c;想了一下&#xff0c;作了一下总结&#xff1a;虽然说c和c在很多人的眼里就是孪生姐妹&#xff0c;其实还是有很大区别的。在这里分…