在学习汇编语言中记录个人认为较重要的知识点
win10下debug安装和使用
debug安装:https://jingyan.baidu.com/article/9faa7231fd2775473c28cb26.html
debug使用命令:https://www.cnblogs.com/tiger2soft/p/5094917.html
8086给出物理地址的方法
物理地址=段地址*16+偏移地址
图中数据皆为十六进制表示
但CPU可以用不同的段地址和偏移地址形成同一个物理地址
例:
物理地址:21F60H
段地址+偏移地址组合可以有:(2000H:1F60H)(2100H:0F60H)(21F0H:0060H)
段寄存器CS和IP
CS和IP为8086中两个最关键的寄存器
物理地址可写成(CS:IP)对应(段地址:偏移地址)存储在CS和IP两个寄存器里
CS中内容为M,IP中内容为N,CPU将从内存M*16+N来读取一条指令并执行
段寄存器DS和[address]
DS是一个段寄存器,存放要访问数据的段地址。
比如我们要读取10000H单元的内容:
mov bx,1000H
mov ds,bx
mov al,[0]
要注意,1000H不能直接送入ds,要经过一个寄存器来做中转,先放入一个一般寄存器bx再将bx中的内容送入ds。
[address]表示一个内存单元,里面的address表示内存单元的偏移地址,在我们使用这个偏移地址来定位一个具体内存单元时,会自动取ds中数据为内存单元的段地址。
和上面所提到一样,对于三种指令add,sub指令中,也不能直接对ds直接运算
三种指令在debug中对ds操作尝试
段寄存器SS和SP
当我们将10000H -- 1000FH这段内存当作栈使用时,SS存储栈顶的段地址,SP存储偏移地址。
任意时刻,SS:SP指向栈顶元素,下图为对栈操作指令push和pop功能的执行过程描述
push指令执行过程
pop指令执行过程
注意:push,pop等栈操作指令,修改的只是SP。也就是说,栈顶的变化范围最大为:0--FFFFH