《8086简介.docx》由会员分享,可在线阅读,更多相关《8086简介.docx(29页珍藏版)》请在三一办公上搜索。
1、8086简介第二章 8086微处理器 微型计算机及微机系统的组成、结构与工作过程,CPU的基本概念与一般结构。 本讲重点 8086微处理器的一般性能特点,内部编程结构的两大组成部分及在信息处理中的相互协调关系,处理器状态字PSW及各个标志位,8086微机系统的存储器组织。 一、8086微处理器 1引言 8086微处理器是Intel公司推出的第三代CPU芯片,它们的内部结构基本相同,都采用16位结构进行操作及存储器寻址,但外部性能有所差异,两种处理器都封装在相同的40脚双列直插组件中。 28086微处理器的一般性能特点: 16位的内部结构,16位双向数据信号线; 20位地址信号线,可寻址1M字节
2、存储单元; 较强的指令系统; 利用第16位的地址总线来进行I/O端口寻址,可寻址64K个I/O端口; 中断功能强,可处理内部软件中断和外部中断,中断源可达256个; 单一的5V电源,单相时钟5MHz。 另外,Intel公司同期推出的Intel8088微处理器一种准16位微处理器,其内部寄存器,内部操作等均按16位处理器设计,与Intel8088微处理器基本上相同,不同的是其对外的数据线只有8位,目的是为了方便地与8位I/O接口芯片相兼容。 38086CPU的编程结构 编程结构:是指从程序员和使用者的角度看到的结构,亦可称为功能结构。 如图21所示是8086CPU的内部功能结构。 从功能上来看,
3、8086CPU可分为两部分,即总线接口部件BIU和执行部件EU。 (1) 执行部件 功能:负责指令的执行。 组成:包括ALU(算术逻辑单元)、通用寄存器组和标志寄存器等,主要进行8位及16位的各种运算。 - 1 - 图2-1 8086/8088CPU内部功能结构图 (2) 总线接口部件 功能:负责与存储器及I/O接口之间的数据传送操作。具体来看,完成取指令送指令队列,配合执行部件的动作,从内存单元或I/O端口取操作数,或者将操作结果送内存单元或者I/O端口。 组成:它由段寄存器、16位指令指针寄存器IP、20位地址加法器和6字节指令队列缓冲器组成。 (3) 8086 BIU的特点 8086的指
4、令队列分别为6/4个字节,在执行指令的同时,可从内存中取出后续的指令代码,放在指令队列中,可以提高CPU的工作效率。 地址加法器用来产生20位物理地址。8086可用20位地址寻址1M字节的内存空间,而CPU内部的寄存器都是16 位,因此需要由一个附加的机构来计算出20位的物理地址,这个机构就是20位的地址加法器。 例如:CS0FE00H,IP0400H,则表示要取指令代码的物理地址为0FE400H。 (4) BIU与EU的动作协调原则: 总线接口部件和执行部件按以下流水线技术原则协调工作,共同完成所要求的信息处理任务: 每当8086的指令队列中有两个空字节,或BIU就会自动把指令取到指令队列中
5、。其取指的顺序是按指令在程序中出现的前后顺序。 每当EU准备执行一条指令时,它会从BIU部件的指令队列前部取出指令的代码,然后用几个时钟周期去执行指令。在执行指令的过程中,如果必须访问存储器或者IO端口,那么EU就会请求BIU,进入总线周期,完成访问内存或者IO端口的操作;如果此时BIU正好处于空闲状态,会立即响应EU的总线请求。如BIU正将某个指令字节取到指- 2 - 令队列中,则BIU将首先完成这个取指令的总线周期,然后再去响应EU发出的访问总线的请求。 当指令队列已满,且EU又没有总线访问请求时,BIU便进入空闲状态。 在执行转移指令、调用指令和返回指令时,由于待执行指令的顺序发生了变化
6、,则指令队列中已经装入的字节被自动消除,BIU会接着往指令队列装入转向的另一程序段中的指令代码。 从上述BIU与EU的动作管理原则中,不难看出,它们两者的工作是不同步的,正是这种既相互独立又相互配合的关系,使得8086可以在执行指令的同时,进行取指令代码的操作,也就是说BIU与EU是一种并行工作方式,改变了以往计算机取指令译码执行指令的串行工作方式,大大提高了工作效率,这正是8086获得成功的原因之一。 (5) 8086 CPU内部寄存器 8086 内部的寄存器可以分为通用寄存器和专用寄存器两大类,专用寄存器包括指针寄存器、变址寄存器等。 通用寄存器 8086 有4个16位的通用寄存器,可以存
7、放16位的操作数,也可分为8个8位的寄存器来使用。其中AX称为累加器,BX称为基址寄存器,CX称为计数寄存器,DX称为数据寄存器,这些寄存器在具体使用上有一定的差别,如表21所示。 指针寄存器 系统中有两个16位的指针寄存器SP和BP,其中SP是堆栈指针寄存器,由它和堆栈段寄存器SS一起来确定堆栈在内存中的位臵; BP是基数指针寄存器,通常用于存放基地址。 变址寄存器 系统中有两个16位的变址寄存器SI和DI,其中SI是源变址寄存器,DI是目的变址寄存器,都用于指令的变址寻址方式。 控制寄存器 IP、标志寄存器是系统中的两个16位控制寄存器,其中IP是指令指针寄存器,用来控制CPU的指令执行顺
8、序,它和代码段寄存器CS一起可以确定当前所要取的指令的内存地址。顺序执行程序时,CPU每取一个指令字节,IP自动加1,指向下一个要读取的字节;当IP单独改变时,会发生段内的程序转移;当CS和IP同时改变时,会产生段间的程序转移。 标志寄存器的内容被称为处理器状态字PSW,用来存放8086 CPU在工作过程中的状态。 - 3 - 寄存器 表2-1 内部寄存器主要用途 用 途 AX AL 字乘法,字除法,字I/O 字节乘,字节除,字节I/O,十进制算术运算 AH BX CX CL DX 字节乘,字节除 转移 串操作,循环次数 变量移位,循环控制 字节乘,字节除,间接I/O 段寄存器 系统中共有4个
9、16位段寄存器,即代码段寄存器CS、数据段寄存器DS、堆栈段寄存器SS和附加段寄存器ES。这些段寄存器的内容与有效的地址偏移量一起,可确定内存的物理地址。通常CS划定并控制程序区,DS和ES控制数据区,SS控制堆栈区。 (6) 处理器状态字PSW 8086 内部标志寄存器的内容,又称为处理器状态字PSW。其中共有9个标志位,可分成两类:一类为状态标志,一类为控制标志。其中状态标志表示前一步操作执行以后,ALU所处的状态,后续操作可以根据这些状态标志进行判断,实现转移;控制标志则可以通过指令人为设臵,用以对某一种特定的功能起控制作用,反映了人们对微机系统工作方式的可控制性。 图22 标志寄存器
10、PSW中各标志位的安排如图22所示,这些标志位的含义如下: 状态标志:6个 CF进位标志位,做加法时最高位出现进位或做减法时最高位出现借位,该位臵1,反之为0。 PF奇偶标志位,当运算结果的低8位中l的个数为偶数时,则该位臵1,反之为0。 AF半进位标志位,做字节加法时,当低四位有向高四位的进位,或在做减法时,低四位有向高四位的借位时,该标志位就臵1。通常用于对BCD算术运算结果的调整。 ZF零标志位,运算结果为0时,该标志位臵1,否则清0。 SF符号标志位,当运算结果的最高位为1,该标志位臵1,否则清0。即与运算结果的最高位相同。 OF溢出标志位,OF溢出的判断方法如下: 加法运算: 若两个
11、加数的最高位为0,而和的最高位为1,则产生上溢出; 若两个加数的最高位为1,而和的最高位为0,则产生下溢出; 两个加数的最高位不相同时,不可能产生溢出。 减法运算: 若被减数的最高位为0,减数的最高位为1,而差的最高位为1,则产生上溢出; 若被减数的最高位为1,减数的最高位为0,而差的最高位为0,则产生下溢出; 被减数及减数的最高位相同时,不可能产生溢出。 如果所进行的运算是带符号数的运算,则溢出标志恰好能够反映运算结果是否超出了8位或16位带符号数所能表达的范围,即字节运算大于十127或小于128时,字运算大于十32767或小于32768时,该位臵1,反之为0。 - 4 - 0101 010
12、0 1001 0100 0101 1001 0011 0110 1010 1001 1010 0011 CF0、AF1、PF1、ZF0、SF1、OF1 一般来讲,不是每次运算后所有的标志都改变,只是在某些操作之后,才对其中某个标志进行检查。 控制标志:3个 TF陷阱标志位(单步标志位、跟踪标志)。当该位臵1时,将使8086/8088进入单步工作方式,通常用于程序的调试。 IF中断允许标志位,若该位臵1,则处理器可以响应可屏蔽中断,否则就不能响应可屏蔽中断。 DF方向标志位,若该位臵1,则串操作指令的地址修改为自动减量方向,反之,为自动增量方向。 二、存储器组织 1. 存储容量 8086有20根
13、地址总线,因此,它可以直接寻址的存储器单元数为220=1Mbyte 2. 物理地址 8086可直接寻址1Mbyte的存储空间,其地址区域为00000HFFFFFH,与存储单元一一对应的20位地址,我们称之为存储单元的物理地址。 3. 存储器的分段及段地址 由于CPU内部的寄存器都是16位的,为了能够提供20位的物理地址,系统中采用了存储器分段的方法。规定存储器的一个段为64KB,由段寄存器来确定存储单元的段地址,由指令提供该单元相对于相应段起始地址的16位偏移量。 这样,系统的整个存储空间可分为16个互不重叠的逻辑段,如图2-3所示。 存储器的每个段的容量为64KB,并允许在整个存储空间内浮动
14、,即段与段之间可以部分重叠、完全重叠、连续排列,非常灵活,如图2-4所示。 图2-3 存储空间段结构 图2-4 分段逻辑结构 - 5 - 4. 偏移地址 偏移地址是某存储单元相对其所在段起始位臵的偏移字节数,或简称偏移量。它是一个16位的地址,根据指令的不同,它可以来自于CPU中不同的16位寄存器。 5. 物理地址的形成 物理地址是由段地址与偏移地址共同决定的,段地址来自于段寄存器,是十六位地址,由段地址及偏移地址计算物理地址的表达式如下: 物理地址=段地址16+偏移地址 例如:系统启动后,指令的物理地址由CS的内容与IP的内容共同决定,由于系统启动的CS=0FFFFH,IP=0000H,所以
15、初始指令的物理地址为0FFFF0H,我们可以在0FFFF0H单元开始的几个单元中,固化一条无条件转移指令的代码,即转移到系统初始化程序部分。 6. 存储器分段组织带来存储器管理的新特点 首先,在程序代码量、数据量不是太大的情况下,可使它们处于同一段内,即使它们在64Kbyte的范围内,这样可以减少指令的长度,提高指令运行的速度; 其次,内存分段为程序的浮动分配创造了条件; 第三,物理地址与形式地址并不是一一对应的,举例:6832H:1280H,物理地址为695A0H。 第四,各个分段之间可以重叠 7. 特殊的内存区域 8088/8086系统中,有些内存区域的作用是固定的,用户不能随便使用,如:
16、中断矢量区:00000H003FFH共1K字节,用以存放256种中断类型的 中断矢量,每个中断矢量占用4个字节,共2564=1024=1K 显示缓冲区:B0000HB0F9FH约4000字节,是单色显示器 的显示缓冲区,存放文本方式下,所显示字符的ASCII码及属性码;B8000HBBF3FH约16K字节,是彩色显示器的显示缓冲区,存放图形方式下,屏幕显示象素的代码。 启动区:FFFF0HFFFFFH共16个单元,用以存放一条无条件转移指令的代码,转移到系统的初始化部分。 习题与思考 18086/8088 CPU由哪两部分组成?它们的主要功能各是什么?它们之间是如何协调工作的? 28086/8
17、088 CPU中有哪些寄存器?各有什么用途?标志寄存器F有哪些标志位?各在什么情况下臵位? 38086/8088系统中储存器的逻辑地址和物理地址之间有什么关系?表示的范围各为多少? 4已知当前数据段位于储存器的A1000H到B0FFFH范围内,问DS=? 5某程序数据段中存有两个数据字1234H和5A6BH,若已知DS=5AA0H,它们的偏移地址分别为245AH和3245H,试画出它们在储存器中的存放情况。 - 6 - 2.2 8086微处理器 8086微型计算机的组成、结构及微机系统的工作过程,微机系统的存储器组织及相关概念。 8086CPU的两种工作模式,8086 CPU的外部结构,即引脚
18、信号及其功能。 18086CPU的两种工作模式 为了适应各种使用场合,在设计8086CPU芯片时,就考虑了其应能够使它工作在两种模式下,即最小模式与最大模式。 所谓最小模式,就是系统中只有一个8086微处理器,在这种情况下,所有的总线控制信号,都是直接由8086CPU产生的,系统中的总线控制逻辑电路被减到最少,该模式适用于规模较小的微机应用系统。 最大模式是相对于最小模式而言的,最大模式用在中、大规模的微机应用系统中,在最大模式下,系统中至少包含两个微处理器,其中一个为主处理器,即8086/8086CPU,其它的微处理器称之为协处理器,它们是协助主处理器工作的。 与8086CPU配合工作的协处
19、理器有两类,一类是数值协处理器8087另一类是输入/输出协处理器8089。 8087是一种专用于数值运算的协处理器,它能实现多种类型的数值运算,如高精度的整型和浮点型数值运算,超越函数的计算等,这些运算若用软件的方法来实现,将耗费大量的机器时间。换句话说,引入了8087协处理器,就是把软件功能硬件化,可以大大提高主处理器的运行速度。 8089协处理器,在原理上有点象带有两个DMA通道的处理器,它有一套专门用于输入/输出操作的指令系统,但是8089又和DMA控制器不同,它可以直接为输入/输出设备服务,使主处理器不再承担这类工作。所以,在系统中增加8089协处理器之后,会明显提高主处理器的效率,尤
20、其是在输入/输出操作比较频繁的系统中。 28086 CPU的引脚信号和功能 (1).引言 如图2-5所示,是8088CPU的外部结构,即引脚信号图,注意:在不同的工作模式下,其中一部分引脚的名称功能可能不一致。 8088/8086CPU芯片都是双列直插式集成电路芯片,都有40个引脚,其中32个引脚在两种工作模式下的名称和功能是相同的,还有8个引脚在不同的工作模式下,具有不同的名称和功能。下面,我们分别来介绍这些引脚的输入/输出信号及其功能。 - 7 - 图2-5 8086/8088CPU引脚功能 (2).两种模式下,名称和功能相同的32个引脚 VCC、GND:电源、接地引脚(3),8088/8
21、086CPU采用单一的+5V电源,但有两个接地引脚。 AD15AD0:地址/数据复用信号输入/输出引脚(16),分时输出 低16位地址信号及进行数据信号的输入/输出。 A19/s6A15/s3:地址/状态复用信号输出引脚(4),分时输出地址的高4位及状态信息,其中s6为0用以指示8086/8088CPU当前与总线连通;s5为1表明8086/8088CPU可以响应可屏蔽中断;s4、s3共有四个组态,用以指明当前使用的段寄存器,00ES,01SS,10CS,11DS。 NMI(Non-Maskable Interrupt)、INTR:中断请求信号输入引脚(2),引入中断源向CPU提出的中断请求信号
22、,高电平有效,前者为非屏蔽中断请求,后者为可屏蔽中断请求信号。 RD:读控制输出信号引脚(1),低电平有效,用以指明要执行一个对内存单元或I/O端口的读操作,具体是读内存单元,还是读I/O端口,取决于M/IO控制信号。 CLK/(Clock):时钟信号输入引脚(1),时钟信号的方波信号,占空比约为33%,即1/3周期为高电平,2/3周期为底电平,8088/8088的时钟频率为4.77MHz,即从该引脚输入的时钟信号的频率为4.77MHz。 Reset(Reset):复位信号输入引脚(1),高电平有效。8088/8086CPU要求复位信号至少维持4个时钟周期才能起到复位的效果,复位信号输入之后,
23、CPU结束当前操作,并对处理器的标志寄存器、IP、DS、SS、ES寄存器及指令队列进行清零操作,而将CS设臵为0FFFFH。 READY:“准备好”状态信号输入引脚(1),高电平有效,“Ready”输入引脚接收来自于内存单元或I/O端口向CPU发来的“准备好”状态信号,表明内存单元或I/O端口已经准备好进行读写操作。该信号是协调CPU与内存单元或I/O端口之间进行信息传- 8 - 送的联络信号。 TEST (Test):测试信号输入引脚(1),低电平有效,TEST信号与WAIT指令结合起来使用,CPU执行WAIT指令后,处于等待状态,当TEST引脚输入低电平时,系统脱离等待状态,继续执行被暂停
24、执行的指令。 MN/MX最小/最大模式设臵信号输入引脚(1),该输入引脚电平的高、低决定了CPU工作在最小模式还是最大模式,当该引脚接+5V时,CPU工作于最小模式下,当该引脚接地时,CPU工作于最大模式下。 BHE/S7:高8位数据允许/状态复用信号输出引脚(1),输出。分时输出BHE有效信号,表示高8为数据线D15D8上的数据有效和S7 状态信号,但S7未定义任何实际意义。 利用BHE信号和AD0信号,可知系统当前的操作类型,具体规定见表2-2所示。 表2-2 BHE和A0的代码组合和对应的操作 BHE 0 0 1 1 0 1 A0 0 1 0 1 1 0 操作 从偶地址单元开始读/写一个
25、字 从奇地址单元或端口读/写一个字节 从偶地址单元或端口读/写一个字节 无效 从奇地址开始读/写一个字(在第一个总线周期将低8位数据送到AD15 AD8,下一个周期将高8位数据送到AD7 AD0 ) 所用数据引脚 AD15 AD0 AD15 AD8 AD7 AD0 - AD15 AD0 在8088系统中,该引脚为SS0,用来与DT/R、M/IO一起决定8088芯片当前总线周期的读写操作,如下表所示。 M/IO DT/R SS0 性能 1 0 0 中断响应 1 0 1 读I/O端口 1 1 0 写I/O端口 1 1 1 暂停 0 0 0 取指令操作码 0 0 1 读存储器 0 1 0 写存储器
26、0 1 1 无源 (3).最小模式下的24-31引脚 当8088/8086CPU的MN/MX引脚固定接+5V时,CPU处于最小模式下,这时候剩余的2431共8个引脚的名称及功能如下: INTA中断响应信号输出引脚(1) 低电平有效,该引脚是CPU响应中断请求后,向中断源发出的认可信号,用以通知中断源,以便提供中断类型码,该信号为两个连续的负脉冲。 - 9 - ALE:地址锁存允许输出信号引脚(1) 高电平有效,CPU通过该引脚向地址锁存器8282/8283发出地址锁存允许信号,把当前地址/数据复用总线上输出的是地址信息,锁存到地址锁存器8282/8283中去。注意:ALE信号不能被浮空。 DE
27、N:数据允许输出信号引脚 低电平有效,为总线收发器8286提供一个控制信号,表示CPU当前准备发送或接收一项数据。 DT/R:数据收发控制信号输出引脚(1) CPU通过该引脚发出控制数据传送方向的控制信号,在使用8286/8287作为数据总线收发器时,DT/R信号用以控制数据传送的方向,当该信号为高电平时,表示数据由CPU经总线收发器8286/8287输出,否则,数据传送方向相反。 IO/M: 存储器/I/O端口选择信号输出引脚(1) 这是CPU区分进行存储器访问还是I/O访问的输出控制信号。当该引脚输出高电平 时,表明CPU要进行I/O端口的读写操作,低位地址总线上出现的是I/O端口的地址;
28、当该引脚输出低电平时,表明CPU要进行存储器的读写操作,地址总线上出现的是访问存储器的地址。 WR(Write): 写控制信号输出引脚(1) 低电平有效,与IO/M配合实现对存储单元、I/O端口所进行的写操作控制。 HOLD(Hold Request): 总线保持请求信号输入引脚(1) 高电平有效。这是系统中的其它总线部件向CPU发来的总线请求信号输入引脚。 HLDA:总线保持响应信号输出引脚 高电平有效,表示CPU认可其他总线部件提出的总线占用请求,准备让出总线控制权。 (4).最大模式下的24-31引脚 当8088/8086CPU的MN/MX引脚固定接地时,CPU处于最大模式下,这时 候剩
29、余的2431共8个引脚的名称及功能如下: QS1、QS0:指令队列状态信号输出引脚(2) 这两个信号的组合给出了前一个T状态中指令队列的状态,以便于外部8088/8086CPU内部指令队列的动作跟踪,如下表所示: QS1 0 0 1 1 QS0 0 1 0 1 无操作 性 能 从指令队列的第一个字节取走代码 队列为空 除第一个字节外,还取走了后续字节中的代码 S2、S1、S0:总线周期状态信号输出引脚(3) 低电平的信号输出端,这些信号组合起来,可以指出当前总线周期中,所进行数据传输过程的类型,总线控制器8288利用这些信号来产生对存储单元、I/O端口的控制信号。S2、S1、S0与具体物理过程
30、之间的对应关系,如表2-2所示。 - 10 - 这里对无源状态作一说明:从表1-6中可以看出,每一种S2S1S0的组合都对应一个具体的总线操作,除111外,其余都称为有源状态。也就是说,在有源状态中,S2S1S0至少有一个信号为0,当S2S1S0=1,也就是一个总线操作即将结束,另一个总线周期还未开始时,称为无源状态,很显然,这时S2S1S0中任一信号的改变,都意味着一个新的总线周期的开始。 LOCK (Lock):总线封锁输出信号引脚(1) 表2-2 S0S2的状态编码 S0 S1 S2 性能 中断响应 读I/O端口 写I/O端口 暂停 取指 读存储器 写存储器 无作用 1 1 1 1 0
31、0 0 0 0 0 1 1 0 0 1 1 0 1 0 1 0 1 0 1 低电平有效,当该引脚输出低电平时,系统中其它总线部件就不能占用系统总线。 LOCK信号是由指令前缀LOCK产生的,在LOCK前缀后面的一条指令执行完毕之后,便撤消LOCK信号。此外,在8088/8086的2个中断响应脉冲之间,LOCK信号也自动变为有效的低电平,以防止其它总线部件在中断响应过程中,占有总线而使一个完整的中断响应过程被中断。 RQ/GT1、RQ/GT0(Request/Grant):总线请求信号输入/总线允许信号输出引脚(2) 这两个信号端可供CPU以外的两个处理器,用来发出使用总线的请求信号和接收CPU
32、对总线请求信号的应答。这两个引脚都是双向的,请求与应答信号在同一引脚上分时传输,方向相反。其中RQ/GT1比RQ/GT0的优先级高。 (5).相关问题的说明 8088/8086的数据线与地址线、状态线是分时复用的,即在某一时刻,总线上出现的是输出地址信息,在另一时刻,总线上是所需读、写的数据信息,或状态信息。 除了个别引脚外,8088/8086的控制信号引脚的定义是一致的,有差别的是,8088的第18脚为IO/M,8086为IO/M,主要是为了使前者能与8位微处理器8080/8085 相兼容的缘故。 8086为BHE/S7,这是因为8086 有16根数据线,可以用高、低8位总线分别进行一BHE
33、 正是为了指明这几类操作而设臵的,个字节的传送,也可以同时进行两个字节的传送,而8088的数据线只有8根,就不存在这一要求,因此就不需要BHE引脚了。 Reset引脚是复位信号输入端,系统启动、或在系统运行过程中,CPU在接收到Reset信号后,会使系统复位。复位后,CPU处于如下状态: CPU的标志寄存器、指令指针寄存器IP、段寄存器DS、ES、SS和指令队列均被清零,码段寄存器CS被臵为FFFFH,CPU将从0FFFF0H处开始执行指令。 CPU与内存、I/O端口之间在时间上的匹配主要靠“READY”信号。 RD信号与IO/M配合使用,指明从内存或者I/O端口读信息 高4位地址线与状态线分
34、时复用,在T1状态,输出地址信息,在其余状态,输出状态信息。 - 11 - (6).8086 CPU的引脚分类 8086 CPU的40个引脚可以分成下列几大类: 数据/地址复用线、地址线、地址/状态复用线AD0AD7 、AD8AD15、) A16A19/S3S6; 常规信号GND、Vcc、CLK; 常用信号ALE、M/IO、RD、WR; 中断INTR、NMI、INTA; MN/MX、READY、RESET; HOLD、HLDA; 、DENBHE/S7SS0、DT/R、TEST。 3两种模式下系统的典型配置 我们除了要了解CPU的内、外部结构之外,还要进一步了解各模式下,系统的典型配臵情况,即除
35、了CPU之外,还需要哪些芯片来构成来一个最基本的应用系统。 (1)最小模式 如图2-5所示,是8088/8086在最小模式下的典型配臵,它具有 以下几个方面的特点。 MN/MX端接+5V,决定了CPU的工作模式 有一片8284A,作为时钟信号发生器 有一片8282或74LS273,用来作为地址信号的锁存器 当系统中所连的存储器和外设端口较多时,需要增加数据总线的驱动能力,这时,需用2片8286/8287作为总线收发器。 图2-5 最小模式下的系统典型配置 (2)最大模式 如图2-6所示,是8088/8086在最大模式下的典型配臵, 可以看出,最大模式和最小模式在配臵上的主要差别在于在最大模式下
36、,要用8288总线控制器来对CPU发出的控制信号进行变换和组合,以得到对存储器或I/O 端口的读/写信号和对锁存器8282及总线收发器8286的控制信号。 最大模式系统中,需要用总线控制器来变换与组合控制信号的原因在于:在最大模式的系统中,一般包含2个或多个处理器,这样就要解决主处理器和协处理器之间的协调工作,和对系统总线的共享控制问题,8288总线控制器就起了这个作用。 - 12 - 在最大模式的系统中,一般还有中断优先级管理部件。8259A用以对多个中断源进行中断优先级的管理,但如果中断源不多,也可以不用中断优先级管理部件。 图2-6 最大模式下的系统典型配置 习题与思考 18086/80
37、88系统中为什么一定要有地址锁存器?需要锁存哪些信息? 2若8086CPU工作于最小模式,试指出当CPU完成将AH的内容送到物理地址为91001H的存储单元操作时,以下哪些信号应为低电平:M/IO、RD、WR、BHE/S7、DT/R。若CPU完成的是将物理地址91000H单元的内容送到AL中,则上述哪些信号应为低电平。 3什么是引脚的分时复用?请说出8086/8088CPU有哪些引脚是分时复用引脚?其要解决的问题是什么? 4试说明8086/8088工作在最大和最小模式下系统基本配臵的差异。 2.3 典型时序分析 回顾:8086 CPU的内、外部结构,两种工作模式,微型计算机系统的工作过程。 本
38、讲重点 与微机系统工作过程定时相关的三种周期,时序的基本概念,研究时序的意义,两种工作模式下的典型时间序列分析。 一、相关的基本概念 1. 什么是时序 - 13 - 时序是计算机操作运行的时间顺序。 2. 为什么要研究时序 (1) 可以进一步了解在微机系统的工作过程中,CPU各引脚上信号之间的相对时间关系。由于微处理器内部电路、部件的工作情况,用户是看不到的,通过检测CPU引脚信号线上,各信号之间的相对时间关系,是判断系统工作是否正常的一种重要途径; (2) 可以深入了解指令的执行过程; (3) 可以使我们在程序设计时,选择合适的指令或指令序列,以尽量缩短程序代码的长度及程序的运行时间。因为对
39、于实现相同的功能,可以采用不同的指令或指令序列,而这些指令或指令序列的字节数及执行时间有可能不相同的。 (4) 对于学习各功能部件与系统总线的连接及硬件系统的调试,都十分有意义,因为CPU与存储器、I/O端口协调工作时,存在一个时序上的配合问题。 (5) 才能更好地处理微机用于过程控制及解决实时控制的题 3. 指令周期、总线周期及时钟周期 微机系统的工作,必须严格按照一定的时间关系来进行,CPU定时所用的周期有三种,即指令周期、总线周期和时钟周期。 (1).指令周期 一条指令从其代码被从内存单元中取出到其所规定的操作执行完毕,所用的时间,称为相应指令的指令周期。由于指令的类型、功能不同,因此,
40、不同指令所要完成的操作也不同,相应地,其所需的时间也不相同。也就是说,指令周期的长度因指令的不同而不同。 (2).总线周期 我们把CPU通过总线与内存或I/O端口之间,进行一个字节数据交换所进行的操作,称为一次总线操作,相应于某个总线操作的时间即为总线周期。虽然,每条指令的功能不同,所需要进行的操作也不同,指令周期的长度也必不相同。但是,我们可以对不同指令所需进行的操作进行分解,它们又都是由一些基本的操作组合而成的。如存储器的读/写操作、I/O端口的读/写操作、中断响应等,这些基本的操作都要通过系统总线实现对内存或I/O端口的访问的。不同的指令所要完成的操作,是由一系列的总线操作组合而成的,而
41、线操作的数量及排列顺序因指令的不同而不同。 8088的总线操作,就是8088CPU利用总线与内存及I/O端口进行信息交换的过程,与这些过程相对应的总线上的信号变化的相对时间关系,就是相应总线操作的时序。 (3).时钟周期 时钟周期是微机系统工作的最小时间单元,它取决于系统的主频率,系统完成任何操作所需要的时间,均是时钟周期的整数倍。时钟周期又称为T状态。 时钟周期是基本定时脉冲的两个沿之间的时间间隔,而基本定时脉冲是由外部振荡器产生的,通过CPU的CLK输入端输入,基本定时脉冲的频率,我们称之为系统的主频率。例如8088CPU的主频率是5MHz,其时钟周期为200ns。 - 14 - 一个基本
42、的总线周期由4个T状态组成,我们分别称为T1T44个状态,在每个T状态下,CPU完成不同的动作。 4. 8086/8088微机系统的主要操作 8086/8088微机系统,能够完成的操作有下列几种主要类型: 系统的复位与启动操作; 暂停操作; 总线操作; 中断操作; 最小模式下的总线保持; 最大模式下的总线请求/允许。 二、 典型的8088时序分析 1引言 指令所执行的操作,可以分为内部操作和外部操作。不同的指令其内、外部操作是不相同的,但这些操作可以分解为一个个总线操作。即总线操作的不同组合,就构成了不同指令的不同操作,而总线操作的类型是有限的,我们如果能够明确不同种类总线操作的时序关系,且可
43、以根据不同指令的功能,把它们分解为不同总线操作的组合,那么,任何指令的时序关系,我们就都可以知道了。 2最小模式下的典型时序 CPU为了与存贮器或I/O端口进行一个字节的数据交换,需要执行一次总线操作,按数据传输的方向来分,可将总线操作分为读操作和写操作两种类型; 按照读/写的不同对象,总线操作又可分为存贮器读/写与I/O读/写操作,下面我们就最小模式下的总线读/写操作时序,来进行具体分析。 (1). 最小模式下的总线读操作时序 时序如图图115所示,一个最基本的读周期包含有4个状态,即T1、T2、T3、T4,必要时可插入1个或几个Tw。 T1状态 M/IO有效,用来指出本次读周期是存贮器读还
44、是I/O读,它一直保持到T4有效。 地址线信号有效,高4位通过地址/状态线送出,低16位通过地址/数据线送出,用来指出操作对象的地址,即存贮器单元地址或I/O端口地址。 ALE有效,在最小模式的系统配臵中我们讲过,地址信号通过地址锁存器8282锁存,ALE即为8282的锁存信号,下降沿有效。 BHE有效,用来表示高8位数据总线上的信息有效,现在通过A15A8传送的是有效地址信息,BHE常作为奇地址存贮体的选通信号,因为奇地址存贮体中的信息总是通过高8位数据线来传输,而偶地址体的选通则用A0。 当系统中配有总线驱动器时,T1使DT/R变低,用来表示本周期为读周期,并通知总- 15 - 接收线驱动
45、器接收数据 T2状态 高四位地址/状态线送出状态信息,S3S6。 低16位地址/数据线浮空,为下面传送数据准备。 BHE/S7引脚成为S7。 RD有效,表示要对存贮器/I/O端口进行读。 接收DEN有效,使得总线收发器可以传输数据 T3状态 从存贮器/I/O端口读出的数据送上数据总线。 Tw状态 若存贮器或外设速度较慢,不能及时送上数据的话,则通过READY线通知CPU,CPU在T3的前沿检测READY,若发现READY0,则在T3结束后自动插入1个或几个Tw,并在每个Tw的前沿处检测READY,等到READY变高后,则自动脱离Tw进入T4。 T4状态 在T4与T3的交界处,采集数据,使各控制
46、及状态线进入无效。 (2). 最小模式下的总线写操作时序 时序如图27所示,最基本的总线写周期也包括四个状态T1T4必要时插入Tw。 - 16 - 图27 总线写周期时序 T1状态 基本上同读周期,只有此时DT/R为高不是低。 T2状态 与读周期有两点不同: RD变成WR; A15A0不是浮空,而是发出要写入存贮器/I/O端口的数据。 T3状态 Tw状态 T4状态 T3、Tw、T4三个状态同读周期。 已完成CPU存贮器/I/O端口的数据传送,使数据线上的数据无效,同时,使各控制与状态信号无效。 (3).中断响应周期(对可屏蔽中断) 波形图如图28所示,由两个连续的总线周期所组成。 图28 中断响应周期时序 说明: 要求INTR信号是一个高电平信号,并且维持两个T,因为CPU在一条指令的最后一个T采样INTR,进入中断响应后,它在第一个周期的T1仍需采样INTR。 在最小模式下,中断