- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
8086_8088 存储器分段概念
存储 器 分段 的原 因
在此之前,我假设大家都理解存储地址以及大端小端的概念。如上图所示为存储器的示意图。那么为
什么要引入分段的概念。
其实,8086/8088引入存储器的分段是有原因的。我们都知道8086/8088 CPU有20根地址线,这样可以
直接寻址的物理地址空间为1M字节 (存储单元以字节为单位),范围是00000H至FFFFFH。但是我在前一
节介绍中说到8086/8088 CPU的寄存器都是16位,那么在传输地址时显然一次只能传输16位有效地址,也
就是只足够访问64K字节地址空间。为了实现寻址1M字节物理空间,8086/8088引入了分段的概念。
存储 器 分段 的概 念
所谓分段,就是可以根据需要把1M字节地址空间划分为若干逻辑段。每个逻辑段必须满足如下两个条
件:
1. 逻辑段的开始地址必须是16的倍数,因为段寄存器长为16位;
2. 逻辑段的最大长度为64K,因为指针寄存器长为16位。
那么1M字节地址空间最多可划分成64K个逻辑段,最少也要划分成16个逻辑段。逻辑段与逻辑段可以相
连,也可以不相连,还可以部分重叠。
这种存储器分段的方法不仅有利于实现寻址1M字节空间,而且也十分有利于对1M字节存储空间的管
理。如下图所示为存储器逻辑段的一种划分。
存储 地址 形成
要访问某个存储单元,根据我们划分的逻辑段,计算存储单元的地址与所在段的起始地址的差值,称
段内偏移 (简称偏移)。
在整个1M地址空间中,存储单元的物理地址等于段起始地址加上段内偏移。物理地址计算公式如下所
示:
物理地址 段值 * 10H + 段内偏移
举个例子:用16进制表示的逻辑地址1234:3456H所对应的存储单元的物理地址为
12340H+3456H 15796H。
其中,段值由段寄存器给出,段内偏移可由指令指针IP、堆栈指针SP和其他可作为存储器指针使用的
存储器 (SI、DI、BX和BP)给出,段内偏移还可以直接用16位数给出。
段 寄存 器 的使 用
当然,段寄存器的使用也是有规定的。在8086/8088 CPU中有四个段寄存器,可以保存四个段值,但这
四个段分工不同。如下图所示为段和段寄存器的引用。
在取指令时,CPU会 自动引用代码段寄存器CS,再加上由IP所给出的16位
段内偏移,得到要取指令的物理地址。
当涉及堆栈操作时,CPU会 自动引用堆栈段寄存器SS,再加上由SP所给出
的16位段内偏移,得到堆栈操作所需的物理地址。
当段内偏移涉及BP寄存器时,缺省引用的段寄存器也为堆栈段寄存器SS。
在一般数据存取的情况下,则自动选择数据段寄存器DS或附加段寄存器ES
,再加上16位偏移,得到存储器操作数的物理地址。此时的16位偏移有多重
可能性,取决于指令的寻址方式,下一节将会讲到。
通常如果整个程序不超过64K字节,那么使用1个64K字节的段就可以了;如果程序的数据区长度超过
64K字节,那么就要在两个或多个数据段中存取数据,这只需要改变数据段寄存器内的段值就可以了。最
后,附上段寄存器的引用规定表。
原创力文档


文档评论(0)