您好,欢迎访问三七文档
当前位置:首页 > 电子/通信 > 综合/其它 > 005第5章8086的总线操作和时序
第章8086系统时序和微机总线本章内容最小组态下的基本引脚最小组态下的总线时序最小组态下的总线形成5.1概述时钟周期(T状态)计算机是一个复杂的时序逻辑电路,时序逻辑电路都有“时钟”信号。计算机的“时钟”是由振荡源产生的、幅度和周期不变的节拍脉冲,每个脉冲周期称为时钟周期,又称为T状态。计算机是在时钟脉冲的统一控制下,一个节拍一个节拍地工作的。总线周期是指CPU通过总线操作与外部(存储器或I/O端口)进行一次数据交换的过程。根据总线操作功能的不同,有多种不同的总线周期。如存储器读周期、存储器写周期、I/O读周期、I/O写周期等。5.1.1时钟周期(T状态)、总线周期和指令周期8086的基本总线周期需要4个时钟周期4个时钟周期编号为T1、T2、T3和T4总线周期中的时钟周期也被称作“T状态”时钟周期的时间长度就是时钟频率的倒数当需要延长总线周期时插入等待状态TwCPU进行内部操作,没有对外操作时,其引脚就处于空闲状态Ti指令周期每条指令的执行包括取指令、译码和执行。执行一条指令所需要的时间称为指令周期。指令指令周期是由1个或多个总线周期组合而成。或者说,指令周期可以被划分为若干个总线周期。8086中的指令码最短的只需要一个字节,多的有6个字节。多字节指令,取指(存储器读)就需要多个总线周期;在指令的执行阶段,由于各种不同寻址方式,需要的总线周期个数也各不相同。因此8086的指令周期是不等长的。对于8086CPU来说,在EU执行指令的时候,BIU可以取下一条指令。由于EU和BIU可以并行工作,8086指令的最短执行时间可以是两个时钟周期,一般的加、减、比较、逻辑操作是几十个时钟周期,最长的为16位乘除法约要200个时钟周期。演示5.2处理器总线外部特性表现在其引脚信号上,学习时请特别关注以下几个方面:指引脚信号的定义、作用;通常采用英文单词或其缩写表示信号从芯片向外输出,还是从外部输入芯片,或者是双向的起作用的逻辑电平高、低电平有效上升、下降边沿有效输出正常的低电平、高电平外,还可以输出高阻的第三态⑶有效电平⑷三态能力⑵信号的流向⑴引脚的功能5.2.18086的两种组态当8086CPU与存储器和外设构成一个计算机的硬件系统时,根据所连的存储器和外设的规模,8086可以有两种不同的组态。两种组态构成两种不同规模的应用系统最小组态模式构成小规模的应用系统8086本身提供所有的系统总线信号最大组态模式构成较大规模的应用系统,例如可以接入数值协处理器80878086和总线控制器8288共同形成系统总线信号两种组态利用MN/MX*引脚区别MN/MX*接高电平为最小组态模式MN/MX*接低电平为最大组态模式两种组态下的内部操作并没有区别IBMPC/XT采用最大组态我们以最小组态展开基本原理通常在信号名称加上划线(如:MX)或星号(如:MX*)表示低电平有效8086的引脚图12345678910111213141516171819204039383736353433323130292827262524232221GNDAD14AD13AD12AD11AD10AD9AD8AD7AD6AD5AD4AD3AD2AD1AD0NMIINTRCLKGNDVCCA15A16/S3A17/S4A18/S5A19/S6BHE*/S7MN/MX*RD*HOLD(RQ)*/GT0*)HLDA(RQ*/GT1*)WR*(LOCK*)M/IO*(S2*)DT/R*(S1*)DEN*(S0*)ALE(QS0)INTA(QS1)TEST*READYRESET80865.2.2最小组态的引脚信号分类学习这40个引脚(总线)信号1.数据和地址引脚2.读写控制引脚3.中断请求和响应引脚4.总线请求和响应引脚5.其它引脚1.数据和地址引脚AD15~AD0(Address/Data)(39,2~16)地址/数据分时复用引脚,双向、三态作为复用引脚,在总线周期的T1状态作为低16位地址线。T2、T3、TW状态,作为数据总线。在DMA方式时,这些引线被置为高阻状态,置为高阻状态。A19/S6~A16/S3(Address/Status)(35~38)地址/状态分时复用引脚,输出、三态。在总线周期的T1状态输出高4位地址A19~A16。由于8086/8088对I/0端口的寻址仅用低16位地址线,故A19~A16作为地址总线使用时只能对存储器寻址。其他时间输出状态信号S6~S3,作用为:S6:始终为低电平。S5:输出,指明标志寄存器中中断允许标志IF的当前状态。S4、S3:编码,指明当前正在使用的段寄存器。S4S3当前正在使用的段寄存器名00ES01SS10CS或未用11DS2.读写控制引脚ALE(AddressLatchEnable)(25)地址锁存允许,输出、高电平有效,是微处理器提供给地址锁存器8282/8283的控制信号在总线周期的T1状态ALE引脚高电平有效,表示当前在地址/数据复用总线上输出的是地址信息,即AD15~AD0和A19/S6~A16/S3正在传送地址信息,地址锁存器把ALE作为锁存信号,对地址进行锁存。由于地址信息在这些复用引脚上出现的时间很短暂,所以系统可以利用ALE引脚将地址锁存起来注意:ALE没有高阻状态M/IO*(Memory/InputandOutput)(28)I/O或存储器访问,输出、三态该引脚输出低电平时,表示CPU将访问I/O端口,这时地址总线A15~A0提供16位I/O口地址该引脚输出高电平时,表示CPU将访问存储器,这时地址总线A19~A0提供20位存储器地址DMA方式:高阻状态WR*(Write)(29)写控制,输出、三态、低电平有效T2、T3、TW期间有效时,表示CPU正在写出数据给存储器或I/O端口RD*(Read)(32)读控制,输出、三态、低电平有效T2、T3、TW期间有效时,表示CPU正在从存储器或I/O端口读入数据DMA方式:高阻状态M/IO*、WR*和RD*是最基本的控制信号组合后,控制4种基本的总线周期总线周期M/IO*WR*RD*存储器读高高低存储器写高低高I/O读低高低I/O写低低高READY(22)存储器或I/O口就绪,输入、高电平有效来自所访问的存储器或I/O设备,有效时表示设备准备就绪,可进行一次数据传输总线操作周期中(T3状态),CPU会测试该引脚如果测到高有效,CPU直接进入下一步如果测到无效,CPU将插入等待周期等待周期中仍然要监测READY信号,确定是否继续插入等待周期DEN*(DataEnable)(26)数据允许,输出、三态、低电平有效。有效时表示CPU准备好接收和发送数据。可以用DEN*为收发器(8286/8287)提供一选通信号。DT/R*(DataTransmit/Receive)(27)数据发送/接收,输出、三态。表明当前总线上数据的流向。高电平时数据自CPU输出(发送)低电平时数据输入CPU(接收)可用DT/R*信号来控制数据总线上的双向收发器的数据传送方向。DMA方式:高阻状态BHE*/S7(BusHighEnable/Status)(34)高8位数据总线允许/状态,输出,三态,分时复用。T1状态:输出BHE*信号,表示高8位数据线上的数据是否有效。其他状态:作为S7输出,是一个未定义的状态信号。BHE*和低位地址A0配合表示不同的数据传送操作:读/写操作BHE*A0所用数据引脚从偶地址开始的一个字00AD15~AD0偶地址的一个字节10AD7~AD0奇地址的一个字节01AD15~AD8从奇地址开始的一个字(两个总线周期)01AD15~AD8(低8位数据)10AD7~AD0(高8位数据)3.中断请求和响应引脚INTR(InterruptRequest)(18)可屏蔽中断请求,输入、高电平有效。有效时,表示请求设备向CPU申请可屏蔽中断,该中断请求是否响应受控于IF(中断允许标志),可以被屏蔽掉。CPU在执行每条指令的最后一个时钟周期对INTR信号进行采样,若IF=1,且又接收到INTR信号,则CPU在结束当前指令后,响应中断请求,进入一中断处理子程序。INTA*(InterruptAcknowledge)(24)可屏蔽中断响应,输出、低电平有效有效时,表示来自INTR引脚的中断请求已被CPU响应,CPU进入中断响应周期NMI(Non-MaskableInterrupt)(17)不可屏蔽中断请求,输入、上升沿有效有效表示外界向CPU申请不可屏蔽中断该中断请求不能被CPU屏蔽,所以优先级别高于INTR(可屏蔽中断)主机与外设进行数据交换通常采用可屏蔽中断不可屏蔽中断通常用于处理掉电等系统故障4.总线请求和响应引脚HOLD(31)总线保持(即总线请求),输入高电平有效有效时,表示总线请求设备向CPU申请占有总线该信号从有效回到无效时,表示总线请求设备对总线的使用已经结束,通知CPU收回对总线的控制权HLDA(HOLDAcknowledge)(30)总线保持响应(总线响应),输出、高电平有效有效表示CPU已响应总线请求并已将总线释放此时CPU的地址总线、数据总线及具有三态输出能力的控制总线将全面呈现高阻,使总线请求设备可以顺利接管总线待到总线请求信号HOLD无效,总线响应信号HLDA也转为无效,CPU重新获得总线控制权5.其它引脚RESET(21)复位请求,输入、高电平有效该信号有效,将使CPU回到其初始状态;当再度返回无效时,CPU将重新开始工作复位时要求该信号至少持续四个时钟周期,若是初次加电,则需要保持至少50µS8086复位后CS=FFFFH、IP=0000H,所以程序入口在物理地址FFFF0H。其他寄存器清0。CLK(Clock)(19)时钟输入系统通过该引脚给CPU提供内部定时信号8086的标准工作时钟为5MHzIBMPC/XT机的8086采用了4.77MHz的时钟,其时钟周期约为210nsVcc(40)电源输入,向CPU提供+5V电源GND(1、20)接地,向CPU提供参考地电平MN/MX*(Minimum/Maximum)(33)组态选择,输入接高电平时,8086引脚工作在最小组态;反之,8086工作在最大组态TEST*(23)测试,输入、低电平有效与WAIT指令配合使用,当CPU执行WAIT指令时,CPU处于等待状态,并且每隔5个T状态对TEST信号测试一次,如果有效,则结束等待状态,继续执行WAIT指令后面的指令。可以使CPU与外部硬件同步。如使用协处理器8087时,通过该引脚和WAIT指令,可使8086与8087的操作保持同步“引脚”小结CPU引脚是系统总线的基本信号可以分成三类信号16位数据线:D0~D1520位地址线:A0~A19控制线:ALE、IO/M*、WR*、RD*、READYINTR、INTA*、NMI,HOLD、HLDARESET、CLK、Vcc、GND5.38086的总线时序时序(Timing)是指信号高低电平(有效或无效)变化及相互间的时间顺序关系CPU时序决定系统各部件间的同步和定时总线时序描述CPU引脚如何实现总线操作什么是总线操作?5.3.1基本概念总线操作是指CPU通过总线对外的各种操作8086的总线操作主要有:存储器读、I/O读操作存储器写、I/O写操作中断响应操作总线请求及响应操作CPU正在进行内部操作、并不进行实际对外操作的空闲状态Ti描述总线操作的微处理器时序有三级指令周期→总线周期→时钟周期任何指令的取指阶段都需要存储器读总线周期,读取的内容是指令代码任何一条以存储单元为源操作数的指令都将引起存储器读总线周期,任何一条以存储单元为目的操作数的指令都将引起存储器写总线周期只有执行IN指令才出现I/O读总线周期,执行OUT指令才出现I/O写总线周期CPU响应可屏蔽中断时生成中断响应总线周期如何实现同步?总线操作中如何实现时序同步是关键CPU总线周期采用同步
本文标题:005第5章8086的总线操作和时序
链接地址:https://www.777doc.com/doc-3047414 .html