典型cpu及指令系统举例.pptVIP

  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文档。上传文档
查看更多
典型cpu及指令系统举例

第四章 典型CPU及指令系统举例 学习内容: 4.1 8086/8088 CPU的结构 4.2 主存储器 4.3 8086/8088堆栈 4.4 8086/8088指令系统 4.5 提高CPU性能的一些措施 学习目标 理解8086/8088CPU的寄存器结构、主存储器、堆栈结构。 掌握8086/8088指令系统的寻址方式。(本章的重点内容) 理解8086/8088指令类型。 了解提高CPU性能的一些措施与当前常用的实际CPU基本组成。 重点难点: 8086/8088指令系统的寻址方式。 课时安排:6课时。 媒体使用: 使用多媒体投影,主要采用PowerPoint准备的电子教案。 §4.1 8086/8088CPU §4.1.1 8086/8088CPU的结构 1. 8086/8088内部结构: 8086/8088CPU采用指令流水线结构,将取指令(或取操作数)与执行指令的功能分别由两个独立部件实现, 即总线接口部件BIU与执行部件EU 总线接口部件BIU见教材P115。 2. 8086/8088主存地址的形成 段基值:在BIU中设置段寄存器,用以存放20位段起始地址的高16位,称为段基值。 偏移量:由EU或指令指针IP提供段内的偏移量,即一个主存单元与所在段的段基址之间的字节距离。(16位) 段基址:由段基值左移4位后,得到一个物理地址。 2. 8086/8088主存地址的形成 2. 8086/8088主存地址的形成 我们把提供一个20位地址的两个寄存器中的值分别称之为: 20位寄存器中的值称之为段基址(Segment base value) 16位寄存器中的值称之为偏移量(Offset)或有效地址(Effective address) 段基址是由四个段寄存器提供20位的高16位,低四位补0形成的 偏移量是由CPU内的EU部分提供的 §4.1. 8086/8088寄存器 1. 段寄存器: CS(代码段寄存器)——用来存放程序的指令代码序列,用来存放当前代码段段首址的高16位,即段基值。 DS(数据段寄存器)——存放程序的有关数据,用来存放当前数据段的段基值。 SS(堆栈段寄存器)——用来存放按后进先出顺序存取的信息。存放当前堆栈段的段基值。 ES(附加段寄存器)——存放运算结果或辅助数据,存放当前附加段的段基值。 1.段寄存器 2 . 通用寄存器 (1)地址指针寄存 (2)数据寄存器 3. 用于控制的寄存器 (1)指令指针IP: (2)标志寄存器FR §4.2 主存储器 §4.2.1 8086/8088主存储器的特点 8086/8088CPU有20条地址引出线,因此具有1M字节(210*210=220)的寻址能力,即可以在1M个字节单元中寻找出所需的一个存储单元。 在8086/8088主存中,一个字节数据占用一个存储单元。一个字(Word)数据(16位)则占用二个相邻的存储单元,数的低8位(低字节)存放在低地址单元;高8位(高字节)存放在高地址单元,并以低字节所在存储单元地址作为字数据的单元地址。 §4.2.2 主存储器的段结构 8086/8088把1MB主存空间按需要划分为若干段(segment)。每个段都由连续的字节单元组成,最大长度为64K(即65536),可作为独立寻址的逻辑单位。 一个段起始单元的地址,称为对应段的段基址(20位)。 §4.2.2 主存储器的段结构 在程序中设置的段称为逻辑段。 主存可分成任意多个段,但在某一时刻,一个程序只能访问4个段寄存器指向的当前段的内容。4个段寄存器CS、DS、SS和ES,分别保存代码段、数据段、堆栈段和附加段这4个当前段的段基址的高16位——段基值。 §4.2.3 逻辑地址与物理地址 逻辑地址——段基值:偏移量(书写形式) (1) 段基值:由某个段寄存器(CS,DS,SS,ES)给出,它是段基址的高16位。 (2) 偏移量:(也称偏移地址)由IP或EU按寻址方式产生的有效地址提供,它是段内某存储单元与段基址之间的字节距离。 物理地址——是指实际的20位主存单元地址,1MB主存空间的每个存储单元只对应惟一的物理地址,其范围为00000H—FFFFFH。 逻辑地址——物理地址的转换方式: 将段基值左移4位形成20位段基址,再加上偏移量,产生20位物理地址。 逻辑地址的来源 CPU在执行指令时,是按指令所需的操作类型从不同的来源获得存储单元的逻辑地址,然后形成对应的物理地址以访问主存。(具体内容见教材的P124表4-2逻辑地址的来源) §4.3 8086/8088堆栈 §4.3.1 堆栈组织 8086/8088的堆栈是由SS指定的一段存储区(≤64KB)构成,并采用向上(地址码减小)生成方式,由堆栈指针S

文档评论(0)

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

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

1亿VIP精品文档

相关文档