xiaoyu111

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

实验结论:

2. 实验任务2

在debug中,使用d命令查看生产日期

 

使用e命令修改生产时期所在的内存单元,修改后,再次使用d命令查看

 

结论:不能修改,C0000~FFFFF是各类ROM地址空间,向其中的内存单元写入数据的操作是无效的,因为这等于改写只读存储器的内容。

 

实验任务3

在debug中,使用e命令,向内存单元填写数据。

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

 

在debug中,使用f命令,向内存单元批量填写数据。

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

 

 修改地址单元和数据

 

 4. 实验任务4

填空 注*:

以下这段汇编指令代码,是在debug环境中使用a命令输入的汇编指令。

-a

mov ax, 20

mov ds, ax

mov ss, ax

mov sp, 30

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___

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

逻辑地址:0020:0030      物理地址:00230

问题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. 实验任务5

问题1:使用t命令单步执行 mov ss, ax 后,ss和sp的值都发生了变化,所以没有暂停,而是同时执行了指令 mov sp, 30。

问题2:分别为CS和IP的值,用于指向下一条指令。

6. 实验任务6

程序源码:

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的运行结果截图

 

 

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

 

7. 实验任务7

下面程序的功能是,完成自身代码的自我复制:把 mov ax, 4c00h 之前的指令复制到内存0:200开始的 连续的内存单元。

补全程序,并在debug中调试验证,确认是否正确实现了复制要求。

assume cs:code

code segment

  mov ax, _____            

  mov ds, ax

  mov ax, 0020h

  mov es, ax

  mov bx, 0

  mov cx, _____

  s:mov al, [bx]

  mov es:[bx], al

  inc bx

  loop s

  mov ax, 4c00h

  int 21h

code ends

end

(1) 补全程序。说明这样填写的依据。

第一空为cs

程序加载到内存中时,cs:ip会初始化为程序的首个地址,而作为程序段的段首,ip为0,所以通过ax将cs的值赋值给ds

第二空为0017h

cx的值为程序返回时的偏移地址,要复制mov ax, 4c00h 之前的指令,得减去mov ax, 4c00h和int 21h 五个字节

先填零,debug后用r查看

 

 cx值为001c,减5后,应该为0017h

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

 

posted on 2021-10-27 11:15  xiaoyu111  阅读(96)  评论(3)    收藏  举报