寄存器CS和IP

Posted 天赋不够努力来凑

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了寄存器CS和IP相关的知识,希望对你有一定的参考价值。

讲述这两个寄存器前我们先来引入8086CPU是如何给出物理地址来访问内存的。

一、物理地址的形成

8086CPU有20位地址总线,可以传送20位地址,寻址能力为1MB,但是它是16位结构,只能送出16位地址,寻址能力为64kb。故8086CPU的物理地址用两个16位地址来合成一个20位的物理地址:物理地址=段地址*16(十六进制形式左移一位)+偏移地址
注:一个X进制左移一位相当于乘以X。
在这里插入图片描述

二、寄存器CS和IP

CS为代码段寄存器,储存内存单元的段地址,IP为指令指针寄存器,储存内存单元的偏移地址,这两寄存器通常与指令相关。任意时刻,CPU将CS:IP指向的内容当指令来执行。

三、8086CPU工作过程

(1)CS:IP指向内存中第一条指令,读取指令进入指令缓冲器。
(2)IP指向下一条指令。
(3)执行指令。
(4)转至步骤一继续重复这个过程
在这里插入图片描述

四、修改CS、IP内容

采用“jmp 段地址:偏移地址”的指令来修改两个寄存器内容。
若想只修改IP的内容,则采用“jmp 某一合法寄存器”的指令来完成,比如jmp ax,把IP寄存器内容改为ax寄存器里内容,好似mov IP,ax(此指令只用来类比但并不能改变IP的值)。

以上是关于寄存器CS和IP的主要内容,如果未能解决你的问题,请参考以下文章

汇编语言

操作系统

汇编语言入门-段指针

8086汇编 段寄存器

寄存器

汇编语言第2章 寄存器