如果您无法下载资料,请参考说明:
1、部分资料下载需要金币,请确保您的账户上有足够的金币
2、已购买过的文档,再次下载不重复扣费
3、资料包下载后请先用软件解压,在使用对应软件打开
一、实验目的:掌握汇编语言设计和调试方法。二、实验要求:利用8253、8255、8259三块芯片相接实现流水灯。三、芯片介绍:1、intel8253是NMOS工艺制成的可编程计数器/定时器,有几种芯片型号,外形引脚及功能都是兼容的,只是工作的最高计数速率有所差异,例如8253〔2.6MHz〕,8253-5(5MHz)8253内部有三个计数器,分别成为计数器0、计数器1和计数器2,他们的机构完全一样。每个计数器的输入和输出都决定于设置在控制存放器中的控制字,互相之间工作完全独立。每个计数器通过三个引脚和外部联系,一个为时钟输入端CLK,一个为门控信号输入端GATE,另一个为输出端OUT。每个计数器内部有一个8位的控制存放器,还有一个16位的计数初值存放器CR、一个计数执行部件CE和一个输出锁存器OL。执行部件实际上是一个16位的减法计数器,它的起始值就是初值存放器的值,而初始值存放器的值是通过程序设置的。输出锁存器的值是通过程序设置的。输出锁存器OL用来锁存计数执行部件CE的内容,从而使CPU可以对此进展读操作。顺便提一下,CR、CE和OL都是16位存放器,但是也可以作8位存放器来用。.z.、8255作为主机与外设的连接芯片,必须提供与主机相连的3个总线接口,即数据线、地址线、控制线接口。同时必须具有与外设连接的接口A、B、C口。由于8255可编程,所以必须具有逻辑控制局部,因而8255内部构造分为3个局部:与CPU连接局部、与外设连接局部、控制局部。1〕与CPU连接局部根据定义,8255能并行传送8位数据,所以其数据线为8根D0~D7。由于8255具有3个通道A、B、C,所以只要两根地址线就能寻址A、B、C口及控制存放器,故地址线为两根A0~A1。此外CPU要对8255进展读、写与片选操作,所以控制线为片选、复位、读、写信号。各信号的引脚编号如下:〔1〕数据总线DB:编号为D0~D7,用于8255与CPU传送8位数据。〔2〕地址总线AB:编号为A0~A1,用于选择A、B、C口与控制存放器。〔3〕控制总线CB:片选信号、复位信号RST、写信号、读信号。当CPU要对8255进展读、写操作时,必须先向8255发片选信号选中8255芯片,然后发读信号或写信号对8255进展读或写数据的操作。.z.〕与外设接口局部根据定义,8255有3个通道A、B、C与外设连接,每个通道又有8根线与外设连接,所以8255可以用24根线与外设连接,假设进展开关量控制,则8255可同时控制24路开关。各通道的引脚编号如下:〔1〕A口:编号为PA0~PA7,用于8255向外设输入输出8位并行数据。〔2〕B口:编号为PB0~PB7,用于8255向外设输入输出8位并行数据。〔3〕C口:编号为PC0~PC7,用于8255向外设输入输出8位并行数据,当8255工作于应答I/O方式时,C口用于应答信号的通信。3〕控制器8255将3个通道分为两组,即PA0~PA7与PC4~PC7组成A组,PB0~PB7与PC0~PC3组成B组。如图7.5所示,相应的控制器也分为A组控制器与B组控制器,各组控制器的作用如下:〔1〕A组控制器:控制A口与上C口的输入与输出。〔2〕B组控制器:控制B口与下C口的输入与输出。.z.、8259A是专门为了对8085A和8086/8088进展中断控制而设计的芯片,它是可以用程序控制的中断控制器。单个的8259A能管理8级向量优先级中断。在不增加其他电路的情况下,最多可以级联成64级的向量优先级中断系统。8259A有多种工作方式,能用于各种系统。各种工作方式的设定是在初始化时通过软件进展的。在总线控制器的控制下,8259A芯片可以处于编程状态和操作状态.编程状态是CPU使用IN或OUT指令对8259A芯片进展初始化编程的状态四、实验硬件连线图如下所示:五、程序代码:INTR_IVADDEQU01C8H;INTR对应的中断矢量地址INTR_OCW1EQU0A1H;INTR对应PC机内部8259的OCW1地址INTR_OCW2EQU0A0H;INTR对应PC机内部8259的OCW2地址INTR_IMEQU0FBH;INTRINTR对应的中断屏蔽字IOY0EQU3000H;片选IOY0对应端口的地址8255IOY1EQU3040H;IOY1对应端口的地址8254MY8254_COUNT1EQUIOY0+01H*2;8254计数器0端口地址MY82