3、段寄存器的引用

段寄存器是因为对内存的分段管理而设置的。16位CPU有四个段寄存器,所以,其程序可同时访问四个不同含义的段。段寄存器及其偏移量的引用关系如图2.7所示。

段寄存器CS指向存放程序的内存段,IP是用来存放下条待执行的指令在该段的偏移量,把它们合在一起可在该内存段内取到下次要执行的指令。

段寄存器SS指向用于堆栈的内存段,SP是用来指向该堆栈的栈顶,把它们合在一起可访问栈顶单元。另外,当偏移量用到了指针寄存器BP,则其缺省的段寄存器也是SS,并且用BP可访问整个堆栈,不仅仅是只访问栈顶。

段寄存器DS指向数据段,ES指向附加段,在存取操作数时,二者之一和一个偏移量合并就可得到存储单元的物理地址。该偏移量可以是具体数值、符号地址和指针寄存器的值等之一,具体情况将由指令的寻址方式来决定。

图2.7 段和段寄存器的引用示意图

通常,缺省的数据段寄存器是DS,只有一个例外,即:在进行串操作时,其目的地址的段寄存器规定为ES。当然,在一般指令中,我们还可以用强置前缀的方法来改变操作数的段寄存器(见:第3.3节中的强置前缀的书写格式)。

一般情况下,段寄存器及其指针寄存器的引用关系如下表所示。表2.2中的“可选用的段寄存器”即是可以用强置说明这些段寄存器的值来作为其操作数地址的段地址。

表2.2 段寄存器及其指针寄存器的引用关系

访问存储器方式 缺省的段寄存器 可选用的段寄存器 偏移量
取指令 CS   IP
堆栈操作 SS   SP
一般取操作数 DS CS、ES、SS 有效地址
串操作

源操作数

DS CS、ES、SS SI

目标操作数

ES   DI

使用指针寄存器BP

SS CS、DS、ES 有效地址

由上表可以看出16位CPU在段寄存器的引用方面有如下规定:

、取指令所用的段寄存器和偏移量一定是用CSIP

、堆栈操作所用的段寄存器和偏移量一定是SSSP

、串操作的目标操作数所用的段寄存器和偏移量一定是ESDI

、其它情况,段寄存器除了其默认引用的寄存器外,还可以强行改变为其它段寄存器。

对于上述规定,随着后续内容的叙述,将会对它们有更进一步理解。