王爽汇编语言第三版实验2

实验任务

(1)使用Debug,将下面的程序段写 入程序,逐条进行,根据指令执行后的实际运行情况填空。

assembly 复制代码
mov ax,ffff
mov ds,ax
mov ax,2200
mov ss,ax
mov sp,0100
mov ax,[0]     ;ax=C0EAH
add ax,[2]     ;ax=COFCH
mov bx,[4]    ;bx=30F0H
add bx,[6]     ;bx=6021H
push ax       ;sp=00FEH ; 修改的内存单元的地址是2200:00FE内容为COFCH
push bx       ;sp=00FCH ; 修改的内存单元的地址是2200:00FC内容为6021
pop ax       ;sp=00FEH ; ax=6021H
pop bx       ;sp=0100H; bx=COFCH
push [4]      ;sp=00FEH; 修改的内存单元的地址是2200:00FE内容为30F0
push [6]      ;sp=00FCH; 修改的内存单元的地址是2200:00FC内容为2F31

解答:

  1. 首先用d命令得到内存FFFF0~FFFFF中的值
  1. 通过显示的值,进行手算一遍,填入上方的表格

  2. 写程序验证,方便起见,我从内存段1000:0开始编写

  3. 执行程序

这里可以注意到在执行完mov ss,ax后立刻执行了mov sp,0100,因此程序直接跳到mov ax,[0000]


分析后面写

(2)仔细观察图3.19中的实验过程,然后分析:为什么2000:0~2000:f中的内容会发生改变?

解答:

首先使用debug写入相应的命令,对程序的运行结果进行验证

事先在2000:0处写入0

修改cs和ip寄存器的值

执行命令,并查看2000:0的值

这些数值很容易能看出是寄存器的内容

  • 现象:在程序未执行之前,内存地址2000:00仅显示0值,但是在构建栈结构后,此内存地址显示出新数据

  • 分析:在网上搜集资料后,得知当使用t命令触发单步中断时,发生了寄存器值入栈操作,CPU自动将中断处理所需的注册值压入栈中,这解释了这些数据的来源。

  • 具体内容:参照课本P249,P238

相关推荐
myloveasuka11 分钟前
寻址方式笔记
汇编·笔记·计算机组成原理
请输入蚊子2 小时前
《操作系统真象还原》 第六章 完善内核
linux·汇编·操作系统·bochs·操作系统真像还原
myloveasuka3 小时前
指令格式举例
汇编·笔记·计算机组成原理
我在人间贩卖青春19 小时前
汇编之分支跳转指令
汇编·arm·分支跳转
我在人间贩卖青春1 天前
汇编之加载存储指令
汇编·arm·寄存器加载存储
我在人间贩卖青春1 天前
汇编之状态寄存器访问指令
汇编·arm·状态寄存器
我在人间贩卖青春1 天前
汇编之软中断指令和协处理指令
汇编·arm·软中断·协处理
我在人间贩卖青春1 天前
汇编之数据处理指令
汇编·arm·数据处理指令
白太岁2 天前
操作系统开发:(11) RTOS 与 GPOS 的分界线:MMU
c语言·开发语言·汇编·arm开发·系统架构
枷锁—sha3 天前
【pwn系列】Pwndbg 汇编调试实操教程
网络·汇编·笔记·安全·网络安全