课程设计(论文)基于单片机的多功能电子时钟的设计.doc
湖南理工学院单片微机原理课程设计报告书题 目: 多功能时间控制器 系 部: 机 电 专 业: 自 动 化 班 级: 03级自动化3班 姓 名: 学 号: 起迄日期:2006年6月19日-2006年6月30日指导教师: 单片微机原理课程设计任务书1课程设计的内容和要求(包括原始数据、技术要求、工作要求等):功能要求:多功能时间控制器能够产生6路独立的时间控制信号;每路都能按如下4种定时模式工作:(1)、定时关机,定时范围:1S30min59S。(2)、定时关机,定时范围:1min30 h 59 min。(3)、定时开机,定时范围:1S30min59S。(4)、定时开机,定时范围:1min30 h 59 min。技术要求:系统停电后,系统定时工作模式信息不会丢失,上电后仍能正常工作;系统安全可靠,不会出现死机现象。定时精度误差,每天<0.1S。操作方便。单片微机原理课程设计任务书2对课程设计成果的要求包括图表、实物等硬件要求:设计硬件系统:说明各部分的工作原理,进行相关元器件的参数选择和计算,用PROTEL画出系统硬件图。(要求提出两个以上的设计方案进行比较论证)系统软件设计:系统功能模块的划分,主要功能模块的流程图。源程序在实验箱上进行仿真调试。撰写系统使用说明书。3主要参考文献:1 赵育良 许兆林.“看门狗”技术在某型相机导航数据接口板中的应用J 国外电子元器件 2005(12)2 刘芳芳 黄会雄 单片机测控系统抗干扰方法的研究与改进J 电子质量 2006.(1)3 姚德法 张洪林 串行时钟芯片DS1302的原理与使用J 信息技术与信息.2006.(1)4 张晓军 罗翔 史金辉 基于时钟芯片的定时控制装置J 现代电子技术 2006(1)5 沈卫红 单片机应用系统设计实例与分析M 北京航空航天大学出版社6 楼苗然 李光辉 51系列单片机设计实例M 北京航空航天大学出版社4课程设计工作进度计划:序号起 迄 日 期工 作 内 容16.196.21进行系统功能分析,查阅相关资料,提出系统初步设计方案。26.226.24硬件系统详细设计,画出详细设计电路图,按排好端口地址。36.256.27软件设计并调试。所有功能在实验箱上实现。46.286.29撰写课程设计报告56.30交设计资料,并答辩。主指导教师日期: 年 月 日目 录1 引言12 单片机概述13 芯片的选择与简介13.1 AT89C-51芯片简介 13.2 8255芯片简介 33.2.1 8255可编程并行接口芯片简介33.2.2 8255A的内部结构 33.2.3 8255可编程并行接口芯片方式控制字格式说明 43.3 时钟芯片12887芯片简介 5 3.3.1 特点 5 3.3.2 管脚名称 5 3.3.3 管脚功能 63.4 共阳极的七段数码管 64 控制器硬件的设计 74.1 多功能时间控制器方案论证 74.2 系统硬件设计 74.2.1 控制器系统流程图 84.2.2 控制器控制线路 95 系统编程信息及内存分布106 使用说明107 总结118 参考文献119 附程序清单1. 引言近年来随着科技的飞速发展,单片机的应用正在不断地走向深入,同时带动传统控制检测日新月异更新。在实时检测和自动控制的单片机应用系统中,单片机往往是随着生活水平的上升,现代家庭拥有多种电器。如冰箱,洗衣机,彩电,空调等等。这些电器的开关总是有一定的规律,所以我们可以对它们进行定时开关设计。本设计把你从这些烦琐的开关小事中解放出来。让你享受更高水平的控制技术给您带来的方便。本系统采用MSC-51系列单片机AT89C51和可编程并行I/O接口芯片8255A为中心器件来设计多功能控制器,实现了对多路电路的开关的控制;显示时间直接通过8255的PA、PB口输出;输入时间和所控制的电路选择有按键控制;系统实用性强、操作简单、显示界面人性化。未来家庭一定是一个自动化程度很高,控制技术得到非常广泛的应用。多功能时间控制器应用领域非常广泛。 2. 单片机概述 单片机是微型计算机的一个重要分支,也是颇具生命力的机种。单片机微型计算机简称单片机,特别适用于控制领域,故又称为微控制器。一块单片机芯片就是具有一定规模的微型计算机系统。 通常,单片机由单块集成电路芯片构成,内部包含有计算机的基本功能部件:中央处理器、存储器和I/O接口电路等。因此,单片机只需要和适当的软件及外部设备相结合,便可成为一个单片机控制系统。单片机经过几代的发展,目前的单片机正朝着高性能和多品种方向发展,它们的CPU功能在增强,内部资源在增多,引脚的多功能化,以及低电压低功耗。目前在智能仪器,工业控制,家用电器,机电一体化。网络通信等领域都应用到了。而我们的十字路口交通灯的控制就是单片机在日常生活中的一个典型的应用。3 芯片的选择与简介3.1 AT89C51芯片简介AT89C51单片机采用40Pin封装的双列直接DIP结构,下图是它们的引脚配置,40个引脚中,正电源和地线两根,外置石英振荡器的时钟线两根,4组8位共32个I/O口,中断口线与P3口线复用。引脚说明如下图(3.1.1): 图(3.1.1)AT89C51的引脚图VCC AT89C51 电源正极输入,接+5V 电压。GND 电源接地端。XTAL1 接外部晶振的一个引脚。在单片机内部,它是一反相放大器输入端,这个放大器构成了片内振荡器。它采用外部振荡器时,些引脚应接地。XTAL2 接外部晶振的一个引脚。在片内接至振荡器的反相放大器输出端和内部时钟发生器输入端。当采用外部振荡器时,则此引脚接外部振荡信号的输入。RST AT89C51 的复位信号输入引脚,高电位工作,当要对芯片又时,只要将此引脚电位提升到高电位,并持续两个机器周期以上的时间,AT89C51 便能完成系统复位的各项工作,使得内部特殊功能寄存器的内容均被设成已知状态。ALE/PROG ALE 是表示允许地址锁存允许信号。当访问外部存储器时,ALE 信号负跳变来触发外部的8 位锁存器 (如74LS373),将端口P0 的地址总线(A0-A7)锁存进入锁存器中。在非访问外部存储器期间,ALE 引脚的输出频率是系统工作频率的 1/16,因此可以用来驱动其他外围芯片的时钟输入。当问外部存储器期间,将以1/12 振荡频率输出。EA/VPP 该引脚为低电平时,则读取外部的程序代码 (存于外部EPROM 中)来执行程序。因此在8031 中,EA 引脚必须接低电位,因为其内部无程序存储器空间。如果是使用AT89C51或其它内部有程序空间的单片机时,此引脚接成高电平使程序运行时访问内部程序存储器,当程序指针PC 值超过片内程序存储器地址(如051/8751/89C51 的PC 超过0FFFH)时,将自动转向外部程序存储器继续运行。此外,在将程序代码记录至8751 内部EPROM、89C51 内部FALSH 时,可以利用此引脚来输入提供编程电压(8751 为2lV、AT89C51 为12V、8051 是由生产厂方一次性加工好)。AT89C51的复位方式可以是自动复位,也可以是手动复位,见下图。此外,EA/Vpp还是一复用脚,Vcc掉电其间,此脚可接上备用电源,以保证单片机内部RAM的数据不丢失。如图(3.1.2):图(3.1.2):PSEN 此为"Program Store Enable"的缩写。访问外部程序存储器选通信号,低电平有效。在访问外部程序存储器读取指令码时,每个机器周期产生二次PSEN 信号。在执行片内程序存储器指令时,不产生PSEN 信号,在访问外部数据时,亦不产生PSEN 信号。P0 P0口(P0.0P0.7)是一个8 位漏极开路双向输入输出端口,当访问外部数据时,它是地址总线(低8 位)和数据总线复用。外部不扩展而单片应用时,则作一般双向IO 口用。P0 口每一个引脚可以推动8 个LSTTL 负载。P2 P2口(P2.0P2.7)口是具有内部提升电路的双向I/0 端口(准双向并行I/O 口),当访问外部程序存储器时,它是高8 位地址。外部不扩展而单片应用时,则作一般双向IO 口用。每一个引脚可以推动4 个LSTL 负载。P1 P1口(P1.0P1.7)口是具有内部提升电路的双向I/0 端口(准双向并行I/O 口),其输出可以推动4 个LSTTL 负载。仅供用户作为输入输出用的端口。P3 P3口(P3.0P3.7)口是具有内部提升电路的双向I/0 端口(准双向并行I/O 口),它还提供特殊功能,包括串行通信、外部中断控制、计时计数控制及外部随机存储器内容的读取或写入控制等功能。其特殊功能引脚分配如下: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 外部随机存储器的读选通,低电平有效3.2 8255芯片简介3.2.1 8255可编程并行接口芯片简介:8255A是一个具有3个8位数据口(即A口、B口、C口,其中C口还可作为两个4位口来使用)的并行输入/输入端口的接口芯片,它为CPU与外部设备提供了TTL电平兼容并行接口。三个数据口均可用软件来设置成输入口或输出口,与外设相连。C口具有按位置位/复位的功能,为按位控制提供了强有力的支持。 8255A具有3种工作方式,即方式0,方式1,方式2。可适应CPU与外设间的多种数据传送方式,如查询方式和中断方式等,以满足用户的各种应用要求。 8255A具有两条功能强、内容丰富的控制命令(方式字和控制字),为用户根据外界条件(I/O设备需要哪些信号线以及它能提供哪些状态线)来使用8255A构成多种接口电路和提供灵活方便的编程环境。8255A执行命令过程中和执行命令完毕之后,所产生的状态可保留在状态字中以便查询。 8255A的C口是一个特殊的端口,除作数据口外,当工作在方式1和方式2时,利用对C口的按位控制可为A、B口提供专门的联络控制信号;在CPU读取8255A状态时,C口可作为方式1和方式2的状态字。 8255A芯片内部主要由控制寄存器、状态寄存器和数据寄存器组成,因此以后的编程主要是对这三类寄存器进行访问。3.2.2 8255A的内部结构8255A内部结构由三部分组成:外设接口部分(通道A、B、C);内部逻辑部分(A组和B组控制电路)和CPU接口部分 (数据总线缓冲器,读/写控制逻辑)。8255A内部结构方框图(3.2.1) 图(3.2.1)8255可编程并行接口芯片有三个输入输出端口,即A口、B口和C口,对应于引脚PA7PA0、PB7PB0和PC7PC0。其内部还有一个控制寄存器,即控制口。通常A口、B口作为输入输出的数据端口。C口作为控制或状态信息的端口,它在方式字的控制下,可以分成4位的端口,每个端口包含一个4位锁存器。它们分别与端口A配合使用,可以用作控制信号输出或作为状态信号输入。3.2.3 8255可编程并行接口芯片方式控制字格式说明:8255有两种控制命令字;一个是方式选择控制字;另一个是C口按位置位复位控制字。其中C口按位置位复位控制字方式使用较为繁难,说明也较冗长,故在此不作叙述,需要时用户可自行查找有关资料。方式控制字格式说明如下图(3.2.2):图(3.2.2) D7:设定工作方式标志,“1”有效。 D6、D5:A口方式选择 0 0 方式0 0 1 方式1 1 ×方式2 D4:A口功能 (1=输入,0=输出) D3:C口高4位功能 (1=输入,0=输出) D2:B口方式选择 (0=方式0,1=方式1) D1:B口功能 (1=输入,0=输出)D0:C口低4位功能 (1=输入,0=输出)8255可编程并行接口芯片工作方式说明: 方式0:方式0是一种基本输入或输出方式,该方式适合于通信双方不需要联络信号(应答信号)的简 单输入/输出场合,CPU可以随时用输入/输出指令对指定端口进行读写操作。 方式1:选通输入输出方式。这时A口或B口的8位外设线用作输入或输出,C口的4条线中三条用作数据传输的联络信号和中断请求信号。 方式2 :双向总线方式。只有A口具备双向总线方式,8位外设线用作输入或输出,此时C口的5条线用作通讯联络信号和中断请求信号。3.3 DS12887时钟芯片3.3.1 特点:·可作为IBMAT计算机的时钟和日历·与MC14681B和DS1287的管脚兼容·在没有外部电源的情况下可工作10年·自带晶体振荡器及电池·可计算到2100年前的秒、分、小时、星期、日期、月、年七种日历信息并带闰年补偿·用二进制码或BCD码代表日历和闹钟信息·有12和24小时两种制式,12小时制时有AM和PM提示·可选用夏令时模式·可以应用于MOTOROLA和INTEL两种总线·数据/地址总线复用·内建128字节RAM14字节时钟控制寄存器114字节通用RAM·可编程方波输出·总线兼容中断(/IRQ)·三种可编程中断时间性中断可产生每秒一次直到每天一次中断 周期性中断122ms到500ms 时钟更新结束中断3.3.2 管脚名称:AD0AD7地址/数据复用总线NC空脚MOT总线类型选择(MOTOROLA/INTEL)CS片选ASALER/W在INTEL总线下作为/WRDS在INTEL总线下作为/RDRESET复位信号IRQ中断请求输出SQW方波输出上电/掉电:当VCC高于4.25V200ms后,芯片可以被外部程序操作;当VCC低于4.25V时,芯片处于写保护状态(所有的输入均无效),同时所有输出呈高阻状态;当VCC低于3V时,芯片将自动把供电方式切换为由内部电池供电。3.3.3 管脚功能:MOT(总线模式选择)当此脚接到VCC时,选用的是MOTOROLA总线时序;当它接到地或不接时,选用的是INTEL总线时序。SQW(方波输出)当VCC低于4.25V时没有作用。AD0AD7(双向数据/地址复用总线)AS(地址锁存)ALEDS(Data Strobe or Read Input) RD当系统选择的是INTEL总线模式时,DS被称作RD。当它有效时表示DS12887正在往总线输出数据。RD信号线在有贮器芯片上被称作OE信号线。R/W(Read/Write Input) WRCS(片选输入) CS当VCC低于4.25V时,DS12887从内部禁止对外部CS的操作。此时时钟和RAM都被保护起来。IRQ(中断请求输出)当中断状态位和对应的中断允许位有效时,IRQ的输出保持为低。复位和读C寄存器都可以清除IRQ中断信号。没有中断时,IRQ呈高阻状态,其他中断源还可以挂接到中断总线上,由于IRQ是漏极输出,所以需要外接上拉电阻。RESET(复位)复位脚对时钟、日历、RAM无效。系统上电时复位脚要保持低电平200ms以上DS12887才可以正常工作。当复位脚为低并且VCC高于4.25V时,以下情况发生: A.周期中断允许(PIE)位清0B.闹钟中断允许(AIE)位清0C.更新完成中断标志(UF)位清0D.中断请求状态标志(IRQF)位清0E.周期中断标(PF)位清0F.当RESET为低时DS12887不可操作G.闹钟中断标志(AF)位清0H.IRQ呈高阻状态I.方波输出允许(SQWE)位清03.4 共阳极的七段数码管数共阳极的七段数码管。如图(3.4.1) 图(3.4.1)VT为双向晶闸管,当门极为高电平时晶闸管导通,该支路指示灯亮;当门极为高电平时晶闸管关断,该支路指示灯灭。4 控制器硬件系统设计4.1多功能时间控制器的方案论证方案一:采用定时装置,将各路信号的定时时间都分别用个自的中断定时装置来控制。这种方法不能满足6路的需求,中断源不够。方案二:三位时间对比法。首先是有一个系统时间,在统一的系统时间下,把将6路信号所定时间的低两位再加上它的高一位(比如说:分与秒的定时,我们再加一个小时位,把他们的个位和十位拆开后的6个数)各存在6个单元中。然后再把系统当前时间拆开后和所定的时间相加,结果放在这6单元中,然后再比较所存时间和系统的当前时间是否一致,当一致时发出动作信号。这个方案的不足之处在于,当定时时间刚好超过最高位的最大时间时,便会产生意想不到的错误。方案三:采用倒计时法,系统上电后,显示器上显示的是系统的当前时间,用户如果要修改这个时间可以按相应的功能键来设置,本设计使用的12887时间芯片,可以提供很精确的时钟时间。当用户按下键盘上的“A”功能键,就可以开始设置开关机时间了。操作方法是:先按“A”键,听到“的”的一声,按数字键“16”,就可以选择六个通道中的其中一个通道,听到“的”的一声,再按功能键“A、B、C、D”,分别代表:方式一、方式二、方式三、方式四,此时就可以设定你想要的定时时间了。各种方式的定时范围分别是:(1)、定时关机,定时范围:1S30min59S。(2)、定时关机,定时范围:1min30 h 59 min。(3)、定时开机,定时范围:1S30min59S。(4)、定时开机,定时范围:1min30 h 59 min。设定好时间后,定时时间会在显示器上显示不动,按“F”键确定就可以了,这时显示器又显示系统的系统时间。当某个通道的定时时间到了后,相应通道的指示灯会被点亮,系统会送出相应的控制信号,非常方便。4.2系统硬件设计选用设备8051单片机一片选用设备:8051单片机一片,8255并行通用接口芯片一片,时钟芯片12887一片,共阳极的七段数码管8个 ,方框图如下图(4.2.1):89C51128878255控制对象控制对象控制对象控制对象控制对象控制对象显示器键盘图(4.2.1)421 系统流程图如下: 开始初始化是否为初次上电初始化并设置系统时间否从片外取系统时间并显示等待有无按键否有铵键,分析取键值,并判断是否为功能键是是功能键吗否选通道,选方式,设定时时间,确定是是422 控制器控制线路图 5 系统编程信息及内存分布1 6路出发信号接P1.0P1.52 12887 发出的时分秒信号 在片外的BF04H、BF02H、BF00H单元内,在片内的25H、26H、27H单元内。经转换成非压缩的BCD码后存在 50H57H 单元内3 DISP子程序的显示时间从50H57H得到,DISP还承担了显示从键盘输入的定时时间(60H67H)、(68H6FH)、(72H7AH)。4 标志位信息KA BIT 24H.6 ;设置键标志位CHANAL1 BIT 21H.0 ;通道1的标志位CHANAL2 BIT 21H.1 ;通道2的标志位CHANAL3 BIT 21H.2 ;通道3的标志位CHANAL4 BIT 21H.3 ;通道4的标志位CHANAL5 BIT 21H.4 ;通道5的标志位CHANAL6 BIT 21H.5 ;通道5的标志位CHA1MOD1 BIT 21H.6 ;通道1下的方式1的标志位CHA1MOD2 BIT 21H.7 ;通道1下的方式2的标志位CHA1MOD3 BIT 22H.0 ;通道1下的方式3的标志位CHA1MOD4 BIT 22H.1 ;通道1下的方式4的标志位CHA2MOD1 BIT 22H.2 ;通道2下的方式1的标志位CHA2MOD2 BIT 22H.3 ;通道2下的方式2的标志位CHA2MOD3 BIT 22H.4 ;通道2下的方式3的标志位CHA2MOD4 BIT 22H.5 ;通道2下的方式4的标志位CHA3MOD1 BIT 22H.6 ;通道3下的方式1的标志位CHA3MOD2 BIT 22H.7 ;通道3下的方式2的标志位CHA3MOD3 BIT 23H.0 ;通道3下的方式3的标志位CHA3MOD4 BIT 23H.1 ;通道3下的方式4的标志位CHA4MOD1 BIT 23H.2 ;通道4下的方式1的标志位CHA4MOD2 BIT 23H.3 ;通道4下的方式2的标志位CHA4MOD3 BIT 23H.4 ;通道4下的方式3的标志位CHA4MOD4 BIT 23H.5 ;通道4下的方式4的标志位CHA5MOD1 BIT 23H.6 ;通道5下的方式1的标志位CHA5MOD2 BIT 23H.7 ;通道5下的方式2的标志位CHA5MOD3 BIT 24H.0 ;通道5下的方式3的标志位CHA5MOD4 BIT 24H.1 ;通道5下的方式4的标志位CHA6MOD1 BIT 24H.2 ;通道6下的方式1的标志位CHA6MOD2 BIT 24H.3 ;通道6下的方式2的标志位CHA6MOD3 BIT 24H.4 ;通道6下的方式3的标志位CHA6MOD4 BIT 24H.5 ;通道6下的方式4的标志位6 使用说明书当用户按下键盘上的“A”功能键,就可以开始设置开关机时间了。操作方法是:先按“A”键,听到“的”的一声,按数字键“16”,就可以选择六个通道中的其中一个通道,听到“的”的一声,再按功能键“A、B、C、D”,分别代表:方式一、方式二、方式三、方式四,此时就可以设定你想要的定时时间了。各种方式的定时范围分别是:(1)、定时关机,定时范围:1S30min59S。(2)、定时关机,定时范围:1min30 h 59 min。(3)、定时开机,定时范围:1S30min59S。(4)、定时开机,定时范围:1min30 h 59 min。设定好时间后,定时时间会在显示器上显示不动,按“F”键确定就可以了,这时显示器又显示系统的系统时间。当某个通道的定时时间到了后,相应通道的指示灯会被点亮,系统会送出相应的控制信号7 总结设计多路时间控制器的关键就是要在软件上难得实现,硬件上是很好实现的。在设计的初始阶段,对设计的方案的筛选进行了科学的研究,最后决定采用倒计时法来完成设计。这个方案设计起来在算法上相对来说要简单点。由于有六路信号要单独控制,这给软件设计带来了很大的困难,理论上来说,只要实现了其中的一路,其它的五路就很好实现了,但在实际设计中,情况并不像想象的那么简单,中间用到了大量的标志位来记录某种操作,如果单独设计某一路在来设计其它五路,那么这么大的程序整合起来后,就会出现很多意想不到的问题,由于像这样的设计经验不足,我在设计中走了很多弯路,以至于在规定的时间内,不能把任务很圆满的完成。不过对这次设计的结果还是很满意,毕竟非常专注地工作了两个星期还是有很大收获的。多路时间控制器的设计完成在市场需求方面前景很广,可以继续研究、设计完善。8参考文献1 赵育良 许兆林.“看门狗”技术在某型相机导航数据接口板中的应用J 国外电子元器件 2005(12)2 刘芳芳 黄会雄 单片机测控系统抗干扰方法的研究与改进J 电子质量 2006.(1)3 姚德法 张洪林 串行时钟芯片DS1302的原理与使用J 信息技术与信息.2006.(1)4 张晓军 罗翔 史金辉 基于时钟芯片的定时控制装置J 现代电子技术 2006(1)5 沈卫红 单片机应用系统设计实例与分析M 北京航空航天大学出版社6 楼苗然 李光辉 51系列单片机设计实例M 北京航空航天大学出版社多功能时间控制器程序清单;* * 主程序 *;* P_A EQU 7C00H ;8255P_B EQU 7D00HP_C EQU 7E00HREG_A EQU 0BF0AHREG_B EQU 0BF0BHREG_C EQU 0BF0CHSECOND_X EQU 0BF00HMINUTE_X EQU 0BF02HHOUR_X EQU 0BF04HSECOND EQU 27H ;秒数据存储单元CMIN EQU 26H ;分数据CHR EQU 25H ;小时数据ADDRESS1 EQU 20H ;输入数据入口地址ADDRESS2 EQU 2BHCS BIT 0BF59HINDATA2 BIT 2FHINDATA1 BIT 24H.7INDATACHA BIT 48HORG 0000H LJMP START ;跳至START执行ORG 0003H RETI ;中断返回(不开中断)ORG 000BH ;定时器T0中断入口地址RETI ;中断返回(不开中断)ORG 0013H ;外中断1中断入口地址RETI ;中断返回(不开中断)ORG 001BH ;定时器T1中断入口地址LJMP INTT1 ;进入定时器中断程序ORG 0023H ;串行口中断入口地址RETI ;中断返回(不开中断)ORG 002BH ;定时器T2中断入口地址RETI ;中断返回(不开中断)ORG 0100H;* START: MOV SP,#68H MOV R3,#08H MOV A,#10H MOV R0,#50H VV:MOV R0,A INC R0 DJNZ R3,VV MOV R3,#08H MOV A,#10H MOV R0,#58H VV01:MOV R0,A INC R0 DJNZ R3,VV01 MOV R3,#08H MOV A,#10H MOV R0,#60H VV02:MOV R0,A INC R0 DJNZ R3,VV02 MOV R3,#08H MOV A,#10H MOV R0,#68H VV03:MOV R0,A INC R0 DJNZ R3,VV03 MOV R3,#08H MOV A,#10H MOV R0,#72H VV04:MOV R0,A INC R0 DJNZ R3,VV04 MOV DPTR,#CON;初始化 MOV A,#88H MOVX DPTR,A MOV DPTR,#CS MOVX A,DPTR CJNE A,#0BBH,PP AJM START2 PP: CLR P1.7 MOV A,#0BBH MOVX DPTR,A CLR INDATACHA ;CLR INDATA LCALL DISP LCALL DL10MS LCALL INPUT_TIME LCALL IN_TIME LCALL DISP LCALL DISP LCALL DL02S LCALL DL02S SETB EA START1: MOV TCON,#01H;IT0边沿方式,初始化125887 MOV IE,#81HMOV DPTR,#REG_BMOV A,#10000000B;禁止更新数据MOVX DPTR,AMOV DPTR,#REG_B;BCD模式,24小时制,允许更新结束中断MOV A,#00010010BMOVX DPTR,AMOV DPTR,#REG_AMOV A,#00100000B;开启振荡,允许计时MOVX DPTR,A START2: CLR P1.7CLR INDATASETB INDATACHALCALL DISP_TIME ;调用显示子程序SS:LCALL DISPLCALL DL10MSLCALL KS11 ;判断是否有键按下,若有,则调用键盘程序JZ SSLCALL VA_KEYMOV A,2AHCJNE A,#0FFH,ENXAJMP START2ENX: LCALL DISP;判断是否为功能键MOV A,2AH CJNE A,#0AH,MMLCALL KEY_AMM:LCALL START2LCALL DISPLCALL VA_KEYLCALL KEY_DATASTEP:SETB EASETB ET1LJMP START1;*; * 键盘程序 *;*VA_KEY: MOV PSW,#00HLCALL KS11;键闭合?JZ VA_KEY;无闭合返回LCALL DL10MS;延时 LCALL DL10MS; LCALL KS11 JZ REOF0 ;无闭合返回 MOV R7,#0EEH;有闭合处理 MOV R5,#04H CLR A MOV R3,A;行 MOV R4,A;列LOOP:MOV DPTR,#P_C MOV A,R7 MOVX DPTR,A;扫描码送PC口 MOVX A,DPTR;读C口 JB ACC.4,KEY0;为1转下一列 SJMP REOF;为0输出返回KEY0:JB ACC.5,KEY1 MOV R3,#01H SJMP REOFKEY1:JB ACC.6,KEY2 MOV R3,#02H SJMP REOFKEY2:JB ACC.7,KEY3 MOV R3,#03H SJMP REOFKEY3:DJNZ R5,NEXT MOV A,#0FFH SJMP EOFNEXT:MOV A,R7 RL A MOV R7,A INC R4 INC R4 INC R4 INC R4 SJMP LOOPREOF:MOV A,R3 ADD A,R4 MOV B,AEOF:LCALL KS11;键松开? JNZ EOF MOV 2AH,B SJMP RETTREOF0:MOV 2AH,#0FFHRETT:RET;* INPUT_TIME