基于DS12C887的实时日历时钟的设计课程设计任务书.doc

上传人:laozhun 文档编号:3938330 上传时间:2023-03-28 格式:DOC 页数:32 大小:588KB
返回 下载 相关 举报
基于DS12C887的实时日历时钟的设计课程设计任务书.doc_第1页
第1页 / 共32页
基于DS12C887的实时日历时钟的设计课程设计任务书.doc_第2页
第2页 / 共32页
基于DS12C887的实时日历时钟的设计课程设计任务书.doc_第3页
第3页 / 共32页
基于DS12C887的实时日历时钟的设计课程设计任务书.doc_第4页
第4页 / 共32页
基于DS12C887的实时日历时钟的设计课程设计任务书.doc_第5页
第5页 / 共32页
点击查看更多>>
资源描述

《基于DS12C887的实时日历时钟的设计课程设计任务书.doc》由会员分享,可在线阅读,更多相关《基于DS12C887的实时日历时钟的设计课程设计任务书.doc(32页珍藏版)》请在三一办公上搜索。

1、中北大学信息商务学院课程设计任务书学生姓名: 高 升 学 号: 10050644X20 学 院: 信息与通信工程学院 专 业: 电子信息工程 题 目: 专业综合实践之单片机系统部分: 基于DS12C887的实时日历时钟的设计 王浩全指导教师: 职称: 教授 2014 年 1 月 10 日中北大学信息商务学院课程设计任务书 2013/2014 学年第 1 学期学 院: 信息与通信工程学院 专 业: 电子信息工程 学 生 姓 名: 高 升 学 号: 10050644X20 学 生 姓 名: 穆志森 学 号: 10050644X26 学 生 姓 名: 康文忠 学 号: 10050644X46 课程设

2、计题目: 专业综合实践之单片机系统部分 基于DS12C887的实时日历时钟的设计 起 迄 日 期: 2013年12 月30 日2014年1月 10 日 课程设计地点: 5院楼 201,510 实验室 指 导 教 师: 王浩全 下达任务书日期: 2013 年 12 月30日课 程 设 计 任 务 书1设计目的:巩固掌握单片机工作原理及应用提高编程能力2设计内容和要求(包括原始数据、技术参数、条件、设计要求等):掌握单片机89C51的工作原理掌握用汇编、C或其他语言实现编程掌握DS12C887时钟芯片3设计工作任务及工作量的要求包括课程设计计算说明书(论文)、图纸、实物样品等:(1)提供核心器件的

3、工作原理与应用介绍;(2)提供用Protel设计的电路原理图,印刷板电路图;(3)提供用Multisim、MaxPlus、Proteus、Medwin、KeilC等软件对电路的仿真、编程与分析;(4)提供符合规定要求的课程设计说明书;(5)提供参考文献不少于15篇,且必须是相关的参考文献; 课 程 设 计 任 务 书4主要参考文献:l 要求按国标GB 771487文后参考文献著录规则书写,例:1 傅承义,陈运泰,祁贵中.地球物理学基础.北京:科学出版社,1985 5设计成果形式及要求:说明书一份6工作计划及进度:1月7日 1月9日:查资料;1月10日 1月14日:在指导教师指导下设计方案;1月

4、15日 1月17日:在指导教师辅导下完成实验;撰写课程设计说明书; 1月18日:答辩系主任审查意见: 签字: 年 月 日目录一 系统设计的主要内容和设计思路71.1主要内容71.2设计思路71.2.1 日历时钟芯片的选择71.2.2 LED简介8二 硬件电路设计102.1 结构框图102.2 主要器件112.2.1 单片机112.2.2 日历时钟芯片DS12C887152.2.3 1602液晶显示屏172.3 电路原理图及说明192.3.1 控制电路192.3.2 日历时钟电路20三 软件设计203.1 时钟部分软件设计213.1.1 DS12C887的内存空间213.1.2程序流程23四 设

5、计结果244.1基于DS12C887的实时日历时钟显示系统的总程序244.2基于DS12C887的实时日历时钟显示系统总电路图31五 结果分析32六 心得体会32七 参考文献33一 系统设计的主要内容和设计思路 1.1主要内容本次的设计题目是电子万年历设计,要求实现年、月、日、时、分、秒的正常显示,需要硬件和软件的结合来实现。本次设计利用时钟日历芯片DS12887的特性和AT89C51单片机的功能利用实现的。时钟芯片在电源的作用下向通过P2口向AT89C51单片机输入时间信号,AT89C51单片机在接受到时间信号后通过P0将信号送到单片机另一扩展芯片ULN2003,驱动LED数码管显示,同时将

6、信号通过P1口送往单片机的扩展芯片74LS154,当送出第一个段码时,单片机输出的位码是0001,而经过416译码器74LS154后就是1111 1111 1111 1110,这时就选中了第一个数码管显示;当送出第十六个段码时,单片机输出的位码是1111,416译码器输出0111 1111 1111 1111,这时就选中了第十六个数码管显示,从而74LS154将接收到的地址信号译码后动态驱动相应的LED,由于LED数码管的公共端由74LS154分时选通,这样,这样任何一个时刻,都只有一位LED在点亮,也即动态扫描显示方式。根据设计的要求万年历要显示年、月、日、时、分、秒的显示就需要16个显示数

7、码管。根据设计要求,用按键来实现省电和正常显示的切换,当按键按下时进入省电模式,否则正常显示。在明确本次设计思路之后,画出设计框图,总体框图如图所示。 图1.1设计总体框图 1.2设计思路由于系统要实现的功能比较单一(主要就是获取实时时间信息),因此设计思路非常清晰。 1.2.1 日历时钟芯片的选择 根据本次题目要求,本次设计选用达拉斯公司的日历时钟芯片DS12C887作为实时时钟芯片,为系统提供详细的年、月、日、星期和小时、分钟等时间信息。DS12C887实时时钟芯片功能丰富,可以用来直接代替IBM PC上的时钟日历芯片,同时,它的管脚也和MC146818B、DS1287相兼容。由于DS12

8、C887能够自动产生星期、年、月、日、时、分、秒等时间信息,其内部又增加了世纪寄存器,从而利用硬件电路解决了“千年”问题;对于一天内的时间记录,有12小时制和24小时制两种模式。在12小时制模式中,用AM和PM区分上午和下午;时间的表示方法也有两种,一种用二进制数表示,一种是用BCD码表示;DS12C887中带有128字节RAM,其中有11字节RAM用来存储时间信息,4字节RAM用来存储DS12C887的控制信息,称为控制寄存器,113字节通用RAM供用户使用;此外用户还可对DS12C887进行编程以实现多种方波输出,并可对其内部的三路中断通过软件进行屏蔽。 1.2.2 LED简介LED数码管

9、根据LED的接法不同分为共阴和共阳两类,了解LED的这些特性,对编程是很重要的,因为不同类型的数码管,除了它们的硬件电路有差异外,编程方法也是不同的。图图1.2.1(a)是共阴和共阳极数码管的内部电路图,它们的发光原理是一样的,只是它们的电源极性不同而已。将多只LED的阴极连在一起即为共阴式,而将多只LED的阳极连在一起即为共阳式。以共阴式为例,如把阴极接地,在相应段的阳极接上正电源,该段即会发光。当然,LED的电流通常较小,一般均需在回路中接上限流电阻。假如我们将b和c段接上正电源,其它端接地或悬空,那么b和c段发光,此时,数码管显示将显示数字“1”。而将a、b、d、e和g段都接上正电源,其

10、它引脚悬空,此时数码管将显示“2”。其它数字的显示原理与此类同。LED的7段数码管利用单只LED组合排列成“8”字型的数码管,分别引出它们的电极,点亮相应的点划来显示出0-9的数字。在这次的设计中采用的均是共阴极的LED显示,当I/O口输出为高电平的时候,对应段就被点亮。LED数码管的结构图如图1.2.1(b)所示。 (a)(b)图1.2.1 LED分类结构图和结构图 这次设计的显示部分采用AT89C51单片机动态扫描完成,在多数的应用场合中,我们并不希望使用多I/O端口的单片机,原则上是使用尽量少引脚的器件。在没有富余端口的情况下,应通过优化设计程序和扩展电路达到预期的目的。动态扫描的频率有

11、一定的要求,频率太低,LED将出现闪烁现象。如频率太高,由于每个LED点亮的时间太短,LED的亮度太低,肉眼无法看清,所以一般均取几个ms左右为宜,这就要求在编写程序时,选通某一位LED使其点亮并保持一定的时间,程序上常采用的是调用延时子程序。LED显示电路(1)静态显示电路LDE显示器工作在静态显示时,其公共阳极(或阴极) 接VCC(或GND) ,一直处于显示有效状态,所以每一位的显示内容必须由锁存器加以锁存,显示各位相互独立。(2) 动态显示电路 将所有位的段选线的同名端联在一起,由一个8位I/O口控制,形成段选线的多位复用。而各位的公共阳极或公共阴极则分别由相应的I/O口线控制,实现各位

12、的分时选通,即同一时刻只有被选通位是能显示相应的字符,而其他所有位都是熄灭的。由于人眼有视觉暂留现象,只要每位显示间隔足够短,则会造成多位同时点亮的假象。这就需要单片机不断地对显示进行控制,CPU需要不断地进行显示刷新,动态显示电路参见图1.2.2,图1.2.2中是扩展了五位的LED数码管显示,用一个74LS154作为五个LED的段选输入,采用动态显示的方式连接。类似地,16位的LED数码管显示也可以用这种方法来实现。 图1.2.2五位LED数码管的动态显示二 硬件电路设计本设计的硬件电路设计主要是围绕日历时钟芯片DS12C887的使用进行的。 2.1 结构框图本设计的硬件电路包括单片机电路、

13、日历时钟芯片电路和数码管显示输出电路,其结构框图如图1所示。 图2.1 系统硬件结构框图 2.2 主要器件本系统的主要器件是单片机,日历时钟芯片以及LED显示驱动芯片。 2.2.1 单片机单片机选用AT89C51单片机。AT89C51是低电压,高性能CMOS8位单片机,片内含8k bytes的可反复擦写的只读程序存储器(PEROM)和256 bytes的随机存取数据存储器(RAM),器件采用高密度、非易失性存储技术生产,与标准MCS-51指令系统及8051产品引脚兼容,片内置通用8位中央处理器(CPU)和Flash存储单元,功能强大的AT89C51单片机适合于许多较为复杂控制应用场合。AT89

14、C51单片机性能及特点:(1)与MCS-51微控制器产品系列兼容。(2)片内有4KB可在线重复编程的快闪擦写存储器(Flash Memory)。(3)存储器可循环写入/擦除1000次。(4)存储数据保存时间为10年。(5)工作电压范围:Vcc可为2.7V6V。(6)全静态工作:可从0HZ到16MHZ。(7)程序存储器具有3级加密保护。(8)1288位内部RAM。(9)32条可编程I/O线。(10)两个16位定时器/计数器。(11)中断结构具有5个中断源和2个优先级。(12)可编程全双工串行通道。(13)空闲状态维持低功耗和掉电状态保存存储内容。逻辑框图及引脚图分别如图2.2(a)(b)所示 (

15、a) (b)图2.2 AT89C51单片机逻辑框图及引脚图功能特性概述:AT89C51提供以下标准功能:8k字节Flash闪速存储器,256字节内部RAM,32个I/O口线,3个16位定时/计数器,一个6向量两级中断结构,一个全双工串行通信口,片内振荡器及时钟电路。同时,AT89C51可降至0Hz的静态逻辑操作,并支持两种软件可选的节电工作模式。空闲方式停止CPU的工作,但允许RAM,定时/计数器,串行通信口及中断系统继续工作。掉电方式保存RAM中的内容,但振荡器停止工作并禁止其它所有部件工作直到下一个硬件复位。AT89C51单片机内部结构框图如图2.3所示。 图2.3 AT89C51单片机内

16、部结构框图引脚功能说明(1)VCC:供电电压(2)GND:接地(3)时钟电路 XTAL1(19脚)芯片内部振荡电路(单级反相放大器)输入端。 XTAL2(18脚)芯片内部振荡电路(单级反相放大器)输出端。 (4)控制信号RST(9脚)复位信号:时钟电路工作后,在此引脚上将出现两个机器周期的高电平,芯片内部进行初始复位,P0口P3口输出高电平,将初值07H写入堆栈指针。ALE(30脚)地址锁存信号:当访问外部存储器时,P0口输出的低8位地址由ALE输出的控制信号锁存到片外地址锁存器,P0口输出地址低8位后,又能与片外存储器之间传送信息。另外,ALE可驱动4个TTL门。(29脚)片外程序存储器读选

17、通:低电平有效,作为程序存储器的读信号,输出负脉冲,将相应的存储单元的指令读出并送到P0口,可驱动8个TTL门。/Vpp(30脚):当为高电平且PC值小于0FFFH时,CPU执行内部程序存储器程序;当为低电平时,CPU仅执行外部程序存储器程序。(5)I/O接口P0口(P0.0P0.7,3932脚)三态双向口:P0口结构包括一个输出锁存器、两个三态缓冲器、一个输出驱动电路和一个输出控制端。P0口做地址/数据复用总线使用。若从P0口输出地址数据信息,此时控制端为高电平,若从P0口输入数据指令信息时,引脚信号应从输入三态缓冲器进入地址总线,它可驱动8个TTL门。P0P3口上的“读-修改-写”功能,其

18、操作是先将字节的全部8位数读入,再通过指令修改某些位,然后将新的数据写回到口锁存器中。P1口(P1.0P1.7,18脚)准双向口:P1口做通用I/O接口使用,P1口的每一位口线能独立地作用于输入线,P1口可驱动4个TTL门。P2口(P2.0P2.7,2128脚)通用I/O接口:它做通用I/O接口使用时,是一个准双向口,此时转换开关MUX倒向左边,输出极与锁存器相连,引脚可作为用户I/O口线使用,输入/输出操作与P1口完全相同,P2口做地址总线使用。当系统中接有外部存储器时,P2口用于输出高8位地址A8A15,这时在CPU控制下,转换开关MUX倒向右边,接通内部地址总线。P2口的口线状态取决于片

19、内输出的地址信息,这些信息来源于PC、DPTR等。在外接程序存储器中,由于访问外部存储器操作连续不断,P2口不断送出地址高8位。AT89C51单片机的P2口一般只做地址总线使用,不做I/O接口直接连外部设备使用。P3口(P3.0P3.7,1017脚)双功能口:P3口做通用I/O接口使用,输出功能控制线为高电平,与非门的输出取决于锁存器的状态,此时锁存器Q端的状态与其引脚状态是一致的。在这种情况下,P3口的结构和操作与P1口相同。P3口第二功能是可作为系统具有控制功能的控制线,另外P3口可驱动4个LSTTL门电路。P3口:P3口管脚是8个带内部上拉电阻的双向I/O口,可接收输出4个TTL门电流。

20、当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。作为输入,由于外部下拉为低电平,P3口将输出电流,这是由于上拉的缘故。P3口也可作为AT89C51的一些特殊功能口使用如:P3.0 RXD(串行输入口);P3.1 TXD(串行输出口);P3.2 /INT0(外部中断0);P3.3 /INT1(外部中断1);P3.4 T0(记时器0外部输入);P3.5 T1(记时器1外部输入);P3.6 /WR(外部数据存储器写选通);P3.7 /RD(外部数据存储器读选通);2.2.2 日历时钟芯片DS12C887日历时钟芯片选用DS12C887,其引脚分布如图2.4所示。 图2.4 DS12C887

21、引脚分布图DS12C887的内部结构框图如图2.5所示。 图2.5 日历时钟芯片DS12C887内部结构框图由图2.5可知,DS12C887内部可看成由电源、日历时钟信息、寄存器和存储器,以及总线接口四部分构成,四部分配合工作,共同实现芯片的功能。DS12C887的具体引脚功能如下:DS12887内部由振荡电路,分频电路,周期中断/方波选择电路,14字节时钟和控制单元,114字节用户非易失RAM,十进制/二进制累加器,总线接口电路,电源开关写保护单元和内部锂电池等部分组成。DS12887引脚分配如图2.6所示,各管脚说明如下:VCC:直流电源+5V电压。当5V电压在正常范围内时,数据可读写;当

22、Vcc低于4.25V,读写被禁止,计时功能仍继续;当Vcc下降到3V以下时,RAM和计时器供电被切换到内部锂电池。MOT(模式选择):MOT引脚接到Vcc时,选择MOTOROLA时序,当接到GND时,选择Intel时序。SQW(方波信号输出):SQW引脚能从实时钟内部15级分频器的13个抽头中选择一个作为输出信号,其输出频率可通过对寄存器A编程改变。AD0-AD7(双向地址/数据复用线):总线接口,可与Motorola微机系列和Intel微机系列接口。AS(地址选通输入):用于实现信号分离,在AD/ALE的下降沿把地址锁入DS12887。DS(数据选通或读输入):DS/RD引脚有两种操作模式,

23、取决于MOT引脚的电平,当使用Motorola时序时,DS是一正脉冲,出现在总线周期的后段,称为数据选通;在读周期,DS指示DS12887驱动双向总线的时刻;在写周期,DS的后沿使DS12887锁存写数据。选择Intel时序时,DS称作(RD),RD与典型存贮器的允许信号(OE)的定义相同。R/W(读/写输入):R/W引脚也有两种操作模式。选Motorola时序时,R/W是低电平信号时,指示当前周期是读或写周期,DS为高电平时,R/W高电平指示读周期,R/W信号一低电平信号,称为WR。在此模式下,R/W引脚与通用RAM的写允许信号(WE)的含义相同。CS(片选输入):在访问DS12887的总线

24、周期内,片选信号必须保持为低。IRQ(中断申请输入):低电平有效,可作微处理的中断输入。没有中断的条件满足时,IRQ处于高阻态。IRQ线是漏极开路输入,要求外接上接电阻。RESET(复位输出):当该脚保持低电平时间大于200ms,DS12887有效复位。 时间和日历单元时间和日历信息通过读相应的内存字节来获取,时间和日历通过写相应的内存字节设置或初始化,其字节内容可以是二进制或BCD形式。时间可选择12小时制或24小时制,当选择12小时制时,小时字节的高门为逻辑“1”代表PM。时间和日历字节是双缓冲的,总是可访问的。非易失RAM在DS1288中,114字节通用非易失RAM不专用一任何特殊功能,

25、它们可被处理器程序用作非易失内存,在更新周期也可访问。中断RTC实时时钟加RAM向处理器提供三个独立的,自动的中断源。定闹中断的发生率可编程,从每秒一次到每天一次,周期性中断的发生率可从500ms到122s选择。更新结束中断用于向程序指示一个更新周期完成。中断控制和状态位在寄存器B和C中,本文的其它部分将详细描述每个中断发生条件。晶振控制位DS12887出厂时,其内部晶振被关掉,以防止锂电池在芯片装入系统前被消耗,寄存器A的BIT4-BIT6的其它组合都是使用晶振关闭。更新周期DS12887每一秒执行一次更新周期,保证时间、日历的准确。在DS12C887内有11字节RAM用来存储时间信息,4字

26、节用来存储控制信息,其具体地址及取值如表2.1所列。 表2.1 DS12C887的存储功能地址功能取值范围(十进制)取值范围二进制BCD码0秒059003B00591秒闹铃059003B00592分059003B00593分闹铃059003B0059412小时模式112010C AM818C PM0112 AM8192 PM24小时模式023001700235时闹铃,12小时制112010C AM818C PM0112 AM8192 PM时闹铃,24小时制023001700236星期(星期日=1)17010701077日131011F01318月112010C01129年09900630099

27、10控制寄存器A11控制寄存器B12控制寄存器C13控制寄存器D50世纪099NA19,20 2.2.3 1602液晶显示屏 下面是1602字符型LCD引脚接口介绍:图 2.6 1602字符型LCD显示器正反面1602字符型LCD引脚说明:第1脚:VSS为电源地,接GND。第2脚:VDD接5V正电源。第3脚:VO为液晶显示器对比度调整端,接正电源时对比度最弱,接地电源时对比度最高,对比度过高时会产生“鬼影”,使用时可以通过一个10K的电位器调整对比度。第4脚:RS为寄存器选择,高电平时选择数据寄存器、低电平时选择指令寄存器。第5脚:RW为读写信号线,高电平时进行读操作,低电平时进行写操作。当R

28、S和RW共同为低电平时可以写入指令或者显示地址,当RS为低电平RW为高电平时可以读忙信号,当RS为高电平RW为低电平时可以写入数据。第6脚:EN端为使能端,当E端由高电平跳变成低电平时,液晶模块执行命令。第714脚:D0D7为8位双向数据线。第15脚:BLA背光电源正极(+5V)输入引脚。第16脚:BLK背光电源负极,接GND。1602字符型LCD与单片机的连接接口说明如下:(1)液晶1、2端为电源;15、16端为背光电源。(2)液晶3端为液晶对比度调节端,通过一个10K电位器接地来调节液晶显示对比度。首次使用时,在液晶的上电状态下,调节至液晶上面一行显示出黑色小格为止。(3)液晶4端为向液晶

29、控制器写数据/写命令选择端,接单片机的P2.2口。(4)液晶5端为读/写选择端只向其写入命令和显示数据。(5)液晶6端为使能信号,是操作时必须的信号,接单片机的P2.1口。 图2.7 1602LCD电路图 2.3 电路原理图及说明 2.3.1 控制电路图2.8所示为本设计的单片机部分的电路原理图。 图2.8 实时日历时钟显示系统单片机部分电路原理图图2.8中,U1为单片机芯片AT89C51,它工作11.0592MHz时钟。P0端口用作地址/数据复用总线AD07,和日历时钟芯片相连。P1端口用作数码管的段码接口,由于本设计的显示不会出现小数点,因此只使用了a、b、c、d、e、f、g,而没有使用d

30、p(小数点)段。P2端口的P2.7在反相之后为日历时钟芯片提供片选信号,需要反相是因为该片选信号为低电平有效。单片机的P3.7(/RD)、P3.6(/WR)引脚和日历时钟芯片的读、写引脚直接相连,它们均为低电平有效。单片机的ALE引脚将和日历时钟芯片的锁存输入引脚直接相连,作为地址锁存,可实现数据和地址线的时分复用。 2.3.2 日历时钟电路日历时钟芯片部分的电路图。 图2.9 实时日历时钟显示系统片选及日历时钟芯片部分电路原理图图2.9中,日历时钟芯片DS12C887,在本设计中,将其MOT引脚接地,选择Intel总线时序模式。在以Intel总线时序模式工作时,它和51单片机的接口完全兼容,

31、因此将它的地址/数据复用线AD0AD7、锁存输入ALE、读输入DS、写输入和51单片机的对应引脚直接相连。DS12C887的方波输出SQW和中断申请/IRQ在本设计中不使用。三 软件设计软件设计分两部分:时钟部分以及显示部分。 3.1 时钟部分软件设计 3.1.1 DS12C887的内存空间DS12C887的内存空间共128个字节,其中11个字节专门用于存储时间、星期、日历和闹钟信息;4个字节专门用于控制和存放状态信息;其余113个字节为用户可以使用的普通RAM空间。图3.1为日历时钟芯片DS12C887的内存空间映射示意图。 图3.1 日历时钟芯片DS12C887内存空间映射示意图地址0x0

32、0-0x09共10个寄存器分别存放的是秒、秒闹钟、分钟、分闹钟、小时、时闹钟、星期、日、月和年信息,地址0x32为世纪信息寄存器(解决了“两千年问题”)地址0x0A0x0D四个寄存器分别为寄存器A、B、C、D,它们用于控制和存放某些状态信息;其余的113字节地址空间是留给用户使用的普通内存空间。根据此地址映射关系(见图11)和芯片选的设置(由单片机的P2.0端口反相后提供)可以得到每个特定寄存器在程序中的地址,即为0x0100加上图11中的地址偏移。比如,日信息寄存器的地址为0x0107,控制寄存器B的地址为0x010B等。在所有的128字节中,寄存器C和D为只读寄存器,寄存器A的第7位属于只

33、读位,秒字节的高阶位也是只读的,其余字节均为可直接读写字节。时钟、日历信息可以通过读取合适的内存字节获得;时钟、日历和闹钟可以通过写合适的内存字节进行设置或初始化。对应时钟、日历和闹钟的10个寄存器字节可以是二进制形式或者BCD码形式,在写这些寄存器时,寄存器B的SET位必须置1。寄存器A字节的内容如下:MSB LSBUIPDV2DV1DV0RS3RS2RS1RS0UIP:更新(UIP)位用来标志芯片是否即将进行更新。当UIP位为l时,更新即将开始;当它为0时,表示在至少244s内芯片不会更新,此时,时钟、日历和闹钟信息可以通过读写相应的字节获得和设置。UIP位为只读位并且不受复位信号(RES

34、ET)的影响。通过把寄存器B中的SET位设置为1可以禁止更新并将UIP位清0。DV0,DV1,DV2:这3位是用来开关晶体振荡器和复位分频器。当DV0 DV1 DV2=010时,晶体振荡器开启并且保持时钟运行;当DV0 DV1 DV2=11X时,晶体振荡器开启,但分频器保持复位状态。RS3、RS2、RS1.、RS0:作用:1)设置周期中断允许位(PIE);2)设置方波输出允许位(SQWE);3)两位同时设置为有效并且设置频率;4)全部禁止。寄存器B字节的内容如下:MSB LSBSETPIEAIEUIESQWEDM24/12DSESET当SET=0,芯片更新正常进行;当SET=1,芯片更新被禁止

35、。SET位可读写,并不会受复位信号的影响。PIE:当PIE=0,禁止周期中断输出到IRQ;当PIE=1,允许周期中断输出到IRQ。AIE:当AIE=0,禁止闹钟中断输出到IRQ;当AIE=1,允许闹钟中断输出到IRQ。UIE:当UIE=0,禁止更新结束中断输出到IRQ;当UIE=1,允许更新结束中断输出到IRQ。此位在复位或设置SET为高时清0。SQWE:当SQWE=0,SQW脚为低;当SQWE=1,SQW输出设定频率的方波。DM:DM=0,二进制;DM=1,BCD。此位不受复位信号影响。24/12:此位为1时,24时制;为0时,12小时制。DSE:夏令时允许标志。在四月的第一个星期日的159

36、59AM,时钟调到30000AM;在十月的最后一个星期日的15959AM,时钟调到10000AM。寄存器C字节的内容如下:MSB LSBIRQFPFAFUF0000IRQF当有以下情况中的一种或几种发生时,中断请求标志位(IRQF)置高:PF=PIE=lAF=AIE=lUF=UIE=1IRQF一旦为高IRQ脚输出低。所有标志位在读寄存器C或复位后清0。PF:周期中断标志。AF:闹钟中断标志。UF:更新中断标志。BIT0BIT3第0位到第3位无用,不能写入,只读,且读出的值恒为0。寄存器D字节的内容如下:MSB LSBVRT0000000VRT当VRT=0时表示内置电池能量耗尽,此时RAM中的数

37、据的正确性就不能保证了。BIT6 BIT0第0位到第6位无用,只读,且读出的值恒为0。芯片DS12C887的113字节普通RAM空间为非易失性RAM空间,它不专门用于某些特别功能,而是可以在微处理器程序中作为非易失性内存空间使用。 3.1.2程序流程程序流程如图3.2所示。 图3.2 系统程序流程图四 设计结果4.1基于DS12C887的实时日历时钟显示系统的总程序1 主程序 程序清单如下:;-; 定义 DS12887 的地址;-SECOND EQU 6F00H ; 秒寄存器SECOND_ALARM EQU 6F01H ; 秒闹钟寄存器MINUTE EQU 6F02H ; 分寄存器MINUTE

38、_ALARM EQU 6F03H ; 分闹钟寄存器HOUR EQU 6F04H ; 时寄存器HOUR_ALARM EQU 6F05H ; 时闹钟寄存器DATE EQU 6F07H ; 日寄存器MONTH EQU 6F08H ; 月寄存器YEAR EQU 6F09H ; 年寄存器REG_A EQU 6F0AH ; 寄存器 AREG_B EQU 6F0BH ; 寄存器 BREG_C EQU 6F0CH ; 寄存器 CREG_D EQU 6F0DH ; 寄存器 D;-SECOND_BUFFER EQU 51H ;秒缓冲区MINUTE_BUFFER EQU 52H ;分缓冲区HOUR_BUFFER E

39、QU 53H ;时缓冲区DATE_BUFFER EQU 54H ;日缓冲区MONTH_BUFFER EQU 55H ;月缓冲区YEAR_BUFFER EQU 56H ;年缓冲区;-Z8279 EQU 0af01H ;8279 状态/命令口地址D8279 EQU 0af00H ;8279 数据口地址LEDMOD EQU 00H ;左边输入 八位字符显示 ;外部译码键扫描方式,双键互锁LEDFEQ EQU 2FH ;扫描速率LEDCLS EQU 0C1H ;清除显示 RAMLEDWR0 EQU 80H ;设定的将要写入的显示RAM地址;-; 主程序;- ORG 0000H LJMP MAIN ORG 0030HMAIN: ;MOV 51H,#00H ;秒 ;MOV 52H,#30H ;分 ;MOV 53H,#13H ;时 ;MOV 54H,#25H ;日 ;MOV 55H,#11H ;月 ;MOV 56H,#10H ;年 ;MOV SP,#60H JNB P2.1, YYY;按键按下读年月日,按键没有按下读时分秒 LCALL INIT8279 LCALL WRITETIME JJJ: LCALL READTIME LCALL DISPLAY JNB P2.1,III

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 办公文档 > 其他范文


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号