8086_8088 存储器分段概念.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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)

xxj1658888 + 关注
实名认证
文档贡献者

教师资格证持证人

该用户很懒,什么也没介绍

领域认证该用户于2024年04月12日上传了教师资格证

1亿VIP精品文档

相关文档