-
Debug是DOS,Windows提供的实模式程序的调试工具,可以看CPU中寄存器的内容
-
Debug的基本功能
- 用R命令查看、改变CPU寄存器的内容
- 用D命令查看内存中的内容
- 用E命令改写内存中的内容
- 用U命令将内存中的机器指令翻译成为汇编指令
- 用T命令执行一条机器指令
- 用A命令以汇编指令的格式在内存中写入一条机器指令
用R命令查看和修改CPU寄存器的内容
输入r命令,会显示如上图的寄存器的内容
此时CS=1C8B,IP=0100 ,那么内存1C8B:0100处的指令为CPU当前要 读取、执行的指令
修改寄存器内容:输入 r [寄存器名称]
输入r ax后我们再输入1111,那么此时ax中的内容就被更改为1111了
用D命令查看内存中的内容
如果我们想要直到内存10000H(1000:0)处的内容,可以用“d 段地址:偏移地址” 的格式查看
输入命令查看后会显示128个内存单元的内容,并用16进制的格式进行输出
- 中间是具体的内容,例如1000:0的内容是72H 1000:1的内容是73H
- 左边起是每一行的起始地址
- 右边是每个内存单元对应的ASCII码字符
用E命令改写内存的内容
如果想将内存1000:0 ~ 1000:9单元的内存内容分别写成0 1 2 3 4 5 6 7 8 9
可以用e 起始地址 数据 数据 ···的方式进行
也可以一个一个输入,e 起始地址进入询问系统,如果更改就书写更改后的值,不更改按空格跳转到下一个询问
最后按enter退出
用u命令将机器码翻译成为汇编指令
输入格式:U 首地址
用T命令执行CS:IP指向的指令
我们首先用R命令查看一下寄存器的内容,CS=1c8B, IP=0102
使用t命令执行指令,执行之后发现IP由0102变成了0104 继续指向下一条指令
用A命令用汇编的形式向内存中写入指令
命令格式:a 首地址
用d命令查看寄存器的内容(存入寄存器的是机器码)
用u 命令将机器码翻译成为汇编指令,验证是否是刚才输入的命令
验证了发现是我们刚才输入的内容
实验
实验任务1:使用Debug,将下面的程序写入内存中,逐条执行,观察每条指令执行CPU中相关寄存器中的
内容的变化。
使用上面讲的a命令输入汇编指令,我们输入完毕发现IP=0017时候输入的应该是add ah,bl
可以用a 1000:0017精确的去更改掉指令(注意我们在输入的时候16进制的数后面是不需要加H的)
这时候我们的指令是输入在1000:0的位置的,我们执行的时候应该更改寄存器CS:IP指向这个位置
现在就是一直按t键执行汇编的指令(注意观察ip的变化)
我们可以发现ip的变化跟你执行的指令的位数是有关的。这也比较好理解,你的指令占了3个空间,
那么你下一次执行指令的位置不就应该再加上3个单位么。
实验2: 将下面的3条指令写入从2000:0开始的内存单元中,利用3条指令计算2的8次方
mov ax,1 add ax,ax jmp 2000:0003
分析:首先看到给到的指令
第一步将1放入ax寄存器(2000:0)
第二步将ax寄存器的内容乘以二(2000:3)
第三步,将CS:IP指令指向第二步的位置
此时应该比较明确了,我们每按t执行一次都会得到2的n次方
并且第三步跳到2000:3使得我们下一次执行还是让ax=ax+ax
jmp 2000:0003起到了循环的效果
所以我们按8次就得到2^8了
实验任务3: 查看内存中的内容
PC机主板上的ROM中有一个生产日期,在内存FFF00H~FFFFFH中的某几个单元中,找到生产日期并且改变它
d fff:0 //查看内存的内容 //接下来不断按d可以接着上面的内容继续查看 找到后用e命令进行修改 发现是ROM(read only memory),不可以进行修改
实验任务4: 向内存从B8100H开始的单元中填写数据,如:
-e b810:0000 01 01 02 02 03 03 04 04
**注意事项:**你在执行e命令之前先打几个回车键(要不然显示不出来)
之后执行e命令更改内存的数据,就会有图像显示出来了
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)