欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    【教学课件】第2章微型计算机概述.ppt

    • 资源ID:5658316       资源大小:1.35MB        全文页数:136页
    • 资源格式: PPT        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    【教学课件】第2章微型计算机概述.ppt

    2.1 微型计算机的基本结构2.2 8086(8088)CPU2.3 系统总线的形成习题,1硬件系统微型计算机硬件系统如图2.1所示。,图2.1 微型计算机结构框图,通常,将图2.1中用虚线框起来的部分叫做微型计算机。若将该部分集成在一块集成电路芯片上,则叫做单片微型计算机,简称单片机。若在该部分的基础上,再包括构成微型计算机所必需的外设,则构成了微型计算机系统,实际上是指硬件系统。微型计算机主要由如下几个部分组成:微处理器或称中央处理单元(CPU)、内部存储器(简称内存)、输入/输出接口(简称接口)及系统总线。,1)CPU CPU是一个复杂的电子逻辑元件,它包含了早期计算机中的运算器、控制器及其他功能,能进行算术、逻辑运算及控制操作。现在经常见到的CPU均采用超大规模集成技术做成单片集成电路。它的结构很复杂、功能很强大。后面将详细地对它加以说明。,2)内存 所谓内存就是指微型计算机内部的存储器。由图2.1可以看到,内存是直接连接在系统总线上的。因此,内存的存取速度比较快。由于内存价格较高,一般其容量较小。这与作为外设(外部设备)的外部存储器刚好相反,后者容量大而速度慢。内存用来存放微型计算机要执行的程序及数据。在微型计算机的工作过程中,CPU从内存中取出程序执行或取出数据进行加工处理。这种由内存取出的过程称为读出内存,而将数据或程序存放于内存的过程则称为写入内存。,存储器由许多单元组成,每个单元存放一组二进制数。我们将要学习的这种微型计算机中规定每个存储单元存放8位二进制数,8位二进制数定义为一个字节。为了区分各个存储单元,就给每个存储单元编上不同的号码,人们把存储单元的号码叫做地址。内存的地址编号是由0开始的,地址顺序向下编排。例如,后面将要介绍的8086CPU的内存地址是00000HFFFFFH,共1兆个存储单元,简称内存可达到1兆字节(1MB)。,如上所述,存储单元的地址一般用十六进制数表示,而每一个存储器地址中又存放着一组二进制(或用十六进制)表示的数,通常称为该地址的内容。值得注意的是,存储单元的地址和地址中的内容两者是不一样的。前者是存储单元的编号,表示存储器中的一个位置,而后者表示这个位置里存放的数据。正如一个是房间号码,另一个是房间里住的人一样。,3)系统总线 目前,微型计算机都采用总线结构。所谓总线就是用来传送信息的一组通信线。由图2.1可以看到,系统总线将构成微型机的各个部件连接到一起,实现了微型机内各部件间的信息交换。由于这种总线在微型机内部,故也将系统总线称为内总线。,如图2.1所示,一般情况下,CPU提供的信号经过总线形成电路形成系统总线。概括地说,系统总线包括地址总线、数据总线和控制总线。这些总线提供了微处理器(CPU)与存储器、输入/输出接口部件的连接线。可以认为,一台微型计算机就是以CPU为核心,其他部件全都“挂接”在与CPU相连接的系统总线上,这样的结构为组成一个微型计算机带来了方便。人们可以根据自己的需要,将规模不一的内存和接口接到系统总线上。需要内存大、接口多时,可多接一些;需要少时,少接一些,很容易构成各种规模的微型机。,另外,微型计算机与外设(也包括其他计算机)的连接线称为外总线,也称为通信总线。它的功能就是实现计算机与计算机或计算机与其他外设的信息传送。微型计算机工作时,通过系统总线将指令读到CPU;CPU的数据通过系统总线写入内存单元;CPU将要输出的数据经系统总线写到接口,再由接口通过外总线传送到外设;当外设有数据时,经由外总线传送到接口,再由CPU通过内总线读接口读到CPU中。,4)接口 微型计算机广泛地应用于各个部门和领域,所连接的外部设备是各式各样的。它们不仅要求不同的电平、电流,而且要求不同的速率,有时还要考虑是模拟信号,还是数字信号。同时,计算机与外部设备之间还需要询问和应答信号,用来通知外设做什么或告诉计算机外设的情况或状态。为了使计算机与外设能够联系在一起,相互匹配并有条不紊地工作,就需要在计算机和外部设备之间接上一个中间部件,以便使计算机正常工作,该部件就叫做输入/输出接口。,为了便于CPU对接口进行读写,就必须为接口编号,称为接口地址。8086(8088)的接口地址可从0000H到FFFFH编址,共64K。在图2.1中,虚线方框内的部分构成了微型计算机,方框以外的部分称为外部世界。微型计算机与外部世界相连接的各种设备,统称外部设备。,另外,在微型计算机的工程应用中所使用的各种开关、继电器、步进电机、A/D及D/A变换器等均可看做微型计算机的外部设备(简称外设)。通过接口部件,微型机与外设协调地工作。接口部件使用很普遍,目前已经系列化和标准化,而且有许多具有可编程序功能,使用方便、灵活,功能也非常强。根据所使用的外部设备,人们可以选择适合要求的接口部件与外设相连。,2软件系统 在上面的叙述中简要地说明了构成微型计算机的硬件组成部分。但任何微型计算机要正常工作,只有硬件是不够的,必须配上软件。只有软、硬件相互配合,相辅相成,微型计算机才能完成人们所期望的功能。可以这么说,硬件是系统的躯体,而软件(即各种程序的集合)是整个系统的灵魂。不配备任何软件的微型机,人们称它为物理机或裸机。,它和刚诞生的婴儿一样,只具有有限的基本功能。一个婴儿将来可能成为一个伟大的科学家,也可能成为一个无所事事的人,这主要取决于他本人和社会如何对他灌输知识和教育。与此比喻相同,一台微型机,如给它配备简单的软件,它只能做简单的工作;如给它配上功能强大的软件,它就可以完成复杂的工作。微型计算机软件系统包括系统软件和应用软件两大类。,1)系统软件 系统软件用来对构成微型计算机的各部分硬件,如CPU、内存、各种外设等进行管理和协调,使它们有条不紊、高效率地工作。同时,系统软件还为其他程序的开发、调试、运行提供一个良好的环境。,提到系统软件,首先就是操作系统。它是由厂家研制并配置在微型计算机上的。一旦微型计算机接通电源,就进入操作系统。在操作系统的支持下,实现人机交互;在操作系统的控制下,实现对CPU、内存和外部设备的管理以及各种任务的调度与管理。在操作系统平台下运行的各种高级语言、数据库系统、各种功能强大的工具软件以及本书将要讲述的C语言和汇编语言均是系统软件的组成部分。在操作系统及其他有关系统软件的支持下,微型计算机的用户可以开发他们的应用软件。,2)应用软件 应用软件是针对不同应用、实现用户要求的功能软件。例如,Internet网点上的Web页、各部门的MIS程序、CIMS中的应用软件以及微型机应用系统中的各种监测控制程序等等。根据各种应用软件的功能要求,在不同的软硬件平台上进行开发时,可以选用不同的系统软件支持,例如不同的操作系统、不同的高级语言、不同的数据库等等。应用软件的开发,采用软件工程的技术途径进行。,应用软件一般都由用户开发完成。用户可以根据微型计算机应用系统的资源配备情况,确定使用何种语言来编写用户程序,既可以用高级语言也可以用汇编语言。高级语言功能强,且比较接近于人们日常生活用语习惯,因此比较容易用其编写程序;而用汇编语言编写的程序则具有执行速度快、对端口操作灵活的特点。在当前,人们通常用高级语言和汇编语言混合编程的方法来编写用户程序。,2.1.2 微型计算机的工作过程 如前所述,微型机在硬件和软件的相互配合之下才能工作。如果仔细观察微型计算机的工作过程就会发现,微型机为完成某种任务,总是将任务分解成一系列的基本动作,然后一个一个地去完成每一个基本动作。当这一任务所有的基本动作都完成时,整个任务也就完成了。这是计算机工作的基本思路。,CPU进行简单的算术运算或逻辑运算、从存储器取数、将数据存放于存储器、由接口取数或向接口送数等,这些都是一些基本动作,也称为CPU的操作。尽管CPU的每一种基本操作都很简单,但几百、几千、几十万甚至更多的基本操作组合在一起,就可以完成某种非常复杂的任务。可以说,现代的计算机可以完成人们所能想到的任何工作,这些工作最终就是通过一系列的简单操作来实现的。,命令微处理器进行某种操作的代码叫做指令。前面已经提到,微处理器只能识别由0和1电平组成的二进制编码,因此,指令就是一组由0和1构成的数字编码。微处理器在任何一个时刻只能进行一种操作。为了完成某种任务,就需把任务分解成若干种基本操作,明确完成任务的基本操作的先后顺序,然后用计算机可以识别的指令来编排完成任务的操作顺序。计算机按照事先编好的操作步骤,每一步操作都由特定的指令来指定,一步接一步地进行工作,从而达到预期的目的。这种完成某种任务的一组指令就称为程序,计算机的工作就是执行程序。,下面通过一个简单程序的执行过程,对微型计算机的工作过程做简要介绍。随着本书的讲述,将使读者对微型计算机的工作原理逐步加深理解。用微型计算机求解“7+10=?”这样一个极为简单的问题,必须利用指令告诉计算机该做的每一个步骤,先做什么,后做什么。具体步骤如下:7ALAL+10AL,其含义就是把7这个数送到AL里面,然后将AL中的7和10相加,把要获得的结果存放在AL里。把它们变成计算机直接识别并执行的如下程序:,也就是说,上面的问题用3条指令即可解决。这些指令均用二进制编码来表示,微型计算机可以直接识别和执行。因此,人们常将这种用二进制编码表示的、CPU能直接识别并执行的指令称为机器代码或机器语言。但直接用这种二进制代码编程序会给程序设计人员带来很大的不便。因为它们不好记忆,不直观,容易出错,而且出了错也不易修改。,为了克服机器代码带来的不便,人们用缩写的英文字母来表示指令,它们既易理解又好记忆。人们把这种缩写的英文字母叫做助记符。利用助记符加上操作数来表示指令就方便得多了。上面的程序可写成如下形式:MOVAL,7ADD AL,10HLT程序中第一条指令将7放在AL中;第二条指令将AL中的7加上10并将相加之和放在AL中;第三条指令是停机指令。当顺序执行上述指令时,AL中就存放着要求的结果。,微型计算机在工作之前,必须将用机器代码表示的程序存放在内存的某一区域里。微型机执行程序时,首先通过总线将第一条指令取进微处理器并执行它,然后取第二条指令,执行第二条指令,依次类推。计算机就是这样按照事先编排好的顺序,依次执行指令。这里要再次强调,计算机只能识别机器代码,不能识别助记符。因此,用助记符编写的程序必须转换为机器代码才能为计算机所直接识别。有关这方面的知识,将在下面的章节中说明。,1设置指令预取队列(指令队列缓冲器)可以形象地想像8086(8088)CPU集成了两种功能单元:总线接口单元(BIU)和指令执行单元(EU)。前者只管不断地从内存将指令读到CPU中,而后者只管执行读来的指令。两者可以同时进行,并行工作。为此,8086CPU中设置了一个6个字节的指令预取队列(8088CPU中的指令预取队列为4个字节)。指令由BIU从内存取出先放在队列中,而EU从队列中取出指令执行。一旦BIU发现队列中空出两个字节以上的位置,它就会从内存中取指令代码放到预取队列中,从而提高了CPU执行指令的速度。,2设立地址段寄存器8086(8088)CPU内部的地址线只有16位,因此,能够由ALU提供的最大地址空间只能为64KB。为了扩大它们的地址宽度,可将存储器的空间分成若干段,每段为64KB。另外,在微处理器中还设立了一些段寄存器,用来存放段的起始地址(16位)。8086(8088)微处理器的实际物理地址是由段地址和CPU提供的16位偏移地址,按一定规律相加而形成的20位地址(A0A19),从而使8086(8088)微处理器的地址空间扩大到1MB。,3在结构上和指令设置方面支持多微处理器系统众所周知,利用8086(8088)的指令系统进行复杂的运算,如多字节的浮点运算、超越函数的运算等,往往是很费时间的。为了弥补这一缺陷,当时的CPU设计者开发了专门用于浮点运算的协处理器8087。将8086(8088)和8087结合起来,就可以组成运算速度很高的处理单元。为此,8086(8088)在结构和指令方面都已考虑了能与8087相连接的措施。,另一方面,为了能用8086(8088)微处理器构成一个共享总线的多微处理器系统结构,以提高微型计算机的性能,同样,在微处理器的结构和指令系统方面也做了统一考虑。总之,8086(8088)微处理器不仅将微处理器的内部寄存器扩充至16位,从而使寻址能力和算术逻辑运算能力有了进一步提高,而且由于采取了上述一些措施,使得微处理器的综合性能与8位微处理器相比有了明显的提高。,8086CPU的引线及其功能8086 CPU是一块具有40条引出线的集成电路芯片,其各引出线的定义如图2.2所示。为了减少芯片的引线,许多引线都具有双重定义和功能,采用分时复用方式工作,即在不同时刻,这些引线上的信号是不同的。同时,8086CPU上有MN/输入引线,用以决定8086CPU工作在哪种工作模式之下。当MN/=1时,8086CPU工作在最小模式之下。此时,构成的微型机中只包括一个8086CPU,且系统总线由CPU的引线形成,微型机所用的芯片少。当MN/=0时,8086CPU工作在最大模式之下。,在此模式下,构成的微型计算机中除了有8086CPU之外,还可以接另外的CPU(如8087、8089等),构成多微处理器系统。同时,这时的系统总线要由8086CPU的引线和总线控制器(8288)共同形成,可以构成更大规模的系统。,1最小模式下的引线 在最小模式下,8086CPU的引线如图2.2所示(不包括括号内的信号)。现对各引脚介绍如下:A16A19/S3S6:这是4条时间复用、三态输出的引线。在8086CPU执行指令过程中,某一时刻从这4条线上送出地址的最高4位A16A19。而在另外时刻,这4条线送出状态S3S6。这些状态信息里,S6始终为低,S5指示状态寄存器中的中断允许标志的状态,它在每个时钟周期开始时被更新,S4和S3用来指示CPU现在正在使用的段寄存器,其信息编码如表2.1所示。,图2.2 8086CPU的引线,表2.1 S4、S3的状态编码,在CPU进行输入/输出操作时,不使用这4位地址,故在送出接口地址的时间里,这4条线的输出均为低电平。在一些特殊情况下(如复位或DMA操作时),这4条线还可以处于高阻(或浮空、或三态)状态。AD0AD15:它们是地址、数据时分复用的输入/输出信号线,其信号是经三态门输出的。由于8086微处理器只有40条引脚,而它的数据线为16位,地址线为20位,因此引线数不能满足信号输入/输出的要求。,于是在CPU内部就采用时分多路开关,将16位地址信号和16位数据信号综合后,通过这16条引脚输出(或输入)。利用定时信号来区分是数据信号还是地址信号。通常,CPU在读/写存储器和外设时,总是先给出存储器单元的地址或外设的端口地址,然后才读/写数据,因而地址和数据在时序上是有先后的。如果在CPU外部配置一个地址锁存器,在这16条引线出现地址信号的时侯把地址信号锁存在锁存器中,利用锁存器的输出去选通存储器的单元或外设端口,那么在下一个时序间隔中,这16条引脚就可以作为数据线进行数据的输入或输出操作了。,M/IO:它是CPU的三态输出控制信号,用来区分当前操作是访问存储器还是访问I/O端口。若该引脚输出为低电平,则访问的是I/O端口;若该引脚输出为高电平,则访问的是存储器。WR:它是CPU的三态输出控制信号。该引脚输出为低电平时,表示CPU正处于写存储器或写I/O端口的状态。,DT/:该引脚是CPU的三态输出控制信号,用于确定数据传送的方向。高电平为发送方向,即CPU写数据到内存或接口;低电平为接收方向,即CPU到内存或接口读数据。该信号通常用于数据总线驱动器8286/8287(74245)的方向控制。:这是CPU经三态门输出的控制信号。该信号有效时,表示数据总线上有有效的数据。它在每次访问内存或接口以及在中断响应期间有效。它常用做数据总线驱动器的片选信号。,ALE:三态输出控制信号,高电平有效。当它有效时,表明CPU经其引线送出有效的地址信号。因此,它常作为锁存控制信号将A0A19锁存于地址锁存器的输出端。:它是读选通三态输出信号,低电平有效。当其有效时,表示CPU正在进行存储器或I/O读操作。,READY:它是准备就绪输入信号,高电平有效。当CPU对存储器或I/O进行操作时,在T3周期开始采样READY信号。若为高电平,表示存储器或I/O设备已准备好;若其为低电平,表明被访问的存储器或I/O设备还未准备好数据,则应在T3周期以后,插入TWAIT周期(等待周期),然后在TWAIT周期中再次采样READY信号,直至READY变为有效(高电平),TWAIT周期才可以结束,进入T4周期,完成数据传送。,INTR:它是可屏蔽中断请求输入信号,高电平有效。CPU在每条指令执行的最后一个T状态采样该信号,以决定是否进入中断响应周期。这条引脚上的请求信号,可以用软件复位内部状态寄存器中的中断允许位(IF)加以屏蔽。:它是可用WAIT指令对该引脚进行测试的输入信号,低电平有效。当该信号有效时,CPU继续执行程序;否则CPU就进入等待状态(空转)。这个信号在每个时钟周期的上升沿由内部电路进行同步。,NMI:它是屏蔽中断输入信号,边沿触发,正跳变有效。这条引脚上的信号不能用软件复位内部状态寄存器中的中断允许位(IF)予以屏蔽,所以由低到高的变化将使CPU在现行指令执行结束后就引起中断。RESET:它是CPU的复位输入信号,高电平有效。为使CPU完成内部复位过程,该信号至少要在4个时钟周期内保持有效。复位后CPU内部寄存器的状态如表2.2所示,各输出引脚的状态如表2.3所示。表2.3中从(S0)到各引脚均处于浮动状态。当RESET返回低电平时,CPU将重新启动。,表2.2 复位后的内部寄存器状态,表2.3 复位后各引脚的状态,:它是CPU输出的中断响应信号,是CPU对外部输入的INTR中断请求信号的响应。在响应中断过程中,由引出端送出两个负脉冲,可用做外部中断源的中断向量码的读选通信号。HOLD:它是高电平有效的输入信号,用于向CPU提出保持请求。当某一部件要占用系统总线时,可通过这条输入线向CPU提出请求。,HLDA:这是CPU对HOLD请求的响应信号,是高电平有效的输出信号。当CPU收到有效的HOLD信号后,就会对其做出响应:一方面使CPU的所有三态输出的地址信号、数据信号和相应的控制信号变为高阻状态(浮动状态);同时还输出一个有效的HLDA,表示处理器现在已放弃对总线的控制。当CPU检测到HOLD信号变低后,就立即使HLDA变低,同时恢复对总线的控制。,/S7:它是时间复用的三态输出信号。该信号有效,用于读/写数据的高字节(D8D15),用以保证8086可以一次读/写一个字节(高字节或低字节)或者读/写一个字(16位)。CLK:这是时钟信号输入端。由它提供CPU和总线控制器的定时信号。8086CPU的标准时钟频率为5MHz。VCC:它是+5V电源输入引脚。GND:它是接地端。,2最大模式下的引线当MN/加上低电平时,8086CPU工作在最大模式之下。此时,除引线24到34这几条引线之外,其他引线与最小模式完全相同。如图2.2所示,图中括号内的信号就是最大模式下重新定义的信号。,:这是最大模式下由8086CPU经三态门输出的状态信号。这些状态信号加到Intel公司同时提供的总线控制器(8288)上,可以产生系统总线所需要的各种控制信号。,的状态编码表示某时刻8086CPU的状态,其编码如表2.4所示。,从表2.4可以看到,当8086CPU进行不同操作时,其输出的S2S0的状态是不一样的。因此,可以简单地理解为8288对这些状态进行译码,产生相应的控制信号。在本章的后面可以看到,8288总线控制器利用S2S0为构成系统总线提供了足够的控制信号。,/,/:它们是总线请求/允许引脚。每一个引脚都具有双向功能,既是总线请求输入也是总线响应输出。但是/比/具有更高的优先权。这些引脚内部都有上拉电阻,所以在不使用时可以悬空。正常使用时的工作顺序大致如下:由其他的总线控制设备(例如数字协处理器8087)产生宽度为一个时钟周期的负向的总线请求脉冲,将它送给RQ/GT引脚,相当于HOLD信号。,CPU检测到这个请求后,在下一个T4或T1期间,在同一个引脚输出宽度为一个时钟周期的负向脉冲给请求总线的设备,作为总线响应信号,相当于HLDA信号。这样从下一个时钟周期开始,CPU就释放总线,总线请求设备便可以利用总线完成某种操作。总线请求设备在对总线操作结束后,再产生一个宽度为一个时钟周期的负向脉冲,通过该引脚送给CPU,它表示总线请求已结束。CPU检测到该结束信号后,从下一个时钟周期开始又重新控制总线,继续执行刚才因其他总线设备请求总线而暂时停止的操作。,:它是一个总线封锁信号,低电平有效。该信号有效时,别的总线控制设备的总线请求信号将被封锁,不能获得对系统总线的控制。信号由前缀指令“LOCK”使其有效,直至下一条指令执行完毕。QS1,QS0:它们是CPU输出的队列状态信号。根据该状态信号输出,从外部可以跟踪CPU内部的指令队列。QS1,QS0的编码如表2.5所示。队列状态在CLK周期期间有效。,表2.5 QS0,QS1的状态编码,2.2.3 8088CPU的引线及其功能8086CPU和8088CPU的内部总线及内部寄存器均为16位,是完全相同的。但是,8088CPU的外部数据线是8位的,即AD0AD7,每一次传送数据只能是8位。而8086CPU是真正的16位处理器,每一次传送数据既可以是16位也可以是8位(高8位或低8位)的。它们有相同的内部寄存器和指令系统,在软件上是互相兼容的。8088 CPU的引线如图2.3所示。,图2.3 8088CPU引线,对照图2.2和图2.3,可以发现它们之间的主要不同表现在引线上:(1)由于8088 CPU外部一次只传送8位数据,因此其引线A8A15仅用于输出地址信号。而8086则将此8条线变为双向分时复用的AD8AD15,即某一时刻送出地址A8A15,而另一时刻则用这8条线传送数据的高8位D8D15。在进行16位数据操作时,8088CPU一定需要两个总线周期才能完成16位数据操作,而8086CPU可能只用一个总线周期、一次总线操作就可完成。因此,8086的速度较8088要快一些。,(2)8086CPU上的/S7信号在8088上变为(HIGH)信号。这是一条状态输出线。它与IO/和DT/信号一起,决定了8088CPU在最小模式下现行总线周期的状态。它们的不同电平所表示的处理器操作情况如表2.6所示。,HIGH:在最大模式时始终为高电平输出。(3)8088的引线28是IO/,即CPU访问内存时该引线输出低电平;访问接口时则输出高电平。对8086而言,该引线的状态刚好相反,即变为M/。当然,两者内部的指令预取队列长度不一样,这在前面已经提到,8088CPU为4个字节而8086CPU为6个字节。从应用的角度来说,这一不同并不重要。,2.2.4 8086CPU的内部结构上面已经说明了关于8086CPU的引线及功能。要特别强调的是从工程应用来说,为了便于以后硬件连接,构成系统,读者在学习任何集成芯片时(包括这里的8086CPU),都必须仔细弄清它们的引线,以便使用时顺利地连接。至于芯片的内部结构,由于芯片集成度的提高,读者不可能也不必要弄清其结构细节,只要对它们有最低限度的了解,满足以后工程应用的需要也就足够了。18086CPU的内部结构8086微处理器内部分为两个部分:执行单元(EU)和总线接口单元(BIU),如图2.4所示。,图2.4 8086(8088)微处理器的内部结构,EU负责指令的执行。它包括ALU(运算器)、通用寄存器和状态寄存器等,主要进行16位的各种运算及有效地址的计算。BIU负责与存储器和I/O设备的接口。它由段寄存器、指令指针、地址加法器和指令队列缓冲器组成。地址加法器将段和偏移地址相加,生成20位的物理地址。,前面已经提到,在8086微处理器中,取指令和执行指令是可以在时间上重叠的,也就是说,总线接口单元的操作与执行单元的操作是完全不同步的。通常,由BIU将指令先读入到指令队列缓冲器中。若此时执行单元刚好要求对存储器或I/O设备进行操作,那么在执行中的取指存储周期结束后,下一个周期将执行执行单元所要求的存储器操作或I/O操作。只要指令队列缓冲器不满,而且执行单元没有存储器或I/O操作要求,BIU总是要到存储器中去取后续的指令。当4个字节的指令队列缓冲器满时,且执行单元又没有存储器或I/O操作请求时,总线接口单元将进入空闲状态。在执行转移、调用、返回指令时,指令队列缓冲器的内容将被清除。,28086处理器中的内部寄存器在8086处理器中,用户能用指令改变其内容的主要是一组内部寄存器,其结构如图2.5所示。,图2.5 8086CPU内部寄存器,1)数据寄存器8086有4个16位的数据寄存器,可以存放16位的操作数。其中AX为累加器,其他3个尽管也可以存放16位操作数,但它们的用途都有区别,具体说明如表2.7所示。,表2.7 数据寄存器的一些专门用途,从图2.5中可以看到,4个16位的寄存器在需要时,可分为8个8位寄存器来用,这样就大大增加了使用的灵活性。2)指针寄存器8086的指针寄存器有两个:SP和BP。SP是堆栈指针寄存器,由它和堆栈段寄存器一起来确定堆栈在内存中的位置。BP是基数指针寄存器,通常用于存放基地址,以使8086的寻址更加灵活。,3)变址寄存器8086的变址寄存器有两个:SI和DI。SI是源变址寄存器,DI是目的变址寄存器,它们都用于指令的变址寻址。顾名思义,SI通常指向源操作数,DI通常指向目的操作数。4)控制寄存器8086的控制寄存器有两个:IP和PSW。IP是指令指针寄存器,用来控制CPU的指令执行顺序。它和代码寄存器CS一起可以确定当前所要取的指令的内存地址。CPU执行程序的地址总是为CS16+IP。当顺序执行程序时,CPU每从内存取一个指令字节,IP自动加1,指向下一个要读取的指令。,当CS不变、IP单独改变时,会发生段内程序转移;当CS和IP同时改变时,会发生段间程序转移。PSW是程序状态字,也有人称它为状态寄存器或标志寄存器,它用来存放8086CPU在工作过程中的状态。PSW各位标志如图2.6所示。,图2.6 状态寄存器,标志寄存器是一个16位的寄存器,空着的各位暂未使用。8086中所用的9位对了解8086CPU的工作和用汇编语言编写程序是很重要的。这些标志位的含义如下:C进位标志位。做加法时出现进位或做减法时出现借位,该标志位置1;否则清0。位移和循环指令也影响进位标志。P奇偶标志位。当结果的低8位中1的个数为偶数时,则该标志位置1;否则清0。,A半加标志位。做加法时,当位3需向位4进位,或做减法时位3需向位4借位时,该标志位置1;否则清0。该标志位通常用于对BCD算术运算结果的调整。Z零标志位。运算结果所有位均为0时,该标志位置1;否则清0。S符号标志位。当运算结果的最高位为1时,该标志位置1;否则清0。,T陷阱标志位(单步标志位)。当该位置1时,将使8086执行单步指令工作方式。在每条指令执行结束时,CPU总是去测试T标志位是否为1。如果为1,那么在本指令执行后将产生陷阱中断,从而执行陷阱中断处理程序。该中断处理程序的首地址由内存的00004H00007H 4个单元提供。该标志位通常用于程序的调试。例如,系统调试软件DEBUG中的T命令,就是利用它来进行程序的单步跟踪的。,I中断允许标志位。如果该位置1,则处理器可以响应可屏蔽中断请求;否则就不能响应可屏蔽中断请求。D方向标志位。当该位置1时,串操作指令为自动减量指令,即从高地址到低地址处理字符串;否则串操作指令为自动增量指令。O溢出标志位。在算术运算中,带符号数的运算结果超出了8位或16位带符号数所能表达的范围,即字节运算大于+127或小于-128时,字运算大于+32 767或小于-32768时,该标志位置位。,5)段寄存器8086微处理器具有4个段寄存器:代码段寄存器CS、数据段寄存器DS、堆栈段寄存器SS和附加段寄存器ES。这些段寄存器的内容与有效的地址偏移量一起可确定内存的物理地址。通常CS规定并控制程序区,DS和ES控制数据区,SS控制堆栈区。,2.2.5 存储器寻址对只学过8位微处理器的读者来说,存储器的段、段寄存器、段内偏移地址等都是过去未涉及的新概念。要想弄清楚为什么8086能寻址1MB的内存空间,并知道如何确定实际的物理地址,这一切都要求读者必须彻底理解这些概念及相互的关系。只有做到了这一点,才能正确地组织存储器和使用存储器。,1由段寄存器、段偏移地址确定物理地址图2.7 物理地址的形成在本节开始我们已经提到,8086可以具有1MB的内存空间,可是内部寄存器只有16位,很显然,不采取特殊措施,是不能寻址1MB存储空间的。为此引入了分段的概念。每个段具有64KB的存储空间。段内的物理地址由16位的段寄存器内容和16位的地址偏移量来确定。,图2.7 物理地址的形成,如图2.7所示,20位的物理地址是这样产生的:物理地址=段寄存器的内容16+偏移地址段寄存器的内容16(相当于左移4位)变为20位,再在低端16位上加上偏移地址(也叫做有效地址EA),便可得到20位物理地址。对于CPU读程序的内存地址,总是由下式来决定:读程序的内存物理地址=CS16+IP,由此可以知道,当8086(8088)CPU复位启动时的复位启动地址(复位入口地址)可如下确定:由于复位时CS=FFFFH,而IP=0000H,则有复位启动地址=CS16+IP=FFFF0H+0000H=FFFF0H也就是说,当8086(8088)CPU读程序时,其内存地址永远是由代码段(CS)寄存器16与IP(指令指针)的内容作为偏移地址来决定的。但是,当8086(8088)CPU读/写内存数据时,DS、SS和ES三个段寄器均可使用,而偏移地址又有多种不同的产生方法,有关内容将在下面的章节中做详细说明。,2段寄存器的使用段寄存器的设立不仅使8086(8088)的存储空间扩大到1MB,而且为信息按特征分段存储带来了方便。在存储器中,信息按特征可分为程序代码、数据、微处理器状态等。为了操作方便,存储器可以相应地划分为:程序区,用来存放程序的指令代码;数据区,用来存放原始数据、中间结果和最后运算结果;堆栈区,用来存放压入堆栈的数据和状态信息。只要修改段寄存器的内容,就可以将相应的存放区设置在内存存储空间的任何位置上。这些区域可以通过段寄存器的设置使之相互独立,也可将它们部分或完全重叠。需要注意的是,改变这些区域的地址时,是以16个字节为单位进行的。图2.8表示了各段寄存器的使用情况。,图2.8 段寄存器的使用情况,在8086CPU中,对不同类型存储器的访问所使用的段寄存器和相应的偏移地址的来源做了一些具体规定。它们的基本约定如表2.8所示。,表2.8 段寄存器使用时的一些基本约定,下面对表2.8中的内容做简要说明。(1)在各种类型的存储器访问中,其段地址要么由“默认”的段寄存器提供,要么由“指定”的段寄存器提供。所谓默认段寄存器是指在指令中不用专门的信息来指定使用某一个段寄存器的情况,这时就由默认段寄存器来提供访问内存的段地址。在实际进行程序设计时,绝大部分都属于这一种情况。在某几种访问存储器的类型中,允许由指令来指定使用另外的段寄存器,这样可为访问不同的存储器段提供方便。这种指定通常是靠在指令码中增加一个字节的前缀来实现的。有些类型的存储器访问不允许指定另一个段寄存器。,(2)段寄存器DS、ES和SS的内容是用传送指令送入的,但任何传送指令都不能向代码段寄存器CS送数。在后面的宏汇编中将讲到,伪指令ASSUME及JMP、CALL、RET、INT和IRET等指令可以设置和影响CS的内容。更改段寄存器的内容意味着存储区的移动。这说明无论程序区、数据区还是堆栈区都可以超过64KB的容量,都可以利用重新设置段寄存器内容的方法加以扩大,而且各存储区都可以在整个存储空间中移动。,(3)表中“段内偏移地址”一栏指明,除了有两种类型访问存储器是“依寻址方式来求得有效地址”外,其他都指明使用一个16位的指针寄存器或变址寄存器。例如,在取指令访问内存时,段内偏移地址只能由指令指针寄存器IP来提供;在堆栈进行压入或弹出操作时,段内偏移地址只能由SP提供;在字符串操作时,源地址和目的地址中的段内偏移地址分别由SI和DI提供。除上述情况以外,为存取操作数而访问内存时,将依不同寻址方式求得段内偏移地址。,2.2.6 8086CPU的工作时序1指令周期与其他周期前面已经提到,由指令集合而成的程序放在内存中,CPU从内存中将指令逐条读出并执行。将CPU完整地执行一条指令所花的时间叫做一个指令周期。在后面的章节中可以看到,有的指令很简单,执行时间比较短,而有的指令很复杂,其执行的时间比较长,但都称为一个指令周期,只不过时间长短不同而已。,如果再细分,一个指令周期还可以分成若干个总线周期,即一条指令是由若干个总线周期来完成的。那么什么是总线周期呢?8086CPU通过其系统总线对存储器或接口进行一次访问所需的时间称为一个总线周期。这里主要是指8086CPU将一个字节写入一个内存单元或一个接口地址,或者8086CPU由内存或接口读出一个字节到CPU的时间,均为一个总线周期。在正常情况下,一个总线周期由4个时钟周期组成。时钟周期就是前面提到的加在CPU芯片引脚CLK上的时钟信号的周期。,可以看到,一条指令是由若干个总线周期来完成的,而一个总线周期又由4个(正常情况)时钟周期来实现,从而建立了指令周期、总线周期和时钟周期的关系。2几种基本时序1)写总线周期写总线周期如图2.9所示。,图2.9 8086的写总线周期,这里以8086的最小模式下的信号时序为例为说明问题。在最大模式下,控制信号由总线控制器(8288)来产生,但在概念及基本时间关系上是一样的。读者只要理解了任何一种时序,就足以解决具体的工程问题。首先,以CPU向内存写入一个字节的总线周期为例来简要说明。该总线周期从第一个时钟周期T1开始,在T1时刻CPU从A16A19/S3S6和/S7这5条引线上送出A16A19及,并从AD0AD15这16条线上送出A0A15。,可见,在这个时钟周期里,CPU从它的21条引线上送出了21位地址信号A0A19和(可以将看成一个地址信号),而且时钟T1之后,这21条线上的信号将变为其他信号。因此,CPU在T1周期里送出ALE地址锁存信号,可以用这个信号将A0A19及锁存在锁存器中,使地址信号在整个总线周期里保持不变。在此T1期间,CPU由M/送出高电平并在整个总线周期中一直维持高电平不变,表示该总线周期是一个寻址内存的总线周期。,在时钟周期T2里,CPU将写入内存的数据从AD0AD7上送出来,加到数据总线D0D7上。同时CPU还会送出控制信号,在地址信号A0A19、IO/及的共同作用下,将D0D7上的数据写入相应的内存单元中。写入内存的操作通常是在的后沿(其上升沿)来实现的。这时的地址、数据信号均已稳定,写操作的工作也就更加可靠。,以上就是在最小模式下正常的内存写入过程。若在实际应用中,遇到内存的写入时间要求较长而CPU提供的写入时间却较短(最长也只有4个时钟周期),则在这样短的时间里数据无法可靠地写入。为了解决这个问题,可以利用CPU的READY信号。当CPU的总线周期里的时钟周期T3开始时(下降沿),CPU内部硬件测试READY信号的输入电平。,若此时READY为低电平,则CPU在T3之后不执行T4,而是插入一个等待时钟周期TWAIT。在TWAIT的下降沿CPU继续检测READY输入电平,若它仍然为低电平,则继续插入等待时钟周期TWAIT。就这样一直插到READY为高电平时,则插入停止并执行总线周期T4。这样一来,一个写入内存的总线周期就可以由4个时钟周期延长为更多个时钟周期,以满足低速内存的要求。,2)读总线周期8086CPU读内存或读接口的总线周期如图2.10所示。,图2.10 8086的读总线周期,由图2.10可以看到,读内存

    注意事项

    本文(【教学课件】第2章微型计算机概述.ppt)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开