实验结论
1. 实验任务1
自行练习,掌握工具用法。此部分无需写实验结论。 如练习中遇到、发现问题,使用搜索引擎,以及,和同学讨论后,都暂时未能得到解决或释疑,可以写 入这一部分。共大家一起讨论。
2. 实验任务2
给出使用d命令查看生产时期的截图 给出使用e命令修改生产日期所在内存单元的截图,以及,修改后,再次使用d命令查看的截图 结论:能否修改,以及,原因分析
不能修改生产日期,因为内存FFF00H ~ FFFFFH为ROM区,内容可读,但不可写
3. 实验任务3
给出在debug中使用e命令修改内存单元的命令,及,效果截图
给出在debug中使用f命令批量填充内存单元的命令,及,效果截图
尝试修改内存单元,或,数据后的效果截图
4. 实验任务4
根据在debug环境中调试观察结果,填空并回答问题。
问题1:题目要求是把00220H ~ 0022fH用作栈空间。指令mov ss, ax 和mov sp, 30 执行后,栈顶的逻辑地址和物理地址分别是?
栈顶的物理地址是:0022fH,逻辑地址:0;
问题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查看此时数据空间内的数据是否有变化。给出实验截图。
结果发生了变化
问题1:使用t命令单步执行mov ss, ax 时,是单步执行完这一条指令就暂停了吗?后面的指令movsp, 30 是什么时候执行的?
没有暂停,mov sp:30紧接在mov ss,ax后进行,但在用t命令单步执行时并没有显示
问题2:根据汇编指令,前三条指令执行后,00220H ~ 0022fH被设置为栈空间。并且,初始时,已通过f命令将初始栈空间全部填充为0。观察单步调试时,栈空间00220H ~ 0022fH内存单元值的变化,特别是图示中黄色下划线表示出的数据值。根据实验观察,尝试思考和分析原因。
画黄线的数据是cs:sp的数值,因为在debug使用t等指令引发了中断造成的,中断过程使用当前栈空间存放cpu关键数据。
给出程序源码
assume cs:code code segment start: mov cx, 10 mov dl, '0' s: mov ah, 2 int 21h add dl, 1 loop s mov ah, 4ch int 21h code ends end start
给出使用masm、link对程序汇编链接过程截图,以及,运行可执行程序task5.exe的运行结果截图
masm
link
可执行程序
给出在debug中查看task5.exe的程序段前缀PSP的截图。
7、实验任务7
给出补全后的完整源码。说明程序中两个空填写的依据。
assume cs:code code segment mov ax, cs mov ds, ax mov ax, 0020h mov es, ax mov bx, 0 mov cx, 17h s: mov al,[bx] mov es:[bx], al inc bx loop s mov ax, 4c00h int 21h code ends end
补充依据:寄存器ds,es分别存了两个段地址,而共用了bx这个寄存器。cx是控制循环的次数的。推测填写mov ax, 4c00h的地址,通过debug中u命令查看其确定地址再进行修改。
在debug中调试,使用g命令将程序执行到 loop s 之后、 mov ax, 4c00h 之前,然后,使用u命 令对0:200开始的内存单元反汇编,确认是否把task7.asm中line3-line12的代码复制到了目标内存 空间。 给出使用g命令运行到指定点和使用u命令反汇编0:200到复制代码长度这一段内存空间的截图。