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

任务2

PC机主板上的ROM中有一个生产时期,在内存FFF00H ~ FFFFFH的某几个单元中,请找到这个生产时 期,并试图修改它。

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

 

结论:不能修改,

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

 

 

任务3

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

-e b800:0 03 04 03 04 03 04 03 04 03 04

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

 

 

 

 

 

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

-f b800:0f00 0f9f 03 04

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

 

 

 

任务4

 

 

 

 

 

 (1)

 

 

 

 

 

 

 

 

 

 

 

执行完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 执行后, 栈顶的逻辑地址和物理地址分别是?

 

SS:SP 20:30  0230H

 

 

问题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:

  执行完 mov ss,ax 后紧跟着执行了mov sp,30

  一般情况下,用T命令执行一条指令后,会停止继续执行,显示出当前CPU各个寄存器的状态和下一步要执行的指令,

  但debug的t命令在执行修改寄存器SS的指令时,下一条指令也紧接着被执行。

 问题2:

 在debug中使用t命令单步调试是利用cpu的中断实现的,发生中断时会将栈中的内容改变

 

 

 

 

任务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

 

结果截图:

 

 

在debug中查看task5.exe的程序段前缀PSP

 

 

 

 

 

任务7

 

 

 

 

 

 

 

 

assume cs:code
code segment
mov ax,cs
mov ds,ax
mov ax,0020h
mov es,ax
mov bx,0
mov cx,23
s: mov al,[bx]
mov es:[bx],al
inc bx
loop s

mov ax,4c00h
int 21h
code ends
end

 

(1)第一空填写 cs,因为这是程序开始的地址

 

第二空填写 21

查看代码发现最后line3-line12所占空间为 0000H~0017H  17H=23

 

 

 

 

 

(2)

 

 

实验总结

1、熟悉掌握了编译、链接的使用

2、熟悉掌握应用了debug中的多种命令

3、了解了栈的特性。

 

posted @ 2021-10-22 19:05  Wknfy  阅读(83)  评论(2)    收藏  举报