- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[工学]2章 8086cpu最新
第2章 80x86 CPU 8086/8088微处理器的编程结构 8086/8088的 引脚信号及工作模式 8086/8088的总线操作时序 8086/8088存储器的组织和管理 8086/8088多处理器系统 从80286到Pentium系列CPU的发展过程 2.1 8086/8088的编程结构 · 16位处理器,采用高性能的N沟道、耗尽型硅栅工艺(NMOS)制造,40脚DIP封装,内含29000个晶体管 掌握一个CPU的工作性能和使用方法,首先 应该了解它的编程结构。 编程结构——就是从一个程序员和使用者的角度看到的结构,它不同于CPU内部的物理结构和实际布局。 (一)BIU (1)地址加法器和段寄存器 由于8086微处理器具有20位地址线,可以方便地寻址1MB的内存单元。但在CPU内部只有16位的寄存器,这就无法保存和传送每个存储单元的20位地址信息,为了正确地访问存储器,8086采用了存储器分段结构,将1MB的内存空间划分为若干个逻辑段,段寄存器用来存放各段的段基址。 地址加法器根据每个逻辑段中使用16位段基址和16位偏移地址进行寻址,计算并形成CPU所要访问的存储单元的20位地址信息。 20位物理地址=16位段基址(左移4位)+16位EA (2)指令队列缓冲器 是6个字节的“先进先出”的RAM存储器,用来按顺序存放CPU要执行的指令代码,并送入执行部件EU中去执行。 EU总是从指令队列的输出端取指令,每当指令队列中存满一条指令后,EU就立即开始执行。当指令队列中前两个指令字节被EU取走后,BIU就自动执行总线操作,读出指令并填入 指令队列中。当程序发生跳转时,BIU则立即清除原来指令队列中的内容并重新开始读取指令代码。 (3)总线控制电路 总线控制电路主要负责产生总线控制信号。例如:产生对存储器的读/写控制信号和I/O端口的读/写控制信号等。 (二)执行单元EU(Execution Unit) EU负责指令的执行。 从BIU的指令队列中取出指令代码,经指令译码器译码后执行指令所规定的全部功能。 执行指令所得结果或执行指令所需的数据,都由EU向BIU发出命令,对存储器或I/O接口进行读/写操作获得。 (1)算术逻辑单元ALU ALU是一个16位的算术逻辑运算部件,用来对操作数进行算术运算和逻辑运算,也可以按指令的寻址方式计算出CPU要访问的内存单元的16位偏移地址。 (2)通用寄存器组、数据暂存寄存器: 是16位的寄存器,它的主要功能是暂时保存数据,并向ALU提供参与运算的操作数。 (3)EU控制电路: EU控制电路接收从BIU指令队列中取出的指令代码,经过分析、译码后形成各种实时控制信号,对各个部件进行实时操作。 (三)、EU与BIU的协同并行工作 8086CPU的寄存器结构 2、指针寄存器和变址寄存器(16位数据寄存) 两个指针寄存器 SP(stack pointer)、BP(base pointer) 两个变址寄存器 SI(source index)、DI(destination index)。 通常用来存放存储器单元的16位EA(即相对于段起始地址的距离,简称偏移地址 EA)。 (1)指针寄存器 (SP\BP) 在8086 CPU内存中有一个按照“先进后出”原则进行数据操作的区域,称为堆栈。CPU对堆栈的操作有两种:压入(PUSH)和弹出(POP),在进行堆栈操作的过程中,SP用来指示堆栈栈顶的偏移地址,称为堆栈指针;而其他指令访问堆栈内容时,用BP来存放位于堆栈段中的一个数据区的“基址”的偏移量,称为基址指针。 如 PUSH/POP AX 和 MOV AX ,[BP]5 (2)变址寄存器 (SI\DI) SI,DI称为变址寄存器,用来存放当前数据所在存储单元的偏移地址。 在串操作指令中, SI存放源操作数地址的偏移量,称为源变址寄存 器; DI存放目标操作数地址的偏移量,称为目标变址寄存器。 通用寄存器的默认用法 3、段寄存器(segment registers) CS(code segment)、DS(data segment)、 SS(stack segment)、ES(extra segment)。 这些寄存器指明了一个特定的现行段,用来存放各段的段基址。当用户用指令设定了它们的初值后,实际上已经确定了一个64KB的存储区段。 CS用来存放当前使用的代码段的段基址,用
您可能关注的文档
最近下载
- 外教社新世纪英专本科生系列(修订版):英语阅读 第1册 PPT课件Unit 3.pptx VIP
- 毕业论文的选题及开题报告的撰写.pptx VIP
- 初中语文2025届中考常考易错字词汇总(多音字+形声字+易错字形+易错成语).pdf VIP
- 4清洁生产的实施途径.pptx VIP
- 中视科华有限公司北京技术服务分公司招聘笔试题库2025.pdf
- JJG 1201-2024 数字式轮胎压力表.pdf
- 高标准农田建设项目监理实施细则.docx
- 四川省成都市2022-2023学年八年级下册期末物理试卷3(含答案).pdf VIP
- 钩端螺旋体病疫情应急处置技术方案.doc VIP
- GB 24430.1-2009 家用双层床安全第1部分:要求.docx VIP
文档评论(0)