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

实验任务2

1.给出使用d命令查看生产时期的截图

2.给出使用e命令修改生产日期所在内存单元的截图,以及,修改后,再次使用d命令查看的截图

3.结论:能否修改,以及,原因分析

无法修改原因:

向地址C0000-FFFFF的内存单元中写入数据的操作是无效的,因为这等于改写只读存储器中的内容。

实验任务3

1.给出在debug中使用e命令修改内存单元的命令,及,效果截图

 2.给出在debug中使用f命令批量填充内存单元的命令,及,效果截图

 3.尝试修改内存单元,或,数据后的效果截图

 

实验任务4

 1 -a
 2 mov ax, 20
 3 mov ds, ax
 4 mov ss, ax
 5 mov sp, 30
 6 push [0] ; 执行后,寄存器(sp) = _002EH_
 7 push [2] ; 执行后,寄存器(sp) = _002CH_
 8 push [4] ; 执行后,寄存器(sp) = _002AH_
 9 push [6] ; 执行后,寄存器(sp) = _0028H_
10 pop [6] ; 执行后,寄存器(sp) = _002AH_
11 pop [4] ; 执行后,寄存器(sp) = _002CH_
12 pop [2] ; 执行后,寄存器(sp) = _002EH_
13 pop [0] ; 执行后,寄存器(sp) = _0030H_

问题1:题目要求是把00220H ~ 0022fH用作栈空间。指令 mov ss, ax 和 mov sp, 30 执行后, 栈顶的逻辑地址和物理地址分别是?

答:栈顶逻辑地址为0020:30,物理地址为00230H。

问题2:单步调试到汇编指令 push [6] 执行结束, pop [6] 执行之前,使用 d 20:20 2f 查看此 时栈空间数据,给出实验截图。

答:

问题3:汇编指令 pop [0] 执行结束后, pop [0] 指令执行结束后,使用d命令 d 20:0 7 查看此 时数据空间内的数据是否有变化。给出实验截图。

 答:无变化

问题4:如果把最后四条指令改成截图中的顺序, pop [6] 指令执行结束后,使用d命令 d 20:0 7 查看此时数据空间内的数据是否有变化。给出实验截图。

答:有变化

实验任务5

问题1:使用t命令单步执行 mov ss, ax 时,是单步执行完这一条指令就暂停了吗?后面的指令 mov sp, 30 是什么时候执行的?

答:没有暂停,后面的指令mov sp, 30也紧跟着执行。

问题2:根据汇编指令,前三条指令执行后,00220H ~ 0022fH被设置为栈空间。并且,初始时,已通 过f命令将初始栈空间全部填充为0。观察单步调试时,栈空间00220H ~ 0022fH内存单元值的变化,特 别是图示中黄色下划线表示出的数据值。根据实验观察,尝试思考和分析原因。

答:CS表示段地址,IP表示偏移地址,CPU从CS:IP指向的内存单元中取地址,当前CS为073F,IP为0100,则CUP从073F0+0100=074F0H处取地址,并读入第一条指令mov ax,20,由于该条指令占有3个内存单元,所以在读入后,IP=IP+3,CS不变,IP变为0103,并执行该条指令。依次类推,由于执行完第二条指令后会紧接着执行第三条指令,而第二条和第三条指令分别占有2个和3个(30为00和30所以占有2个内存单元)内存单元,所以IP=0103+2+3=0108,即第一条画黄线的部分。

  由于t指令引发了中断,在此过程中,CUP使用栈的内存单元存放了数据,即当前CS和IP的值,如第二条黄线内容所示。

实验任务6

1.给出程序源码

 1 assume cs:code
 2 code segment
 3 start:
 4 mov cx, 10
 5 mov dl, '0'
 6 s: mov ah, 2
 7 int 21h
 8 add dl, 1
 9 loop s
10 mov ah, 4ch
11 int 21h
12 code ends
13 end start

2.给出使用masm、link对程序汇编链接过程截图,以及,运行可执行程序task6.exe的运行结果截图

 3.给出在debug中查看task5.exe的程序段前缀PSP的截图。

两个字节确实是CD 20。

实验任务7

 1.给出补全后的完整源码。说明程序中两个空填写的依据

 1 assume cs:code
 2 code segment
 3 mov ax, cs
 4 mov ds, ax
 5 mov ax, 0020h
 6 mov es, ax
 7 mov bx, 0
 8 mov cx, 0017H
 9 s: mov al, [bx]
10 mov es:[bx], al
11 inc bx
12 loop s
13 mov ax, 4c00h
14 int 21h
15 code ends
16 end

答:第一个空为cs,表示将当前CPU即将执行的指令的内存单元地址放入ax寄存器中,而后通过ax寄存器将地址放入段寄存器ds中。

第二个空为0017H,由于程序的目标是,完成自身代码的自我复制:把 mov ax, 4c00h 之前的指令复制到内存0:200开始的 连续的内存单元。而cx表示总的循环次数,循环的内容是通过段前缀ex和偏移地址[bx]将每一次ds:bx中的内容复制到ex:bx中去,之后bx自加1,所以总的循环次数cx即为第3行到第12行代码中一共占有多少内存单元。即cx=2+2+3+2+3+3+2+3+1+2=23(0017H)。

2.在debug中调试,使用g命令将程序执行到 loop s 之后、 mov ax, 4c00h 之前,然后,使用u命令 对0:200h开始的内存单元反汇编,确认是否把task7.asm中line3-line12的代码复制到了目标内存空间。

 复制完成。

 

------------恢复内容结束------------

posted @ 2021-10-24 13:12  城风欧欧  阅读(86)  评论(3)    收藏  举报