寄存器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的主要内容,如果未能解决你的问题,请参考以下文章