基于DS12C887的实时日历时钟的设计课程设计任务书_第1页
基于DS12C887的实时日历时钟的设计课程设计任务书_第2页
基于DS12C887的实时日历时钟的设计课程设计任务书_第3页
基于DS12C887的实时日历时钟的设计课程设计任务书_第4页
基于DS12C887的实时日历时钟的设计课程设计任务书_第5页
已阅读5页,还剩27页未读 继续免费阅读

下载本文档

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

文档简介

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星期(星期日=1131011f01318月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 or

40、g 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 ajmp jjj2年月日的读取和显示显示的子程序yyy: lcall init8279iii: lcall writet

41、imerrr: lcall readtime lcall display1 jnb p2.1,rrr ;按键未释放继续读年月日 ajmp jjj ;按键释放跳转读时分3 8279初始化子程序init8279: push dph ;保存现场 push dpl push acc mov dptr ,#z8279 mov a,#ledmod ;置8279工作方式 movx dptr,a mov a,#ledfeq ;置键盘扫描速率 movx dptr,a mov a,#ledcls ;清除 led 显示 movx dptr,a pop acc ;恢复现场 pop dpl pop dph ret4 时

42、分秒显示子程序程序display: mov a,second_buffer anl a,#0fh mov r5,a mov r4,#0 lcall disled ;显示秒低位 mov a,second_buffer swap a anl a,#0fh mov r5,a mov r4,#1 lcall disled ;显示秒高位 mov r5,#16 mov r4,#2 lcall disled ;显示- mov a,minute_buffer anl a,#0fh mov r5,a mov r4,#3 lcall disled ;显示分钟低位 mov a,minute_buffer swap

43、a anl a,#0fh mov r5,a mov r4,#4 lcall disled ;显示分钟高位 mov r5,#16 mov r4,#5 lcall disled ;显示- mov a,hour_buffer anl a,#0fh mov r5,a mov r4,#6 lcall disled ;显示小时低位 mov a,hour_buffer swap a anl a,#0fh mov r5,a mov r4,#7 lcall disled ;显示小时高位 ret 5 年月日显示子程序display1:mov a,date_buffer anl a,#0fh mov r5,a mov r4,#0 lcall disled ;显示日的低位 mov a,date_buffer swap a anl a,#0fh mov r5,a mov r4,#1 lcall disled ;显示日高位 mov r5,#16 mov r4,#2 lcall disled ;显示- mov a,mont

温馨提示

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

评论

0/150

提交评论