一.实验目的:
掌握DEBUG 的基本命令及其功能
二.实验内容:
- 预备知识: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命令后加寄存器名来进行,输入“r ax”后按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,可以用”-e 1000:0 0 1 2 3 4 5 6 7 8 9”
2)格式:-e起始地址,逐个单元相继地修改。
如:-e 1000:10
1000:0010 6D.0 61.1 72.2 6B.1c
输入e 1000:10 ,Debug 显示起始地址1000:0010,和1000:0010单元的原始内容:6D,然后光标停在“.”的后面提示输入想要写入数据,输入数据0,然后按空格键,即用输入的数据0改写了当前的内存单元。当前单元处理完成后,Debug将接着显示下一个内存单元的原始内容,并提示读者进行修改,可以用同样的方法处理。改写完毕后,按Enter键,E命令操作结束。
可以用E命令向内存中写入字符,比如:用E命令从内存1000:0开始写入:数值1、字符“a”,数值2,字符“b”,数值3,字符“c”,可以用:“-e 1000:0 1 ‘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”。 可以用:‘-e 1000:0 1 “a+b” 2 “c++” 3 “IBM” ’。
可以用E命令向内存中写入机器码
比如要从内存1000:0单元开始写入这样一段机器码:
机器码 对应的汇编指令
b80100 mov ax,0001
b90200 mov cx,0002
01c8 add ax, cx
可用:”-e 1000:0 b8 01 00 b9 02 00 01 c8”
(7) 用U命令查看写入的或内存中原有的机器码所对应的汇编指令
1)-U 段地址:偏移地址
该命令从指定地址开始,反汇编32个字节,若地址省略,则从上一个U命令的最后一条指令的下一个单元开始显示32个字节。
2)-U地址范围
该命令对指定范围的内存单元进行反汇编
(8)使用T命令,可以执行CS:IP指向的指令,格式:-t,指令执行后,Debug显示输出CPU中寄存器的状态。
(9) 用Debug的A命令以汇编指令的形式在内存中写入机器指令。
格式:-A 段地址:偏移地址
该命令从指定地址开始允许输入汇编语句,把它们汇编成机器代码相继存放在从指定地址开始的存储器中。
三.实验任务
(1) 使用Debug,将下面的程序段写入内存,逐条执行,观察每条指令执行后,CPU中相关寄存器中内容的变化。
机器码 汇编指令
b8 20 4e mov ax,4E20H
05 16 14 add ax,1416H
bb 00 20 mov bx,2000H
01 d8 add ax,bx
89 c3 mov bx,ax
01 d8 add ax,bx
b8 1a 00 mov ax,001AH
bb 26 00 mov bx,0026H
00 d8 add al,bl
00 dc add ah,bl
00 c7 add bh,al
b4 00 mov ah,0
00 d8 add al,bl
04 9c add al,9CH
提示: 可用E命令和A命令以两种方式将指令写入内存。注意用T命令执行时,CS:IP的指向。这里比较简单,图片不再一一列举。
(2) 将下面3条指令写入从2000:0开始的内存单元中,利用这3条指令计算2的8次方。
mov ax,1
add ax,ax
jmp 2000:0003
读者跟着往下做即可。
最后的AX=(0100)16=(28)10=(256)10
小结:可以观察到jmp命令其实有一个段内间接寻址的作用。
(3) 查看内存中的内容
PC机主板上的ROM中写有一个生产日期,在内存FFF00H~FFFFFH的某几个单元中,请找到这个生产日期并试图改变它。
你会发现并不可以改变。可以自己动手试一下
(4) 向内存从B8100H开始的单元中填写数据,如:
-e B810:0000 01 01 02 02 03 03 04 04
按道理来说我们应该是可以写进去的,但是你会发现当你-d的时候并没有写进去,这就是这道题的魅力所在。你可以借助下图所示的方法来查看你 写入的内容。
请读者:先填写不同的数据,观察产生的现象;再改变填写的地址,观察产生的现象。
小结:第四个实验让我受益匪浅,出错了很多次,因为不论我怎么改b810:0中的内容,只要我-d b810:0就不会显示出我刚才改的东西,我一直以为是我对于段地址+偏移地址=物理地址的理解出现了问题,百度之后才发现,其实并不是我错了,而是这道题它实在是有趣的很,b8000h-bffffh共32kb空间,为80*25彩色字符模式的显示缓冲区。向这个地址空间写入数据,写入的内容会立即出现在显示器上。b810:0是一个显示存储区,它的内容是不断变化的,当你改变的时候,屏幕上就会出现彩色字符,当你运行其他命令式它又会不见。
四.实验报告
写出在DEBUG状态下编写、运行程序的过程以及调试所中遇到的问题是如何解决的,并对调试过程中的问题进行分析,对执行结果进行分析。