灯火互联
管理员
管理员
  • 注册日期2011-07-27
  • 发帖数41778
  • QQ
  • 火币41290枚
  • 粉丝1086
  • 关注100
  • 终身成就奖
  • 最爱沙发
  • 忠实会员
  • 灌水天才奖
  • 贴图大师奖
  • 原创先锋奖
  • 特殊贡献奖
  • 宣传大使奖
  • 优秀斑竹奖
  • 社区明星
阅读:3981回复:0

[系统教程]经典汇编语言教程:2.2.1 段寄存器的

楼主#
更多 发布于:2012-09-10 17:41


段寄存器是因为对内存的分段管理而设置的。16位cpu有四个段寄存器,所以,其程序可同时访问四个不同含义的段。段寄存器及其偏移量的关系如图2.7所示。
段寄存器CS指向存放程序的内存段,IP是用来存放下条待执行的指令在该段的偏移量,把它们合在一起可在该内存段内取到下次要执行的指令。
段寄存器SS指向用于堆栈的内存段,SP是用来指向该堆栈的栈顶,把它们合在一起可访问栈顶单元。另外,当偏移量用到了指针寄存器BP,则其缺省的段寄存器也是SS,并且用BP可访问整个堆栈,不仅仅是只访问栈顶。
段寄存器DS指向数据段,ES指向附加段,在存取操作数时,二者之一和一个偏移量合并就可得到存储单元的物理地址。该偏移量可以是具体数值、符号地址和指针寄存器的值等之一,具体情况将由指令的寻址方式来决定。

02-7.gif[设为封面] [删除]
图2.7 段和段寄存器的示意图

通常,缺省的数据段寄存器是DS,只有一个例外,即:在进行串操作时,其目的地址的段寄存器规定为ES。当然,在一般指令中,我们还可以用强置前缀的方法来改变操作数的段寄存器(见:第3.3节中的强置前缀的书写格式)。
一般情况下,段寄存器及其指针寄存器的关系如下表所示。表2.2中的“可选用的段寄存器”即是可以用强置说明这些段寄存器的值来作为其操作数地址的段地址。
表2.2 段寄存器及其指针寄存器的关系 访问存储器方式缺省的段寄存器可选用的段寄存器偏移量
取指令CSIP
堆栈操作SSSP
一般取操作数DSCS、ES、SS有效地址
串操作
源操作数DSCS、ES、SSSI

目标操作数ESDI
使用指针寄存器BPSSCS、DS、ES有效地址
由上表可以看出16位CPU在段寄存器的方面有如下规定:

★、取指令所用的段寄存器和偏移量一定是用CS和IP;

★、堆栈操作所用的段寄存器和偏移量一定是SS和SP;

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

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

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

喜欢0 评分0
游客

返回顶部