掌握DEBUG 基本命令及其功能.docx
- 文档编号:28447877
- 上传时间:2023-07-13
- 格式:DOCX
- 页数:15
- 大小:279.08KB
掌握DEBUG 基本命令及其功能.docx
《掌握DEBUG 基本命令及其功能.docx》由会员分享,可在线阅读,更多相关《掌握DEBUG 基本命令及其功能.docx(15页珍藏版)》请在冰豆网上搜索。
掌握DEBUG基本命令及其功能
实验一掌握DEBUG基本命令及其功能
【上篇】查看CPU和内存,用机器指令和汇编指令编程
一.实验目的:
掌握DEBUG的基本命令及其功能
掌握win7win8使用DEBUG功能
二.实验内容:
1.预备知识:
Debug的使用
(1)什么是Debug?
Debug是DOS、Windows都提供的实模式(8086方式)程序的调试工具。
使用它,可以查看CPU各种寄存器中的内容、内存的情况和在机器码级跟踪程序的运行。
(2)我们用到的Debug功能
●用Debug的R命令查看、改变CPU寄存器的内容;
●用Debug的D命令查看内存中的内容;
●用Debug的E命令改写内存中的内容;
●用Debug的U命令将内存中的机器指令翻译成汇编指令;
●用Debug的T命令执行一条机器指令;
●用Debug的A命令以汇编指令的格式在内存中写入一条机器指令。
(3)进入Debug
Debug是在DOS方式下使用的程序。
我们在进入Debug前,应先进入到DOS方式。
用以下方式可以进入DOS:
①重新启动计算机,进入DOS方式,此时进入的是实模式的DOS。
②在Windows中进入DOS方式,此时进入的是虚拟8086模式的DOS。
(4)用R命令查看、改变CPU寄存器的内容
1)显示CPU内部所有寄存器内容和标志位状态;格式为:
-R
2)显示和修改某个指定寄存器内容,格式为:
-R寄存器名
若要修改一个寄存器中的值,比如AX中的值,可用R命令后加寄存器名来进行,输入“rax”后按Enter键,将出现“:
”作为输入提示,在后面输入要写入的数据后按Enter键,即完成了对AX中内容的修改。
若想看一下修改的结果,可再用R命令查看
(5)用Debug的D命令查看内存中的内容
1)格式:
-d段地址:
偏移地址,Debug将列出从指定内存单元开始的128个内存单元的内容。
使用D命令,Debug将输出3部分内容,如图2.34所示。
中间是部分从指定地址开始的128个内存单元的内容,用十六进制的格式输出,每行的输出从16的整数倍的地址开始,最多输出16个单元的内容。
左边是每行的起始地址。
右边是每个内存单元中的数据对应的可显示的ASCII码字符。
2)格式:
-d段地址:
起始偏移地址结尾偏移地址,Debug将列出指定范围的内存单元的内容。
(6)用Debug的E命令改写内存中的内容,有两种格式:
1)格式:
-e起始地址数据数据数据……,如要将1000:
0开始的10个内存单元修改为0~9,可以用”-e1000:
00123456789”
2)格式:
-e起始地址,逐个单元相继地修改。
如:
-e1000:
10
1000:
00106D.061.172.26B.1c
输入e1000:
10,Debug显示起始地址1000:
0010,和1000:
0010单元的原始内容:
6D,然后光标停在“.”的后面提示输入想要写入数据,输入数据0,然后按空格键,即用输入的数据0改写了当前的内存单元。
当前单元处理完成后,Debug将接着显示下一个内存单元的原始内容,并提示读者进行修改,可以用同样的方法处理。
改写完毕后,按Enter键,E命令操作结束。
可以用E命令向内存中写入字符,比如:
用E命令从内存1000:
0开始写入:
数值1、字符“a”,数值2,字符“b”,数值3,字符“c”,可以用:
“-e1000:
01‘a’2‘b’3‘c’”
修改的结果是,向1000:
0、1000:
2、1000:
4单元中写入数值1、2、3,向1000:
1、1000:
3、1000:
5单元中写入字符“a”、“b”、“c”的ASCII码值:
61H、62H、63H。
也可以用E命令向内存中写入字符串,比如:
用E命令从内存1000:
0开始写入:
数值1、字符串“a+b”、数值2、字符串“c++”、字符3、字符串“IBM”。
可以用:
‘-e1000:
01“a+b”2“c++”3“IBM”’。
可以用E命令向内存中写入机器码
比如要从内存1000:
0单元开始写入这样一段机器码:
机器码对应的汇编指令
b80100movax,0001
b90200movcx,0002
01c8addax,cx
可用:
”-e1000:
0b80100b9020001c8”
(7)用U命令查看写入的或内存中原有的机器码所对应的汇编指令
1)-U段地址:
偏移地址
该命令从指定地址开始,反汇编32个字节,若地址省略,则从上一个U命令的最后一条指令的下一个单元开始显示32个字节。
2)-U地址范围
该命令对指定范围的内存单元进行反汇编
(8)使用T命令,可以执行CS:
IP指向的指令,格式:
-t,指令执行后,Debug显示输出CPU中寄存器的状态。
(9)用Debug的A命令以汇编指令的形式在内存中写入机器指令。
格式:
-A段地址:
偏移地址
该命令从指定地址开始允许输入汇编语句,把它们汇编成机器代码相继存放在从指定地址开始的存储器中。
三.实验任务
(1)使用Debug,将下面的程序段写入内存,逐条执行,观察每条指令执行后,CPU中相关寄存器中内容的变化。
(逐条执行,每条指令执行结果截图)
机器码汇编指令
b8204emovax,4E20H
051614addax,1416H
bb0020movbx,2000H
01d8addax,bx
89c3movbx,ax
01d8addax,bx
b81a00movax,001AH
bb2600movbx,0026H
00d8addal,bl
00dcaddah,bl
00c7addbh,al
b400movah,0
00d8addal,bl
049caddal,9CH
提示:
可用E命令和A命令以两种方式将指令写入内存。
注意用T命令执行时,CS:
IP的指向。
(2)将下面3条指令写入从2000:
0开始的内存单元中,利用这3条指令计算2的8次方。
movax,1
addax,ax
jmp2000:
0003
(3)查看内存中的内容
PC机主板上的ROM中写有一个生产日期,在内存FFF00H~FFFFFH的某几个单元中,请找到这个生产日期并试图改变它。
(内存ffff:
0005~ffff:
000C(共8个字节单元中)处)
【下篇】用机器指令和汇编指令编程
一.实验内容
1.预备知识:
Debug命令的补充
(1)在D命令中使用段寄存器
格式:
“d段寄存器:
偏移地址”,以段寄存器中的数据为段地址SA,列出从SA:
偏移地址开始的内存区间中的数据。
以下是4个例子:
①-rds
:
1000
-dds:
0;查看从1000:
0开始的内存区间中的内容
②-rds
:
1000
-dds:
1018;查看1000:
10~1000:
18中的内容
③-dcs:
0;查看当前代码段中的指令代码
④-dss:
0;查看当前栈段中的内容
(2)在E、A、U命令中使用段寄存器
在E、A、U这些可以带有内存单元地址的命令中,也可以同D命令一样,用段寄存器表示内存单元的段地址。
以下是3个例子:
①-rds
:
1000
-eds:
0112233445566;在从1000:
0开始的内存区间中写入数据
②-ucs:
0;以汇编指令的形式,显示当前代码段中的代码,0代码的偏移地址
③-rds
:
1000
-ads:
0;以汇编指令的形式,向从1000:
0开始的内存单元中写入指令
(3)下一条指令执行了吗?
在Debug中,用A命令写一段程序:
movax,2000
movss,ax
movsp,10;安排2000:
0000~2000:
000F为栈空间,初始化栈顶。
movax,3123
pushax
movax,3366
pushax;在栈中压入两个数据。
在用T命令单步执行movax,2000后,显示出当前CPU各个寄存器的状态和下一步要执行的指令:
movss,ax;在用T命令单步执行movss,ax后,下一条指令应该是movsp,10,却变成了movax,3123?
注意,在用T命令单步执行movss,ax前,ax=0000,ss=0b39,sp=ffee,而执行后ss=2000,sp=0010。
ss变为2000是正常的,这正是movss,ax的执行结果。
而能够将sp设为0010的只有指令movsp,10,看来,movsp,10一定是得到了执行。
在用T命令执行movss,ax的时候,它的下一条指令movsp,10也紧接着执行了。
整理一下我们分析的结果:
在用T命令执行movss,ax的时候,它的下一条指令movsp,10也紧接着执行了。
一般情况下,用T命令执行一条指令后,会停止继续执行,显示出当前CPU各个寄存器的状态和下一步要执行的指令,但T命令执行movss,ax的时候,没有做到这一点。
不单是movss,ax,对于如:
movss,bx,movss,[0],popss等指令都会发生上面的情况,这些指令有哪些共性呢?
它们都是修改栈段寄存器SS的指令。
结论:
Debug的T命令在执行修改寄存器SS的指令时,下一条指令也紧接着被执行。
二.实验任务
(1)使用Debug,将上面的程序段写入内存,逐条执行,根据指令执行后的实际运行情况填空。
(逐条执行,每条指令执行结果截图)
movax,ffff
movds,ax
movax,2200
movss,ax
movsp,0100
movax,[0];ax=C0EA
addax,[2];ax=C0FC
movbx,[4];bx=30F0
addbx,[6];bx=6021
pushax;sp=00FE;修改的内存单元的地址是2200:
FE内容为C0FC
pushbx;sp=00FC;修改的内存单元的地址是2200:
FC内容为6021
popax;sp=00FE;ax=6021
popbx;sp=0100;bx=C0FC
push[4];sp=00FE;修改的内存单元的地址是2200:
FE内容为30F0
push[6];sp=00FC;修改的内存单元的地址是2200:
FC内容为3F31
(2)使用Debug,将下面的程序段写入内存,逐条执行,观察每条指令执行后,CPU中相关寄存器中内容的变化。
(逐条执行,每条指令执行结果截图)如果有问题请说明原因
汇编指令
movax,1000H
movds,ax
movds,[0]
addds,ax
最后一条指令无法执行,因为段寄存器ds不可在算术指令中
(3)仔细观察下图中的实验过程,然后分析:
为什么2000:
0~2000:
f中的内容会发生改变?
用Debug进行实验的示例
这是由于debug的单步中断所致。
单步执行后会显示个寄存器的值以及下一条将要执行的指令,方便程序员的调试工作。
【实验报告】
首先截屏显示你在Window下调试DEBUG的步骤。
(WinXP可以直接使用,其他注明如何软件实现)
在DEBUG状态下编写、运行程序的过程以及调试所中,对实验任务中的内容逐一调试,并对此过程中的问题进行分析,对执行结果进行分析。
中间过程截图显示。
例如:
(实验报告一律截图,抄袭一律严惩!
)
补充内容
MASM5.0解决方案
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 掌握DEBUG 基本命令及其功能 掌握 DEBUG 基本 命令 及其 功能