第4章典型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文档。上传文档
查看更多
第4章典型CPU及指令系统举例.ppt

第4章 典型CPU及指令系统举例 学习目标 理解8086/8088CPU的寄存器结构、主存储器、堆栈结构。 掌握8086/8088指令系统的寻址方式。这是本章的学习的重点内容,是理解指令功能和编程的基础。 理解8086/8088指令类型。 4.1 8086/8088 CPU 8086 CPU是16位微处理器,即CPU的内外数据总线为16位,一个总线周期可以传送一个字(16位)数据。 8088 CPU是准16位微处理器,其CPU的内部总线为16位,外部数据总线为8位,因此一个总线周期只能传送一个字节 8086和8088两者的内部结构基本上相同,其地址引脚均为20位,可寻址1M字节的主存空间。 1.8086/8088的内部结构 8086/8088CPU采用指令流水线结构,将取指令(或取操作数)与执行指令的功能分别由两个独立部件实现, 即总线接口部件BIU与执行部件EU 1.8086/8088的内部结构 1.8086/8088的内部结构 执行部件EU:包括一个16位算术逻辑运算部件ALU、一组通用寄存器、暂存器,以及EU控制器。EU的主要任务是执行指令。具体功能,见P115 总线接口部件BIU:包括一组段寄存器、指令指针、6字节的指令队列(8088是4字节)、20位地址总线形成部件,以及总线控制逻辑。BIU的主要任务是完成CPU与内存或I/O端口之间的信息传送。 1.8086/8088的内部结构 8086/8088 主存地址的形成 问题:8086/8088的主存容量为1M字节,其主存单元地址为20位,而CPU内部寄存器和数据通路是16位。如何将16位地址码扩展到20位? 1.8086/8088的内部结构 8086/8088 主存地址的形成 解决办法:把主存空间划分为若干段,每个段的最大长度为64K字节。将每个段的起始地址(称为段基值),放在段寄存器中。由EU或指令指针IP提供段内偏移量,即一个内存单元与所在段的段基址之间的字节距离。 1.8086/8088的内部结构 8086/8088 主存地址的形成 1.8086/8088的内部结构 区分段基值和段基址的概念 2. 8086/8088 寄存器 8086/8088 CPU中的寄存器包括段寄存器、通用寄存器以及用于控制的寄存器。 段寄存器: CS(代码段寄存器)——代码段用来存放程序的指令代码序列,CS用来存放当前代码段段首址的高16位,即段基值。 DS(数据段寄存器)——数据段用来存放程序的有关数据,DS用来存放当前数据段的段基值。 2. 8086/8088 寄存器 段寄存器: SS(堆栈段寄存器)——堆栈段用来存放按后进先出顺序存取的信息。SS存放当前堆栈段的段基值。 ES(附加段寄存器)——附加段中存放运算结果或辅助数据。ES用来存放当前附加段的段基值。 2. 8086/8088 寄存器 通用寄存器:EU中设置了8个16位的通用寄存器,按使用情况可分为: 地址指针寄存器。P118 数据寄存器:累加寄存器AX,基址寄存器BX,计数寄存器CX,数据寄存器DX;AH,AL;BH,BL;CH,CL;DH,DL; 2. 8086/8088 寄存器 用于控制的寄存器 指令指针IP:作用类似于PC,当现行指令执行完毕,由IP提供下一条指令地址。 注意指令队列的作用P120 标志寄存器FR 4.2 主存储器 在机器内部是用20位二进制无符号数表示存储单元,在汇编语言中常用5位十六进制数或符号地址表示存储单元地址,十六进制的存储单元地址范围为:00000H~FFFFFH。见P1211图4-8 在8086/8088主存中,一个字节数据占用一个存储单元。一个字数据(16位)则占用二个相邻的存储单元,数的低8位存放在低地址单元,高8位存放在高地址单元,并以此数低字节所在存储单元地址作为字数据的单元地址。 1.主存储器的段结构 8086/8088 把1M的主存空间按需要划分为若干段,每个段都由连续的字节单元组成,最大长度为64K。 一个段的起始单元的地址,称为对应段的段基址(20位)。8086/8088对段基址是有限制的,不能起始于任意地址,段基址的低4位为0。因此1M字节的地址空间中,可作为段基址的共有64K个: 00000H,00010H,00020H,00030H,…… FFFE0H,FFFF0H 在程序中设置的段称为逻辑段。各逻辑段在物理存储器中可以是邻接、间隔、部分重叠和完全重叠。 2. 逻辑地址与物理地址 逻辑地址:包含段基值和偏移量两部分,两者都是无符号16位二进制数,书写格式: 段基值:偏移量 物理地址:是指实际的20位主存单元地址,1M的主存空间的每个存储单元只对应唯一的物理地址,其范围是:00000H~FFFFFH 逻辑地址的来

文档评论(0)

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

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

1亿VIP精品文档

相关文档