实验一 8086汇编指令编码和调试

四、实验结论

 


 

1. 实验任务1

由于已经熟练掌握了debug的使用以及程序的编译和连接,故略过。

 

2. 实验任务2

(1)在debug中,使用d命令查看生产日期,得知生产日期为1992/01/01。

 

 

 

 实验一 8086汇编指令编码和调试

 

 

 

 

 (2)使用e命令修改生产时期所在的内存单元。

实验一 8086汇编指令编码和调试

 

使用d命令再次查看被修改地址的内容,发现并未修改成功。

 

原因分析:由于ROM是只读存储器,故无法修改其内容。

8086内存地址的分配空间如下:

实验一 8086汇编指令编码和调试

 

 

 

由于题目已经提及该内存单元所在为ROM,故不用分析其地址也可得出答案。

至于为什么生产时间为1992/01/01,可能是因为使用的是DosBox软件运行的虚拟环境,与实际生产时间并无关系。

 

3. 实验任务3

(1)从b800:0开始的内存单元开始,依次写入十六进制数据04 03,重复写5次。

 

 

 

 实验一 8086汇编指令编码和调试

 

 

 (2)把内存单元区间b800:0f00 ~ b800:0f9f连续160个字节,依次重复填充十六进制数据03 04。

实验一 8086汇编指令编码和调试

 

 实验一 8086汇编指令编码和调试

 

(3)尝试修改内存地址为a800:0, 发现此时屏幕上并没有输出。

实验一 8086汇编指令编码和调试

 

原因分析:A000H-BFFFH为显存地址空间,向这个地址写入数据可以打印到屏幕上。

 

4. 实验任务4

 (1)单步执行,在执行push指令和pop指令时,栈顶偏移地址的寄存器sp值的变化情况如下,发现每执行一条push指令sp值-2,每执行一条pop指令sp值+2。

  push [0] ; 执行后,寄存器(sp) =002E

  push [2] ; 执行后,寄存器(sp) =002C

  push [4] ; 执行后,寄存器(sp) =002A

  push [6] ; 执行后,寄存器(sp) =0028

  pop [6];执行后,寄存器(sp)=002A

  pop [4] ; 执行后,寄存器(sp) =002C

  pop [2] ; 执行后,寄存器(sp) = 002E

  pop [0] ; 执行后,寄存器(sp) = 0030

指令 mov ss, ax 和 mov sp, 30 执行后, 栈顶的逻辑地址和物理地址分别是0020H:0030H和0230H。

实验一 8086汇编指令编码和调试

 

实验一 8086汇编指令编码和调试

 

(2)push [6] 指令执行结束后, pop [6] 指令执行结束前,使用d命令 d 20:20 2f 查看此时栈空间的数据。

实验一 8086汇编指令编码和调试

 

(3)pop [0] 指令执行结束后,使用d命令 d 20:0 7 查看此时数据空间内的数据,发现数据发生了变化。

实验一 8086汇编指令编码和调试

 

(4)将pop顺序逆置,重复上述步骤,发现数据发生了变化。

 实验一 8086汇编指令编码和调试

 

 

 实验一 8086汇编指令编码和调试

 

 5. 实验任务5

 

 实验一 8086汇编指令编码和调试

 

 

问题一:使用t命令单步执行 mov ss, ax 时,执行完之后并未暂停,继续执行后面的指令 mov sp, 30。

问题二:0108和073F分别是IP和DS中的值,CS:IP存放的是指令的起始地址,DS存放的是数据的段地址, 可能是对定义栈段时部分运行环境变量进行暂存。

 

6. 实验任务6

 

源代码:

实验一 8086汇编指令编码和调试

 

 

编译和连接:

 实验一 8086汇编指令编码和调试

 

 

 

程序运行结果:

 实验一 8086汇编指令编码和调试

 

查看task6.exe的程序段前缀,验证得前两个字节是CD 20。

实验一 8086汇编指令编码和调试

 

 

 

7.实验任务7

(1)第一空应填 CS ,因为要将程序自身代码内容复制到0:200开始的内存单元处,而程序指令的起始地址由CS:IP给出,故填CS。

         第二空应填17H,采用debug对代码进行调试(第二空暂时填0),计算出整个代码共001CH个字节,减去最后两行代码占用的字节数0005H,故填17H。

实验一 8086汇编指令编码和调试

 

实验一 8086汇编指令编码和调试

 

 

源代码:

 实验一 8086汇编指令编码和调试

 

 (2)在debug调试中,使用g命令将程序执行到 loop s 之后、 mov ax, 4c00h 之前,然后,使用u命令 对0:200h开始的内存单元反汇编,验证得复制成功。

实验一 8086汇编指令编码和调试

 

 

实验总结

 


(1)ROM为只读存储器,无法修改其中的内容。

    8086内存地址的分配空间如下:

 实验一 8086汇编指令编码和调试

 (2)A0000-BFFFF为显存地址空间,向这个地址写入数据可以打印到屏幕上。

 (3)存储器

 

  随机存储器(RAM):带电存储,关机丢失,可读可写

 

  • 用于存放CPU使用的绝大部分程序和数据,主随机存储器由装在主板上的RAM和扩展插槽的RAM组成。
  • 其他接口卡上也可能有自己的RAM

 

  只读存储器(ROM):关机不丢,只能读取

 

  • 主板上的ROM装有系统的BIOS(基本输入输出系统)。

  • 其他接口卡上也可能有自己的ROM,一般装着相应的BIOS

 (4)CPU的实模式和保护模式,见https://zhuanlan.zhihu.com/p/42309472

 

 

 

上一篇:剑指Offer 30.包含min函数的栈


下一篇:实验1 8086汇编指令编码与调试