四、实验结论
1. 实验任务1
由于已经熟练掌握了debug的使用以及程序的编译和连接,故略过。
2. 实验任务2
(1)在debug中,使用d命令查看生产日期,得知生产日期为1992/01/01。
(2)使用e命令修改生产时期所在的内存单元。
使用d命令再次查看被修改地址的内容,发现并未修改成功。
原因分析:由于ROM是只读存储器,故无法修改其内容。
8086内存地址的分配空间如下:
由于题目已经提及该内存单元所在为ROM,故不用分析其地址也可得出答案。
至于为什么生产时间为1992/01/01,可能是因为使用的是DosBox软件运行的虚拟环境,与实际生产时间并无关系。
3. 实验任务3
(1)从b800:0开始的内存单元开始,依次写入十六进制数据04 03,重复写5次。
(2)把内存单元区间b800:0f00 ~ b800:0f9f连续160个字节,依次重复填充十六进制数据03 04。
(3)尝试修改内存地址为a800:0, 发现此时屏幕上并没有输出。
原因分析: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。
(2)push [6] 指令执行结束后, pop [6] 指令执行结束前,使用d命令 d 20:20 2f 查看此时栈空间的数据。
(3)pop [0] 指令执行结束后,使用d命令 d 20:0 7 查看此时数据空间内的数据,发现数据发生了变化。
(4)将pop顺序逆置,重复上述步骤,发现数据发生了变化。
5. 实验任务5
问题一:使用t命令单步执行 mov ss, ax 时,执行完之后并未暂停,继续执行后面的指令 mov sp, 30。
问题二:0108和073F分别是IP和DS中的值,CS:IP存放的是指令的起始地址,DS存放的是数据的段地址, 可能是对定义栈段时部分运行环境变量进行暂存。
6. 实验任务6
源代码:
编译和连接:
程序运行结果:
查看task6.exe的程序段前缀,验证得前两个字节是CD 20。
7.实验任务7
(1)第一空应填 CS ,因为要将程序自身代码内容复制到0:200开始的内存单元处,而程序指令的起始地址由CS:IP给出,故填CS。
第二空应填17H,采用debug对代码进行调试(第二空暂时填0),计算出整个代码共001CH个字节,减去最后两行代码占用的字节数0005H,故填17H。
源代码:
(2)在debug调试中,使用g命令将程序执行到 loop s 之后、 mov ax, 4c00h 之前,然后,使用u命令 对0:200h开始的内存单元反汇编,验证得复制成功。
五、实验总结
(1)ROM为只读存储器,无法修改其中的内容。
8086内存地址的分配空间如下:
(2)A0000-BFFFF为显存地址空间,向这个地址写入数据可以打印到屏幕上。
(3)存储器
随机存储器(RAM):带电存储,关机丢失,可读可写
只读存储器(ROM):关机不丢,只能读取
主板上的ROM装有系统的BIOS(基本输入输出系统)。
其他接口卡上也可能有自己的ROM,一般装着相应的BIOS
(4)CPU的实模式和保护模式,见https://zhuanlan.zhihu.com/p/42309472。