硬件课程设计实验报告_模拟交通灯_第1页
硬件课程设计实验报告_模拟交通灯_第2页
硬件课程设计实验报告_模拟交通灯_第3页
硬件课程设计实验报告_模拟交通灯_第4页
硬件课程设计实验报告_模拟交通灯_第5页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、硬件部件设计与调试实验题目:模拟交通灯实验目的与要求: 了解交通灯管理的基本工作原理熟悉8259A中断控制器的工作原理和应用编程熟悉8255A并行接口的各种工作方式和应用熟悉8253计数器/定时器的工作方式及应用编程,掌握利用软硬件相结合定时的方法掌握多位LED显示问题的解决实验原理与方法:l 8259、8255A和8253的工作原理:一、8259的工作原理:1、数据总线缓冲器:8259A与系统数据总线的接口,是8位双向三态缓冲器。CPU与8259A之间的控制命令信息、状态信息以及中断类型信息,都是通过缓冲器传送的。2、读/写控制逻辑:CPU通过它实现对8259A的读/写操作。3、级连缓冲器:

2、用以实现8259A芯片之间的级连,使得中断源可以由8级扩展至64级。4、控制逻辑电路:对整个芯片内部各部件的工作进行协调和控制。5、中断请求寄存器IRR:8位,用以分别保存8个中断请求信号,当响应的中断请求输入脚有中断请求时,该寄存器的相应位置1。6、中断屏蔽寄存器IMR:8位,相应位用以对8个中断源的中断请求信号进行屏蔽控制。当其中某位置“0“时,则相应的中断请求可以向CPU提出;否则,相应的中断请求被屏蔽,即不允许向CPU提出中断请求。该寄存器的内容为8259A的操作命令字OCW1,可以由程序设置或改变。7、中断服务寄存器ISR:8位,当CPU正在处理某个中断源的中断请求时,ISR寄存器中

3、的相应位置1。8、用以比较正在处理的中断和刚刚进入的中断请求之间的优先级别,以决定是否产生多重中断或中断嵌套。二、8255A的工作原理:1、8255A的内部结构:1) 数据总线缓冲器:这是一个双向三态的8位数据缓冲器,它是8255A与微机系统数据总线的接口。输入输出的数据、CPU输出的控制字以及CPU输入的状态信息都是通过这个缓冲器传送的。2) 三个端口A,B和C:A端口包含一个8位数据输出锁存器和缓冲器,一个8位数据输入锁存器。B端口包含一个8位数据输入/输出锁存器和缓冲器,一个8位数据输入缓冲器。C端口包含一个8位数据输出锁存器和缓冲器,一个8位数据输入缓冲器(输入没有锁存器)。3) A组

4、和B组控制电路:这是两组根据CPU输出的控制字控制8255工作方式的电路,它们对于CPU而言,共用一个端口地址相同的控制字寄存器,接收CPU输出的一字节方式控制字或对C口按位复位字命令。方式控制字的高5位决定A组的工作方式,低3位决定B组的工作方式。对C口按位复位命令字可对C口的每一位实现置位或复位。A组控制电路控制A口和C口上半部,B组控制电路控制B口和C口下半部。4) 读写控制逻辑:用来控制把CPU输出的控制字或数据送至相应端口,也由它来控制把状态信息或输入数据通过相应的端口送到CPU。2、8255A的 工作方式:方式0-基本输入输出方式;方式1-选通输入输出方式;方式2-双向选通输入输出

5、方式。三、8253的工作原理:8253是可编程的计数器/定时器,其内部有三个独立的16位计数器/定时器通道,每个计数器通道均可按6种不同的方式工作,并且都可以按二进制或十进制计数。其CLK0CLK2是计数器02的时钟脉冲输入端, GATE0GATE2是门控脉冲输入端, OUT0OUT2是输出端。l 交通信号灯实时控制和管理的总体设计 芯片选择及端口选择1 用实验系统8255A实现对信号灯的控制(所用端口自定);2位数码显示用8255A实现控制。2 用实验系统8235的计数器2定时向实验系统主片8259A的IRQ7请求中断,以实现要求的1分钟、5秒钟和20秒的定时。实验系统8235的计数器2的C

6、LK2接OPCLK,频率为1.19318MHZ;GATE2已接+5V;定时采用软硬件相结合的方式实现。3、 用实验系统的发光二极管模拟红绿灯。 注:8259A的端口地址为:218H、219H8255A的端口地址为:端口A-200H、端口B-201H、端口C-202H、控制端口-203H8253的端口地址为:计数器0-208H、计数器1-209H、计数器2-20aH、控制寄存器0-20bH。本设计硬件由定时模块、发光二极管模块、数码管显示模块和紧急中断模块组成。定时模块采用硬件定时和软件定时相结合的方法,用8253定时/计数器定时100ms,再用软件计时实现所需的定时。发光二极管模块由8255控

7、制发光二极管来实现。数码管显示模块由实验平台上的LED显示模块实现。紧急中断模块是由单脉冲发生单元和8259中断控制器组成。程序主要是由定时子程序、发光二极管显示子程序、数码管显示子程序和中断服务程序组成。包括对8253、8255以及8259等可编程器件的编程。l 方案论证: 软件延时,设计简单,使用方便,但是无法进行精确计时,无法在实际应用中进行使用,本次设计采用了,定时器0进行计时,每10ms产生一个脉冲信号,可以准确的计时并方便8段数码管进行显示。使用中断比较麻烦,在试验中需要两次加载初始化程序和中断服务程序,并且需要手工指定中断服务地址和中断向量号;但是使用中断可以进行多样化设计,强化

8、程序功能与执行效率。在本设计中程序每10MS请求一次中断,实现精确定时与数码管显示刷新。实验设计思路与实现:l 硬件设计:本课题的设计可通过实验平台上的一些功能模块电路组成,由于各模块电路内部已经连接,用户在使用时只要设计模块间电路的连接,因此,硬件电路的设计及实现相对简单。完整系统的硬件连接如图1所示。硬件电路由定时模块、发光二极管模块、数码管显示模块和紧急中断模块组成。定时模块是由8253的计数器0来实现定时100ms。Clk0接实验平台分频电路输出Q6,f46875hz。GATE0接8255的PA0,由8255输出来控制计数器的起停。OUT0接8259的IRQ2,定时完成申请中断,进入中

9、断服务程序。发光二极管显示模块由8255输出来控制发光二极管的亮灭。8255输出为低电平时,对应的发光二极管就点亮,否则就熄灭。8255的接口电路如图2所示。交通灯的对应关系如下:L7L6L5L2L1L0PC7PC6PC5PC2PC1PC013红灯13黄灯13绿灯24红灯24黄灯24绿灯实验平台上提供一组六个LED数码管。插孔CS1用于数码管段选的输出选通,插孔CS2用于数码管位选信号的输出选通。本设计用4个数码管来倒计时。紧急中断模块是由单脉冲发生单元和8259中断控制器,单脉冲发生单元主要用来请求中断,然后做出紧急情况处理。Q6OUT0 8253 GATE0 Clk0 PA0 8255 P

10、C地址 CS1译码 CS2电路 CS3 CS4路数码管显示模块IRQ28259IRQ3发光二极管电路单脉冲发生单元PC BUS图1 系统硬件电路图图2 8255接口电路l 软件设计思路:设计数器0的计数初值为25000,由于CLK0接脉冲信号,频率为2.5MHZ,所以每10ms中断一次。利用CX对不同的状态时间计数,用来实现计数器0对1分钟,20秒钟,5秒钟的定时。中断子程序分为数码显示刷新部分和红绿黄灯各种状态切换部分。每进入中断即刷新LED显示。用对于东西车道和南北车道黄灯闪烁利用标志位判断实现,满足比较条件就暗,不满足条件就亮。8253计数的起停由8255的PA0控制,8255的PA0输

11、出1时,8253开始计数,交通灯按正常状态切换工作,PA0输出0时,计数器停止工作,交通灯不再按正常状态切换。8253开始计数后每100ms发出一个中断申请信号,在中断子程序中先刷新数码管,然后判断当前状态,进入相应的处理程序进行处理。主程序负责系统的初始化,然后数码管数据输出显示,同时检测PC键盘按键,有按键就退出程序。主程序的流程图如图3所示。Y初始化8253初始化8255设置中断向量设置交通灯初态启动计数器数码管数据输出开始有按键结束N 图3 主程序的流程图定时中断子程序是本设计的重点,负责完成数码管输出数据刷新和各个状态的处理切换。中断子程序包括数码管输出数据刷新程序和各状态处理程序。

12、数码管输出数据刷新子程序是实现倒计时25s,用LEDOUT表示输出的数据,cnt用来软件计时1s,就是计数10个100ms。LED输出是要将输出的数据转化为段选码。根据当前的状态跳转到相应的处理程序,在处理程序中完成定时和状态的切换。状态1和3的流程是一样的,先点亮对应的交通灯,再判断定时到了就可以切换了。状态2和4要实现黄灯的闪烁,间隔点亮和熄灭就可以了。状态1和3处理程序的流程图(以状态1为例)如图6所示,其中NUM是状态1对应的PC口输出。外部中断服务子程序主要用来处理紧急情况,将2个方向的车都停止运行,点亮所有红灯。下次中断来时恢复以前的状态。用一个标志位FLAG判断是第一次进入还是恢

13、复状态。l 源程序清单:本次设计中,选用8235的计数器0定时向实验系统主片8259A的IRQ0请求中断。设置8253的计数器0每10ms请求一次中断,工作于模式3;8255的A端口控制交通灯。 初始化程序:DATASEGMENTLEDDB3FH,06H,5BH,4FH,66H,6DH,7DH,07H;存放七段代码表DB7FH,6FH,77H,7CH,39H,5EH,79H,71HD1EQU10HD2EQU200H;8255A端口AEAEQU200H;8259端口地址EEEQU203HCONTROLEQU20bH;8253端口地址COUNT0EQU208HCOUNT1EQU209HCOUNT2

14、EQU20aHZ8279EQU222HD8279EQU220HLEDMODEQU00;左边输入,八位显示外部译码八位显示LEDFEQEQU38H;扫描频率DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATACODESEGMENTASSUMECS:CODECONTDB0CONT1DB0CONT2DB0BKSDDB0BKADDB0BKDADB0TEMPDB0;*START:MOVAX,0MOVDS,AXMOVAX,OFFSETIRQ0ADDAX,2000HMOVSI,0FH*4MOVSI,AXMOVAX,0MOVSI+2,AXINAL,218HANDAL,7FHOUT2

15、19H,ALCLIMOVAL,80H;初始化8255OUTEE,ALMOVAL,00OUTEA,ALMOVAL,0f0HOUTEA,ALMOVDX,218H;8259初始化MOVAL,bOUTDX,ALMOVAL,08HMOVDX,219HOUTDX,ALMOVDX,203H;设置为全输出MOVAL,80HOUTDX,ALMOVDX,200HMOVAL,0ffhOUTDX,AL;清LEDMOVDX,200H;全红MOVAL,0F0HOUTDX,ALMOVAL,b;初始化8253OUTCONTROL,ALMOVAX,2500MOVDX,COUNT0OUTDX,ALMOVAL,AHOUTCOUNT

16、0,ALMOVAX,DATAMOVDS,AX中断服务程序:A1:STIHLTJMPA1IRQ0:;写数码管程序,暂缺JMPCOMPARECOMPARE:CMPDL,0JZSTATE0CMPDL,1JZSTATE1CMPDL,2JZSTATE2CMPDL,3JZSTATE3STATE0:;状态0:东西红南北绿moval,boutD2,alDECSIJNZCHANGE1DECDHMOVSI,100CHANGE1:DECCXCMPCX,0JNZM0MOVCX,500STATE1:DECDI;状态1:东西方向黄灯闪烁,南北绿灯CMPDI,0JNZSHINE1MOVAL,b;东西灭,南北绿OUTD2,A

17、LMOVDI,50JMPCHANGESHINE1:MOVAL,B;东西黄,南北绿OUTD2,ALCHANGE:DECSIJNZCHANGE2DECDIMOVSI,100CHANGE2:DECCXCMPCX,0JNZM1MOVCX,2000MOVDH,25STATE2:MOVAL,b;状态2:东西绿灯,南北红灯OUTD2,ALDECSIJNZCHANGE3DECDHMOVSI,100CHANGE3:DECCXCMPCX,0JNZM2MOVCX,500STATE3:DECDI;状态3:东西绿灯,南北黄灯闪烁CMPDI,0JNZSHINE2MOVAL,B;东西绿灯,南北灭OUTD2,ALMOVDI,

18、50JMPSOURCESHINE2:MOVAL,B;东西绿,南北黄OUTD2,ALSOURCE:DECSIJNZCHANGE4DECDHMOVSI,100CHANGE4:DECCXCMPCX,0JNZM3MOVCX,6000MOVDH,65M0:MOVDL,0;下次进入状态0JMPEXITM1:MOVDL,1;下次进入状态1JMPEXITM2:MOVDL,2;下次进入状态2JMPEXITM3:MOVDL,3;下次进入状态3EXIT:MOVAL,20HOUT218H,ALIRETCODEENDSENDSTARTl 程序运行结果:1即东西方向的绿灯和南北方向的红灯同时点亮1分钟;21分钟后,东西方

19、向的黄灯闪烁5秒钟,。此时南北方向仍维持红灯点亮。3东西方向的黄灯闪烁5秒钟后,转为东西方向的红灯和南北方向的绿灯同时点亮20秒钟;420秒钟后,转为南北方向的黄灯闪烁5秒钟,此时东西方向仍维持红灯点亮。5南北方向的黄灯闪烁5秒钟后,东西方向的绿灯和南北方向的红灯同时点亮1分钟。如此循环重复。l 课程设计总结1. 软件延时与定时器计时 软件延时,设计简单,使用方便,但是无法进行精确计时,无法在实际应用中进行使用,本次设计采用了,定时器0进行计时,每10ms产生一个脉冲信号,可以准确的计时并方便8段数码管进行显示2. 使用中断的好处 使用中断比较麻烦,在试验中需要两次加载初始化程序和中断服务程序

20、,并且需要手工指定中断服务地址和中断向量号;但是使用中断可以进行多样化设计,强化程序功能与执行效率。3. 关于本次设计在本次设计中,使用了8259A中断控制器、8253计数器、8255可编程并行接口实现了,对南北、东西方向交通的分别计时、分别控制,但是程序没有实现对双向交通的数码显示,数码显示模块空缺,我们会尽快将程序补全,使其具有完整的交通灯功与其他设计相比,并非复制并修改老师的代码,做到了自主设计,在设计中掌握的计算机接口设计的基本方法、锻炼了能力。十字道口的红绿灯是交通法规的无声命令,是司机和行人的行为准则。十字道口的交通红绿灯控制是保证交通安全和道路畅通的关键。当前,国内大多数城市正在采用“自动”红绿交通灯,它具有固定的“红灯绿灯”转换间隔,并自动切换。它们一般由“通行与禁止时间控制显示、红黄绿三色信号灯和方向指示灯”三部分组成。在交通灯的通行与禁止时间控制显示中,通常要么东西、南北两方向各50秒;要么根据交通规律,东西方向60秒,南北方向40秒,时间控制都是固定的。交通灯的时间控制显示,以固定时间值预先“固化”在单片机中,每次只是以一定周期交替变化。但是,实际上不同时刻的车辆流通状况是十分复杂的,是高度非线性的、随机的,还经常受认为因素的影响。采用定时控制经常

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论