实验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的代码复制到了目标内存空间。

复制完成。
------------恢复内容结束------------
浙公网安备 33010602011771号