一、设计内容及要求 利用DS1302实现年月日时分秒,并用数码管显示。(用proteus实现) 二、设计原始资料 单片机原理及应用教程 范立南 2006年 1月 单片机原理及应用教程 刘瑞新 2003年07月 三、设计完成后提交的文件和图表 1.计算说明书部分 1)方案论证报告打印版或手写版 2)程序流程图 3)具体程序 2.图纸部分: 具体电路原理图打印版 四、进程安排 教学内容 学时 地点 资料查阅与学习讨论 1天 单片机实验室 分散设计 5天 单片机实验室 编写报告 3天 单片机实验室 成果验收 1天 单片机实验室 五、主要参考资料 《电子设计自动化技术基础》马建国、孟宪元编 清华大学出版 2004年4月 《实用电子系统设计基础》 姜威 2008年1月 《单片机系统的PROTEUS设计与仿真》 张靖武 2007年4月
2
指导老师成绩 答辩小组成绩 总成绩
3
摘要
本课题通过MCS-51单片机来设计电子时钟,采用汇编语言进行编程,可以实现以下一些
功能:小时,分,秒和年,月,日的显示 。本次设计的电子时钟系统由时钟电路,LED显示电路三部分组成。51单片机通过软件编程,在LED数码管上实现小时,分,秒和年,月,日的显示;利用时钟芯片DS1302来实现计时。本文详细介绍了DS1302 芯片的基本工作原理及其软件设计过程,运用PROTEUS软件进行电路连接和仿真,同时还介绍了74LS164,通过它来实现I|O口的扩展。
关键词:时钟芯片,仿真软件,74LS164
4
目录
前言
0.1设计思路………………………………………………………..8 0.2研究意义……………………………………………………….8 一、时钟芯片
1.1 了解时钟芯片……………………………………………….8-9 1.2 掌握时钟芯片的工作原理………………………………….10-11 二、74LS164
2.1 了解74LS164………………………………………………..11-12 2.2 掌握的74LS164工作原理………………………………….12 三、数码管
3.1 熟悉常用的LED数码管.……………………………………12-13 3.2 了解动态显示与静态显示………………………………….13 四、程序设计
4.0 程序流程图…………………………………………………..14
4.1 DS1392的驱动……………………………………………….15-16 4.2 PROTUES实现电路连接…………………………………….17 4.3 数码管的显示:小时;分;秒……………………………….18 4.4 数码管显示:年;月;日……………………………………19 五、总结…………………………………………………………………..20-21 六、附页程序………………………………………………………………22-31
5
前言
单片机自20世纪70年代问世以来,以其极高的性能价格比,受到人们的重视和关注,应用很广、发展很快。单片机体积小、重量轻、抗干扰能力强、环境要求不高、价格低廉、可靠性高、灵活性好、开发较为容易。由于具有上述优点,单片机的使用领域已十分广泛,已经远远超出了计算机科学的领域,小到玩具,信用卡,大到航天器,机器人,从实现数据采集,过程控制,模糊控制等智能控制到人类的日常生活,可以说,在人们的生活生产中都离不开单片机,又如智能仪表、实时工控、通讯设备、导航系统、家用电器,电子万年历,到计时器,定时器,计数器,频率计,电子秤,电子血压表等。各种产品一旦用上了单片机,就能起到使产品升级换代的功效,常在产品名称前冠以形容词——“智能型”,“电脑型”,如智能型洗衣机,电脑温控冰箱等
0.1研究思路
电子时钟的理论基础主要涉及了51单片机应用中的数据转换显示,数码管显示原理。另外,也涉及到了单片机的动态扫描显示原理等一些内容。单片机体积小、重量轻、可靠性高、灵活性好、开发较为容易。
它功能强大,提供了相当多的相关功能模块,所以使用非常方便,用51单片机和DS1302来设计电子时钟是完全可行的,基于MCS-51的电子时钟设计,首先要有明确的设计目的和设计方案,要设计出硬件总体框架图,经过资料的查找,得到流程图。
0.2 研究的意义
通过MCS-51电子时钟的设计,可以对51单片机有了更加深刻的认识,对其各个引脚功能掌握的更为透彻。也再次认识到单片机的应用具有使用范围广的特点,对各个行业的技术改造和产品智能化的更新换代起着重要的推动作用。由于设计的电子时钟起定时,计时作用,所以在设计过程中,可以很好的了解其原理,掌握时钟芯片的结构和实现方法。
在设计电子时钟的过程中,需要完成硬件设计和软件设计,所以需要设计电路硬件原理图。在绘制原理图过程中,再次对PROTEL 99软件进行了熟悉和复习,对软件中的各个文件编辑器进行了掌握,并且知道了在原理图设计和绘制时,要对元件有合理的布局和放置。另外,通过这次研究,在自己动手设计硬件原理图和软件编程的过程中,可以很好的了解到电子时钟的总体设计过程和功能的实现过程,自己着手硬件和软件的制作,一定程度上提高了自己的动手能力和解决问题的能力。
1.1 了解时钟芯片
DS1302 是美国DALLAS公司推出的一种高性能、低功耗、带RAM的实时时钟电路,它可以对年、月、日、周日、时、分、秒进行计时,具有闰年补偿功能,工作电压为2.5V~5.5V。采用三线接口与CPU进行同步通信,并可采用突发方式一次传送多个字节的时钟信号或RAM数据。DS1302内部有一个31×8的用于临时性存放数据的RAM寄存器。DS1302是DS1202的升级产品,与DS1202兼容,但增加了主电源/后背电源双电源引脚,同时提供了对后背电源进行涓细电流充电的能力2.1 引脚功能及结构,下图为DS1302的引脚功能图(1):
6
DS1302的内部结构
DS1302的外部引脚功能说明如图3所示:
X1,X2
GND RST I/O SCLK VCC1
32.768kHz 晶振引脚 地 复位
数据输入/输出 串行时钟 电池引脚
图(1)
DS1302有下列几组寄存器:
① DS1302有关日历、时间的寄存器共有12个,其中有7个寄存器
(读时81h~8Dh,写时80h~8Ch),存放的数据格式为 BCD 码形式, 如表(2)所示。
表(2)
②DS1302有关 RAM 的地址
DS1302中附加31字节静态 RAM 的地址如表(3)所示。
7
表(3) ③ DS1302的工作模式寄存器
所谓突发模式是指一次传送多个字节的时钟信号和 RAM 数据,突发模式寄存器如表(4)所示。
表(4)
1.2 掌握时钟芯片的工作原理
DS1302工作时为了对任何数据传送进行初始化,需要将复位脚(RST)置为高电平且 将8位地址和命令信息装入移位寄存器。数据在时钟(SCLK)的上升沿串行输入,前8位指 定访问地址,命令字装入移位寄存器后,在之后的时钟周期,读操作时输出数据,写操作时 输出数据。时钟脉冲的个数在单字节方式下为8+8(8位地址+8位数据),在多字节方式下为 8加最多可达248的数据。 DS1302的寄存器和控制命令
对 DS1302的操作就是对其内部寄存器的操作,DS1302内部共有12个寄存器,其中有7个寄存器与日历、时钟相关,存放的数据位为 BCD 码形式。此外,DS1302还有年份寄存器、控制寄存器、充电寄存器、时钟突发寄存器及与 RAM相关的寄存器等。时钟突发寄存器可一次性顺序读写除充电寄存器以外的寄存器。 DS1302内部的 RAM 分为两类,一类是单个 RAM 单元,共31个,每个单元为一个8位 的字节,其命令控制字为 COH~FDH,其中奇数为读操作,偶数为写操作;再一类为突发方式下的 RAM,此方式下可一次性读写所有的 RAM 的31个字节,命令控制字为 FEH(写)、 FFH(读)。 我们现在已经知道了控制寄存器和 RAM 的逻辑地址,接着就需要知道如何通过外部接口来访问这些资源。单片机是通过简单的同步串行通讯与 DS1302通讯的,每次通讯都必须由单片机发起,无论是读还是写操作,单片机都必须先向 DS1302写入一个命令帧,这个帧的格式如表所示,最高位 BIT7固定为1,BIT6决定操作是针对 RAM 还是时钟寄存器,接着的5个 BIT 是 RAM 或时钟寄存器在 DS1302的内部地址,最后一个 BIT表示这次操作是读操作抑或是写操作。
物理上,DS1302的通讯接口由3个口线组成,即 RST,SCLK,I/O。其中 RST 从低电平
8
变成高电平启动一次数据传输过程,SCLK 是时钟线,I/O 是数据线。具体的读写时序参考下图,但是请注意,无论是哪种同步通讯类型的串行接口,都是对时钟信号敏感的,而且一般数据写入有效是在上升沿,读出有效是在下降沿(DS1302正是如此的,但是在芯片手 册里没有明确说明),如果不是特别确定,则把程序设计成这样:平时 SCLK保持低电平,在时钟变动前设置数据,在时钟变动后读取数据,即数据操作总是在 SCLK保持为低电平的时候,相邻的操作之间间隔有一个上升沿和一个下降沿。
二、74LS164
2.1 了解74LS164
在单片机系统中,如果并行口的IO资源不够,而串行口又没有其他的作用,那么我们可以用74LS164来扩展并行IO口,节约单片机资源。74LS164是一个串行输入并行输出的移位寄存器。并带有清除端。其中; Q0—Q7 并行输出端 。A,B串行输入端。 MR 清除端,为0时,输出清零。 CP 时钟输入端。
74LS164 引脚定义 74LS164逻辑表 表(5)
9
74LS164 电路原理:
74ls164参考实验照片: 表(6)
2.2 掌握的74LS164工作原理
当清除端(CLEAR)为低电平时,输出端(QA-QH)均为低电平。 串行数据输入端(A,B)可控制数据。当 A、B任意一个为 低电平,则禁止新数据输入,在时钟端(CLOCK)脉冲上升沿作用下Q0 为低电平。当A、B 有一个为高电平,则另一个就允许输入数据,并在CLOCK 上升沿作用下决定Q0 的状态。
三、数码管
3.1 熟悉常用的LED数码管
LED数码管(LED Segment Displays)是由多个发光二极管封在在一起组成“8”字型的器件,引线已在内部连接完成,只需引出它们的各个笔划,公共电极。LED数码管常用段数一般为7段有的另加一个小数点,还有一种是类似于3位“+1”型。位数有半位,1,2,3,4,5,6,8,10位等等....,LED数码管根据LED的接法不同分为共阴和共阳两类,了解LED的这些特性,对编程是很重要的,因为不同类型的数码管,除了它们的硬件电路有差异外,编程方法也是不同的。右图什阴和共阳极数码管的内部电路,它们的发光原理是一样的,只是它们的电源极性不同而已。颜色有红,绿,蓝,黄等几种。常用LED数码管内部引脚图片 图1这是一个7段两位带小数点10引脚的LED数码管。
10
图1 这是一个7段两位带小数点10引脚的LED数码管
图2 引脚定义每一笔划都是对应一个字母表示DP是小数点
3.2 了解动态显示与静态显示
LED数码管要正常显示,就要用驱动电路来驱动数码管的各个段码,从而显示出我们要的数位,因此根据LED数码管的驱动方式的不同,可以分为静态式和动态式两类。 A、静态显示驱动:
静态驱动也称直流驱动。静态驱动是指每个数码管的每一个段码都由一个单片机的I/O埠进行驱动,或者使用如BCD码二-十进位解码器解码进行驱动。静态驱动的优点是编程简单,显示亮度高,缺点是占用I/O埠多,如驱动5个数码管静态显示则需要5×8=40根I/O埠来驱动,要知道一个89S51单片机可用的I/O埠才32个呢。故实际应用时必须增加解码驱动器进行驱动,增加了硬体电路的复杂性。 B、动态显示驱动:
数码管动态显示介面是单片机中应用最为广泛的一种显示方式之一,动态驱动是将所有数码管的8个显示笔划\"a,b,c,d,e,f,g,dp \"的同名端连在一起,另外为每个数码管的公共极COM增加位元选通控制电路,位元选通由各自独立的I/O线控制,当单片机输出字形码时,所有数码管都接收到相同的字形码,但究竟是那个数码管会显示出字形,取决于单片机对位元选通COM端电路的控制,所以我们只要将需要显示的数码管的选通控制打开,该位元就显示出字形,没有选通的数码管就不会亮。
11
四、程序设计 4.0程序流程图:
结束
12
开始 启动ds11302 把数据存到8051的缓存区
数据通过74ls164串行输出 判断有无中断
没有中断,显示 小时;分;秒 有中断显示 年;月;日
4.1 DS1392的驱动
SCLK EQU P1.0 SIO EQU P1.1 RST EQU P1.2 ORG 0000H JMP MAIN MAIN: CALL INIT SJMP $ WRB: MOV 40H,#8 LPW:MOV A,B RRC A MOV B,A MOV SIO,C SETB SCLK CLR SCLK DJNZ 40H,LPW RET
RDB: MOV 40H,#8 LRB:
MOV C,SIO RRC A SETB SCLK CLR SCLK DJNZ 40H,LPR RET
RTIME:MOV R0,#30H MOV R7,#7 MOV R1,#80H LPRT:CLR RST CLR SCLK SETB RST MOV B,R1 CALL WRB CALL RDB
13
MOV @R0,A INC R0 INC R1 INC R1 SERB SCLK CLR RST
DJNZ R7,LPRT RET END
14
4.2PROTUES实现电路连接
15
4.3数码管的显示:小时;分;秒
16
通过开关来切换 小时;分;秒到年;月;日 4.4数码管显示年;月;日
17
五、总结
两个星期的单片机课程设计很快就结束了,在这两周当中,虽然开始有点困难,但是经
过我们们分工合作,合理地进行设计安排,再加上老师的耐心指导,我们们终于顺利地完成了本次单片机课程设计,同时也学到了很多东西。
在本次课程设计中,我们通过动手实践操作,进一步学习和掌握了单片机原理的有关知识,特别是程序的编程方面,加深了对单片机原理及应用技术的认识,进一步巩固了对单片机知识的理解,掌握简单单片机应用系统的设计、制作、调试的方法。在设计时根据课题要求,复习相关的知识,查询相关的资料。根据实验条件,找到适合的方案,找到需要的元器件及工具,进行实验。这次的单片机课程设计重点是通过实践操作和理论相结合,提高动手实践能力,提高科学的思维能力,更在一周的时间了解了更多的有关单片机的知识,使知识更加丰富,使自己更加充实。
与此同时,我们也对团队分工合作有了进一步的认识,只有通过合理的分工合作,我们们才能够在短短一周的时间内完成设计任务,相信这对以后在社会上工作和学习会有很多帮助,让我们能更好的进入工作状态。最重要的是,这次课程设计也增加了我们对问题的研究和探讨,在我们以后的学习中会有更多的帮助。
单片机作为我们们的主要专业课之一,虽然在大三开学初我们对这门课并没有什么兴趣,觉得那些程序枯燥乏味,但在这次课程设计后我们发现自己在一点一滴的努力中对单片机的兴趣也在逐渐增加。作为一名电气专业的大三学生,我们觉得做单片机课程设计是十分有意义的,而且是十分必要的。虽然过去从未独立应用过它们,但在学习的过程中带着问题去学我们发现效率很高,这是我们做这次课程设计的又一收获。然后,要做好一个课程设计,就必须做到:在设计程序之前,对所用单片机的内部结构有一个系统的了解,知道该单片机内有哪些资源;要有一个清晰的思路和一个完整的的软件流程图;在设计程序时,不能妄想一次就将整个程序设计好,反复修改、不断改进是程序设计的必经之路;要养成注释程序的好习惯,一个程序的完美与否不仅仅是实现功能,而应该让人一看就能明白你的思路,这样也为资料的保存和交流提供了方便;在设计课程过程中遇到问题是很正常的,但我们们应该将每次遇到的问题记录下来,并分析清楚,以免下次再碰到同样的问题的课程设计结束了,但是从中学到的知识会让我们受益终身。在设计的过程中发现了自己的不足之处,对以前所学过的知识理解得不够深刻,掌握得不够牢固。我们们通过查阅大量有关资料,并在小组中
18
互相讨论,交流经验和自学,若遇到实在搞不明白的问题就会及时请教老师,使自己学到了不少知识,也经历了不少艰辛,但收获同样巨大。通过这次课程设计我们也发现了自身存在的不足之处,虽然感觉理论上已经掌握,但在运用到实践的过程中仍有意想不到的困惑,经过一番努力才得以解决。
在完成单片机课程设计后,我们们发现我们们还有许多不足,所学到的知识还远远不够,以至于还有一些功能不能被动完成。但通过学习这一次实践,增强了我们们的动手能力,提高和巩固了单片机方面的知识,特别是软件方面。从中增强了我们们的团队合作精神,并让我们们认识到把理论应用到实践中去是多么重要.
19
六、附页程序
程序:
IO EQU P1.0 ;实时时钟数据线引脚 SCLK EQU P1.1 ;实时时钟时钟线引脚 RST EQU P1.2 ;实时时钟复位线引脚
SECOND EQU 40H MINUTE EQU 41H HOUR EQU 42H DAY EQU 43H MONTH EQU 44H WEEK EQU 45H YEAR EQU 46H ORG 0000H JMP MAIN ORG 0003H jmp INT_0 ORG 0020H MAIN:CLR IT0 SETB EX0 SETB EA
LCALL GET ;从DS1302读取时间
DISPALY:
MOV a,40H ;显示秒 ANL a,#0FH ;低位保留 lcall www lcall delay mov a,40h anl a,#0f0h
swap a ;高位低位互换 lCALL aaa lcall delay
20
MOV a,41H ;显示分 ANL a,#0FH ;低位保留 lcall wwwf lcall delay mov a,41h anl a,#0f0h
swap a ;高位低位互换 lCALL aaaf lcall delay
MOV a,42H ANL a,#0FH lcall wwws lcall delay mov a,42h anl a,#0f0h
swap a lCALL aaas lcall delay ljmp main sjmp $ INT_0:
MOV a,43H ANL a,#0FH lcall wwwr mov a,43h anl a,#0f0h
swap a lCALL aaar lcall delay
MOV a,44H ANL a,#0FH lcall wwwy lcall delay mov a,44h
anl a,#0f0h swap a
;显示时 ;低位保留 ;高位低位互换 ;显示日 ;低位保留 ;高位低位互换 ;显示月 ;低位保留 ;高位低位互换
21
lCALL aaay lcall delay
MOV a,46H ;显示年 ANL a,#0FH ;低位保留 lcall wwwn lcall delay mov a,46h anl a,#0f0h
swap a ;高位低位互换 lCALL aaan lcall delay RETI
;把寄存器中的内容传给74ls164的子程序
www: ;给秒的低四位数码管赋值 mov 49h,#8h lcall L0 eee:
jb acc.7,rrr clr p0.0 jmp ttt rrr:
setb p0.0 ttt:
clr p2.0 setb p2.0 rl a
djnz 49h,eee ret
aaa: ;给秒的高四位数码管赋值 mov 49h,#8h lcall L0 sss:
jb acc.7,ddd clr p0.1 jmp fff ddd:
22
setb p0.1 fff: clr p2.1 setb p2.1 rl a
djnz 49h,sss ret
wwwf: ;给分的低四位数码管赋值 mov 49h,#8h lcall L0 eeef:
jb acc.7,rrrf clr p0.2 jmp tttf rrrf:
setb p0.2 tttf:
clr p2.2 setb p2.2 rl a
djnz 49h,eeef ret
aaaf: mov 49h,#8h lcall L0 sssf:
jb acc.7,dddf clr p0.3 jmp ffff dddf:
setb p0.3 ffff:
clr p2.3 setb p2.3 rl a
djnz 49h,sssf ret
wwws: mov 49h,#8h
;给分的高四位数码管赋值 ;给时的低四位数码管赋值 23
lcall L0 eees:
jb acc.7,rrrs clr p0.4 jmp ttts rrrs:
setb p0.4 ttts:
clr p2.4 setb p2.4 rl a
djnz 49h,eees ret
aaas: mov 49h,#8h lcall L0 ssss:
jb acc.7,ddds clr p0.5 jmp fffs ddds:
setb p0.5 fffs:
clr p2.5 setb p2.5 rl a djnz 49h,ssss ret
wwwr: mov 49h,#8h lcall L0 eeer:
jb acc.7,rrrr clr p0.0 jmp tttr rrrr:
setb p0.0 tttr:
clr p2.0
给时的高四位数码管赋值 ;给日的低四位数码管赋值24
; setb p2.0 rl a
djnz 49h,eeer ret
aaar: ;给日的高四位数码管赋值 mov 49h,#8h lcall L0 sssr:
jb acc.7,dddr clr p0.1 jmp fffr dddr:
setb p0.1 fffr:
clr p2.1 setb p2.1 rl a
djnz 49h,sssr ret
wwwy: mov 49h,#8h lcall L0 eeey:
jb acc.7,rrry clr p0.2 jmp ttty rrry:
setb p0.2 ttty: clr p2.2 setb p2.2 rl a
djnz 49h,eeey ret
aaay: mov 49h,#8h lcall L0 sssy:
;给月的低四位数码管赋值;给月的高四位数码管赋值 25
jb acc.7,dddy clr p0.3 jmp fffy dddy:
setb p0.3 fffy: clr p2.3 setb p2.3 rl a
djnz 49h,sssy ret
wwwn: mov 49h,#8h lcall L0 eeen:
jb acc.7,rrrn clr p0.4 jmp tttn rrrn:
setb p0.4 tttn: clr p2.4 setb p2.4 rl a
djnz 49h,eeen ret
aaan: mov 49h,#8h lcall L0 sssn:
jb acc.7,dddn clr p0.5 jmp fffn dddn:
setb p0.5 fffn: clr p2.5 setb p2.5
;给年的低四位数码管赋值;给年的高四位数码管赋值 26
rl a
djnz 49h,sssn ret
delay: ;延时60ms mov 47h,#60
lop11: mov 48h,#0ffh lop22: nop nop
djnz 48h,lop22 djnz 47h,lop11 ret
;判断时钟每位是几(1,2,
L0: cjne a,#0h,L1 mov a,#0c0h ret
L1: cjne a,#1h,L2 mov a,#0f9h ret
L2: cjne a,#2h,L3 mov a,#0a4h ret
L3: cjne a,#3h,L4 mov a,#0b0h ret
L4: cjne a,#4h,L5 mov a,#99h ret
L5: cjne a,#5h,L6 mov a,#92h ret
L6: cjne a,#6h,L7 mov a,#82h ret
L7: cjne a,#7h,L8 mov a,#0f8h ret
L8: cjne a,#8h,L9 mov a,#80h
3,4,5,6,7,8,,27
9,) ret
L9: mov a,#90h RET
从DS1302读取时间 GET:
MOV R0,#40H
MOV R1,#81H ;DS1302中读时间的首地址 MOV R7,#7 GETLOOP:
CLR RST nop
CLR SCLK nop
SETB RST nop
MOV B,R1
LCALL WRITE ;写命令字 LCALL READ ;读时间 MOV @R0,A ;将从DS1302中读取的时间从内存中保存
INC R0 ;修改地址指针 INC R1 INC R1 SETB SCLK nop
CLR RST nop
DJNZ R7,GETLOOP RET
WRITE:
MOV 30H,#8 ;写入命令子程序DS1302 LOP1:
MOV A,B RRC A MOV B,A MOV P1.0,C SETB P1.1
28
CLR P1.1
DJNZ 30H,LOP1
RET
READ: ;读出数据子程序DS1302 MOV 30H,#8
LOP2: MOV C,P1.0 RRC SETB CLR DJNZ RET END
A P1.1 P1.1
30H,LOP2
29
因篇幅问题不能全部显示,请点此查看更多更全内容