用AT89S51单片机实现数字钟的控制_第1页
用AT89S51单片机实现数字钟的控制_第2页
用AT89S51单片机实现数字钟的控制_第3页
用AT89S51单片机实现数字钟的控制_第4页
用AT89S51单片机实现数字钟的控制_第5页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

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

文档简介

1、桂林电子科技大学微机单片机接口设 计 报 告指导老师: 吴 兆 华 学 生: 钱 广 学 号: 092011102 桂林电子科技大学机电工程学院 一 设计题目: 用AT89S51单片机实现数字钟的控制。从12.00开始计时,由P0-0口控制秒,P0-1口控制分,P0-2口控制时。二 设计目的要求和意义2.1设计目的要求1通过单片机最小系统的设计,了解常用单片机应用系统开发手段和过程,进一步熟悉和掌握单片机的结构和工作原理,并能初步掌握一般单片机控制系统的编程和应用,从而进一步加深对单片机理论知识的理解。2 掌握单片机内部功能模块。如定时器/计数器、中断系统、存储器、I/O口等;3 掌握单片机的

2、接口及相关外围芯片的特性、使用与控制方法;4 掌握单片机的编程方法,调试方法;5 掌握单片机应用系统的构建和使用,为以后设计和实现单片机应用系统打下良好的基础。6.学会使用并熟练掌握电路绘制软件Protel99SE(或DXP);7.掌握电路图绘制及PCB图布线技巧。2.2 系统设计意义1、在系统掌握单片机相应基础知识的前提下,熟悉单片机最小应用系统的设计方法及系统设计的基本步骤。2、完成所需单片机最小应用系统原理图设计绘制的基础上完成系统的电路图设计。3、完成系统所需的硬件设计制作,在提高实际动手能力的基础上进一步巩固所学知识。4、进行题目要求功能基础上的软件程序编程,会用相应软件进行程序调试

3、和测试工作。5、通过单片机应用系统的设计将所学的知识融会贯通,锻炼独立设计、制作和调试单片机应用系统的能力;领会单片机应用系统的软、硬件调试方法和系统的研制开发过程,为进一步的科研实践活动打下坚实的基础。三 系统硬件电路图设计用Protel99SE绘制的硬件电路原理图如下:在电路中,由单片机的P0-0,P0-1,P0-2控制三个开关,由P1口控制数码管的段,由P3口控制位的扫描。图1系统原理图四 程序流程图与源代码4.2 程序源代码程序设计思想:由单片机的P0-0,P0-1,P0-2控制三个开关,由P1口控制数码管的段,由P3口控制位的扫描。#include unsigned char cod

4、e dispcode=0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71,0x00;unsigned char dispbitcode=0xf7,0xfb,0xfd,0xfe, 0x7f,0xbf,0xdf,0xef;unsigned char dispbuf8=0,0,16,0,0,16,0,0;unsigned char dispbitcnt;unsigned char second;unsigned char minite;unsigned char hour=12;unsi

5、gned int tcnt;unsigned char mstcnt;unsigned char i,j;void main(void) TMOD=0x02; TH0=0x06; TL0=0x06; TR0=1; ET0=1; EA=1; while(1) if(P00=0) for(i=5;i0;i-) for(j=248;j0;j-); if(P00=0) second+; if(second=60) second=0; minite+; dispbuf0=second%10; dispbuf1=second/10; while(P00=0); if(P01=0) for(i=5;i0;i

6、-) for(j=248;j0;j-); if(P01=0) minite+; if(minite=60) minite=0; hour+; dispbuf3=minite%10; dispbuf4=minite/10; while(P01=0); if(P02=0) for(i=5;i0;i-) for(j=248;j0;j-); if(P02=0) hour+; if(hour=24) hour=0; dispbuf6=(hour%10); dispbuf7=(hour/10); while(P02=0); void t0(void) interrupt 1 using 0 mstcnt+

7、; if(mstcnt=8) mstcnt=0; P3=dispbitcodedispbitcnt; P1=dispcodedispbufdispbitcnt; dispbitcnt+; if(dispbitcnt=8) dispbitcnt=0; tcnt+; if(tcnt=4000) tcnt=0; second+; if(second=60) second=0; minite+; if(minite=60) minite=0; hour+; if(hour=24) hour=0; dispbuf0=second%10; dispbuf1=second/10; dispbuf3=mini

8、te%10; dispbuf4=minite/10; dispbuf6=(hour%10); dispbuf7=(hour/10); 五 系统功能分析与说明本系统主要是实现对转弯灯的控制功能。本最小系统包括微处理器、复位模块、转弯灯输出模块、输出显示模块、晶振模块,下面详细的介绍了各模块的功能:5.1 微处理器本系统微处理器用的是AT89S51单片机,下面详细介绍AT89S51的功能和引脚图。AT89S51单片机是美国ATMEL公司生产的低功耗,高性能CMOS 8位单片机,片内含4K bytes的可系统编程的Flash只读程序存储器,器件采用ATMEL公司的高密度,非易失性存储技术生产,兼容标

9、准8051指令系统及引脚。它集Flash程序存储器,既可在线编程(ISP)也可用传统方法进行编程及通用8位微处理器于单片芯片中,ATMEL公司的功能强大,低价AT89S51单片机可为您提供许多高性价比的应用场合,可灵活应用于各种控制领域。AT89S51是一个低功耗,高性能CMOS 8位单片机,片内含8k Bytes ISP(In-system programmable)的可反复擦写1000次的Flash只读程序存储器,器件采用ATMEL公司的高密度、非易失性存储技术制造,兼容标准MCS-51指令系统及89C51引脚结构,如图4芯片内集成了通用8位中央处理器和ISP Flash存储单元,功能强大

10、的微型计算机的AT89S51可为许多嵌入式控制应用系统提供高性价比的解决方案。AT89S51具有如下特点:40个引脚,8k Bytes Flash片内程序存储器,128 bytes的随机存取数据存储器(RAM),32个外部双向输入/输出(I/O)口,5个中断优先级2层中断嵌套中断,2个16位可编程定时计数器,2个全双工串行通信口,看门狗(WDT)电路,片内时钟振荡器。图2 AT89S51引脚图引脚排列及功能:AT89S51/LS51具有PDIP,TQFP和PLCC三种封装形式。1) P08位、开漏极、双向I/O口P0口可作为通用IO口,但须外接上拉电阻;作为输出口,每个引脚可吸收8个TTL的灌

11、电流。作为输入时,首先应将引脚置1。 P0口也可用做访问外部程序存储器和数据存储器时的低8位地址数据总线的复用线。在该模式下,P0口含有内部上拉电阻。 在Flash编程时,P0口接收代码字节数据;在编程校验时,P0口输出代码字节数据(需要外接上拉电阻)。 2) P1口8位、双向IO口,内部含有上拉电阻P1口可作为普通IO口。输出缓冲器可驱动4个TTL负载;用做输入时,先将引脚置1,由片内上拉电阻将其抬到高电平。P1口的引脚可由外部负载拉到低电平,通过上拉电阻提供拉电流。 在Flash并行编程和校验时,P1口可输入低字节地址。在串行编程和校验时,P15/MOSI,P16/MISO和P17/SCK

12、分别是串行数据输入、输出和移位脉冲引脚。3) P2口具有内部上拉电阻的8位双向IO口P2口用做输出口时,可驱动4个TTL负载;用做输入口时,先将引脚置1,由内部上拉电阻将其提高到高电平。若负载为低电平,则通过内部上拉电阻向外输出电流。 CPU访问外部16位地址的存储器时,P2口提供高8位地址。当CPU用8位地址寻址外部存储器时,P2口为P2特殊功能寄存器的内容。 在Flash并行编程和校验时,P2口可输入高字节地址和某些控制信号。4) P3口具有内部上拉电阻的8位双向口P3口用做输出口时,输出缓冲器可吸收4个TTL的灌电流;用做输入口时,首先将置1,由内部上拉电阻抬为高电平。若外部的负载是低电

13、平,则通过内部上拉电阻向外部输出电流。 在与Flash并行编程和校验时,P3口可输入某些控制信号。P3口除了通用IO功能外,还有替代功能,如下表1所示。引脚符号说明P3.0RXD串行口输入P3.1TXD串行口输出P3.2INT0外部中断0P3.3INT1外部中断1P3.4T0T0定时器的外部计数输入P3.5T1T1定时器的外部计数输入P3.6WR外部数据存储器的写选通P3.7RD外部数据存储器的读选通5) ALE/PROG地址锁存允许/编程脉冲信号端在CPU访问外部程序存储器或外部数据存储器时,ALE提供一个地址锁存信号,将低8位地址锁在片外地址锁存器中。 在与Flash并行编程时,该引脚也是

14、编程负脉冲的输入端。 在正常操作状态下,该引脚端口输出恒定频率的脉冲。其频率为晶振频率的16,可用做外部定时或其他触发信号。应注意,CPU每次访问外部数据存储器时,都要丢失一个ALE脉冲。 如果需要,则通过将SFR(8EH)的第0位置1,可禁止ALE操作,但在使用MOVC或MOVX指令时,ALE仍然有效。也就是说,ALE的禁止位不影响对外部存储器的访问。6) PSEN外部程序存储器读选通信号,低电平有效当AT89S51LS51执行来自外部程序存储器的指令代码时,PSEN每个机器周期两次有效。在访问外部数据存储器时,PSEN无效。7) ENV外部程序存储器访问允许当EA接地时,CPU只执行片外程

15、序存储器中的程序;当EA接V时,CPU首先执行片内程序 存储器中的程序(0000H0FFFH),然后自动转向执行片外程序存储器中的程序(1000HFFFFH)。 如果程序锁定位LB1被编程(P),那么EA值将在复位时由片内锁存。 在与Flash并行编程时,该引脚可接入12V的编程电压Vpp。8) XTAL1和XTAL2XTAL1和XTAL2分别为反向放大器的输入和输出。该反向放大器可以配置为片内振荡器。石晶振荡和陶瓷振荡均可采用。如采用外部时钟源驱动器件,XTAL2应不接。有余输入至内部时钟信号要通过一个二分频触发器,因此对外部时钟信号的脉宽无任何要求,但必须保证脉冲的高低电平要求的宽度。9)

16、 PEROM整个PEROM阵列和三个锁定位的电擦除可通过正确的控制信号组合,并保持ALE管脚处于低电平10ms 来完成。在芯片擦操作中,代码阵列全被写“1”且在任何非空存储字节被重复编程以前,该操作必须被执行。此外,AT89S51设有稳态逻辑,可以在低到零频率的条件下静态逻辑,支持两种软件可选的掉电模式。在闲置模式下,CPU停止工作。但RAM,定时器,计数器,串口和中断系统仍在工作。在掉电模式下,保存RAM的内容并且冻结振荡器,禁止所用其他芯片功能,直到下一个硬件复位为止。10) RST复位输入端,高电平有效在振荡器稳定有效运行情况下,RST端维持两个机器周期的高电平,便可复位器件。 当看门狗

17、定时器溢出输出时,该引脚将输出长达98个振荡周期的高电平。11) VCC电源电压输入端12) GND电源地AT89S51有两种节电运行模式:空闲模式和掉电模式。 空闲模式 在空闲模式下,CPU处于睡眠状态,振荡器和所有片内外围电路仍然有效。空闲模式可由软件设置进入(设IDL1)。在这种模式下,片内RAM和SFR中的内容保持不变。 空闲模式可通过任何一个允许中断或硬件复位退出。 若用硬件复位方式结束空闲模式,则在片内复位控制逻辑发生作用前长达约两个机器周期时间内,器件从断点处开始执行程序。片内硬件禁止访问内部RAM,但不禁止访问端口。为避免采用复位方式退出空闲模式时对端口的不应有的访问,在紧随设

18、置进入空闲指令(即设IDL1)的后面,不能是写端口或外部RAM的指令。 掉电模式引起掉电模式的指令是执行程序中的最后一条指令(使PD1的指令)。在掉电模式下,振荡器停止工作,CPU和片内所有外围部件均停止工作,但片内RAM和SFR中的内容保留不变,直到掉电模式结束。 退出掉电模式可用硬件复位或任何一个有效的外部中断INT0和INT1。复位可重新设置SFR中的内容,但不改变片内RAM中的内容。在Vcc电源恢复到正常值并维持足够长的时间之后,允许振荡器恢复并达到稳定,方可进行复位,以退出掉电模式。在本系统中,主要利用了P1、P0口。5.2 复位电路的设计图3 复位电路复位电路的基本功能是:系统上电

19、时提供复位信号,直至系统电源稳定后,撤销复位信号。复位电路采用简单的电阻、电容以及按键开关构成手动复位。如图5所示,在给AT89S51的RST引脚加上高电平并保持2个机器周期的时间,单片机内部就执行复位操作。若此引脚持续高电平,单片机就处于循环复位状态。上电瞬间RST引脚获得高电平,随着电容C的充电,RST引脚的高电平将逐渐下降。RST引脚的高电平只要能保持足够的时间(2个机器周期),单片机就可以进行复位操作。复位电路一般R取10K,C取10uF, RC越大,充电时间越长,单片机上电复位过程越长,其实RC取值不是需要特别严格。还有种说法,R=1K,C=22uF,抗干扰性更好。5.3 转弯灯输入

20、模块图4 输入电路如图6所示,转弯的左右闪烁灯是通过输入检测模块的输入信号的有无来工作的。按键的一端接地,输入信号取自与按键的另一端,当有按键按下时,输入信号为0。这时,单片机AT89S51检测到P10、P11的信号为0并通过程序来对输出口所要输出的数据进行处理并通过LED闪烁显示。当没有按键按下时,无法判断P10、P11的信号。此时中间的LED长亮。其中R1、R2起到限流作用。5.4 输出显示电路图5 输出电路5.5 晶振电路图6 晶振电路如图8所示,晶振电路由12Mhz的石英晶体和两个30PF的电容并联而成。系统的时钟电路设计是采用的内部方式,即利用芯片内部的振荡电路。AT89S单片机内部

21、有一个用于构成振荡器的高增益反相放大器。引脚XTAL1和XTAL2分别是此放大器的输入端和输出端。这个放大器与作为反馈元件的片外晶体谐振器一起构成一个自激振荡器。外接晶体谐振器以及电容C1和C2构成并联谐振电路,接在放大器的反馈回路中。对外接电容的值虽然没有严格的要求,但电容的大小会影响振荡器频率的高低、振荡器的稳定性、起振的快速性和温度的稳定性。因此,此系统电路的晶体振荡器的值为12MHz,电容应尽可能的选择陶瓷电容,电容值约为22F。在焊接刷电路板时,晶体振荡器和电容应尽可能安装得与单片机芯片靠近,以减少寄生电容,更好地保证振荡器稳定和可靠地工作。此电路为单片机提供了稳定的频率,保证了单片

22、机的工作的可靠性。5.6 制作PCB图Protel99功能强大,为我们进行电子电路原理图和印制板图的设计提供了良好的操作环境。用Protell99进行电路设计分为两大部分:原理图的设计和电路板的设计。原理图的设计实在SCH系统中进行的,电路原理图是印刷板电路设计的基础,只有设计好原理图才有可能进行下一步的电路板设计。用protel99进行电路板设计的第一步是其原理图的设计。显然,原理图决定整个电路的基本功能,也是接下来生成网表和设计印刷板电路的基础。具体步骤如下:(1)图面设置: Protel99允许用户根据电路的规模设置图面的大小,按照偏好和习惯设置图面的样式。实际上,设置图面就是设置了一个

23、工作平面,以后的工作就要在这个平面上进行。所以图面应该设置得足够大,为进一步工作提供一个足够大的工作空间。(2)放置元件: 所谓放置元件就是从元件库中选取所需得元件,将其布置到图面上合适的位置,有时还要重定义元件的编号、封装。元件的封装很重要,要根据元件的实际尺寸和实际封装来决定,要是元件没封装好,将会给以后电路板的制作带来很大的麻烦。这些都是下一步工作的基础。Protel99为用户提供了一个非完备的元件库,并且允许用户对这个元件库进行编辑或者新建自己的元件库。电路板的制作过程(1) 打印:将生成的PCB图打印到热转印纸上,需注意线不能太窄,墨要加重,否则制板时容易断线,如果在操作过程中断了线

24、,可用电烙铁将锡带过。(2) 熨烫:将热转印纸覆在铜板上,用电熨斗进行熨烫,关键要注意熨烫的时间,不能太久,也不能时间太短,否则,太久会把铜板烫坏,不够的话墨迹覆不上去。(3) 腐蚀:把铜板放到三氯化铁溶液中腐蚀,需注意溶液浓度要较高,最好用热水配置,这样腐蚀更快,一般3分钟即可。如果时间过长,需剩下的铜线也可能被腐蚀。(4) 打孔:打孔时注意钻头尺寸,本次用的钻头大小是0.712mm的,最需注意的地方是集成块的管脚,如果打孔误差大,管座就很难插上。(5) 放置元件:放置前应先打磨一下打孔后留下的毛刺,并均匀地涂上松香水(目的是防止铜线氧化,易于焊锡覆着焊盘,但多涂会导致焊接时焊点变黑,影响美

25、观)。放置元件时注意集成块的管脚,二极管和电解电容的正负,这些都是平时比较容易出错的地方。(6) 焊接:焊接技术比较难掌握,焊锡、烙铁与焊盘的位置关系,焊锡熔化时间长短,松香水的浓度,烙铁的温度等等,都是影响焊点美观的因素。(7) 检查:检查是否有虚焊,集成块管脚位置是否正确,电源引线位置是否恰当等。检查完毕就能进行调试了。 图7 PCB图在电路中的开关本来是用按键,但由于材料有限,用拨位开关取代。整个系统经过电路设计的修改和仿真软件的验证之后,做成实物这样大大降低了调试和检测的时间。其功能基本上实现。六 设计体会制作了这个最小系统后,基本理解了protel99SE软件的一些基本使用思路:1、

26、主要分两个部分,一个为原理图,一个为PCB图,原理图为你所要实现电路的基本原理结构,只是实现其原理的框图。一个为PCB,就是你所做的电路的具体实现形式,所做电路的大小,元件大小,导线大小都完全和做出后的电路板一摸一样,做PCB的时候,要考虑到很多的因素,比如导线的宽度,焊盘大小,安全间距,元件摆放位置,元件大小,干涉情况等。2、原理图和PCB又是有关联的,它们电气特性是一样的,在一边的修改完全可以反映到另一方面。这就使的设计思路的唯一性,也让改动变得更加合理以及人性化。3、原理图和PCB都有自己元件库里的元件和一些基本的电路线路组成的。在做原理图和PCB的时候,最好先把元件进行封装库统一。似得原理图和PCB能环环相扣,减少设计出错的可能性。在进行这个最小系统的编程设计时,不用以前学习的汇编编程,改用c语言进行编程。学习了单片机的c语言编程后,发现c语言编单片机程序的时候比汇编更加直观,逻辑性也更加强,也更加容易编出大的程序。由于c语言强大的逻辑功能,有时侯能编出一些汇编无法或者很难编写

温馨提示

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

评论

0/150

提交评论