毕业设计(论文)基于图形点阵液晶显示的单片机开发系统的设计.doc
基于图形点阵液晶显示的单片机开发系统的设计 摘 要 单片机开发系统主要是采用ATEML公司生产的AT89C55系列单片机为主控制芯片,显示系统采用图形点阵式液晶,采用键盘管理芯片进行键盘控制,在芯片本身提供的系统资源的基础上,进行了并行总线的扩展,和串行总线的扩展。同时基于此系统作了简单的时钟显示,和A/D,D/A的控制,在作A/D,D/A时主要是基于一语应录放板进行了语音录放的实验关键词: 液晶显示 单片机 AT89c55 开发系统 ABSTRACTThe development system of MCU is primarily based on the main control chip of the series of AT89C51 that is produced by the company of ATMEL. The Manifestation system uses LCD. And using a chip named HD7279A proceeds keyboards. Make the best use of the resource of MCU and expand the collateral bus. Of course this MCU system uses I2C bus to employ parts of an apparatus that accord with I2C bus. At the same time, based on the system, I make the simple clock shows on LCD by using a real time clock chip named DS12C887. I also do an experiment on A/D and D/A .By using a sound system, I make an experiment that record the sound and play. Key phrase: LCD MCU of AT89C55 The development system一 单片机最小系统的硬件设计利用单片机完成复杂系统的设计,一般是基于一定的软硬件平台,在硬件方面,主要是体现在,基于的开发系统,也可以说是事先就有的单片机最小系统的开发平台,如果有了此开发平台,就有如高楼大厦的地基,正是基于这点此次毕业设计首先进行了单片机最小系统的设计,其基本的硬件电路设计如图1。图 1 单片机最小系统设计图 1 的总体设计思想采用了单片机并行总线串行总线的扩展模式。其中单片机最小系统的主控芯片采用了 ATMEL 公司推出的带20 K字节可擦除、可编程Flash程序存储器,256字节的数据存储器的AT89C55。其芯片内含有丰富的硬件资源,带有足够大的程序存储器,这在对液晶进行编程时,可以充分利用程序存储器大的特点,可以得到足够字模的存储空间,而不需要在扩展程序存储器;并且支持 0 33 MHZ 的时钟频率选择范围,可以进一步提高信号的处理速度;并且有足够的输入输出口可以进行外扩展,可以完成设想的大部分电路的开发设计。图 1 中 Y1 晶振( 11.059 MHZ )与 C1C2 组成振荡电路; C4C5R1C6反相器及复位键组成上电复位,和手动复位电路;并通过相应的电路完成并行总线和串行总线的扩展。单片机并行总线扩展硬件实现在本单片机开发系统中,外挂的静态随机存取储存器为 512 k 字节的存储器 HM628512 ,其地址线为 19 条,单片机本身的地址只有 16 条,要驱动 HM628512 就必须进行地址扩展。在图1中采用两片74LS373及一片74LS138来实现,首先U2芯片进行低8位地址与数据的分离,产生 A0A7 低8位地址,同时与A8A14(P2.0 P2.6)组成15位地址,在利用 P2.7A7A6A5A4 控制 74 LS138 与写信号 WR 将高 4 位地址 A16 A18 所存在 U3 上,这样就可以控制HM628512,通过此方法也可以控制更大的存储器(A0 A22)。在实际电路设计中巧妙利用 P2.7 ,A7 区分了不同的器件,在 P2.7位高电平时两片 74 LS138 无效,此时选中随机存取储存器,进行存储,在 P2.7 为低电平时,配以 A7,可以选中不同的 74 LS138 ,进行译码,控制其它的芯片,比如说 A/ D0809D/A0832,或其他芯片。单片机串行总线扩展硬件实现由于并行总线在对外扩展时,占用的口线地址资源比较多,有时在设计时会成生冲突,只给设计者带来了很多不便,由于芯片集成工艺的飞速发展,产生了相应串行协议的芯片,现在常用的主要有一线,二线,三线的控制芯片。所谓一线控制芯片就是地址数据通过一条数据线与微控制器相连接,通过芯片与微控制器之间的固定通信协议,进行数的读写,此类芯片有 DS18B20DS2890 等。二线制芯片应用最广是满足I2C总线接口标准的器件,其中二线分别是时钟线( SCL )数据线( SDA )。三线制是满足 SPI 总线接口的器件,分别是地址线( SDI )数据线( SDO )时钟线( SCLK )。在设计中串行总线主要采用的是 I2C 总线,用 P1 口实现,详细内容将在第四部分讲述,同时单片机提供了串行通信接口( UATR ),可以与个人计算机机进行通信,或几个单片机互联,实现多单片机之间的通信。二 系统资源的初次分配及结构框图 AT89C55 内部资源的分配AT89C55 内部含有 20 K 字节程序存储器,除用来存放号程序代码外,主要是存放液晶显示的数据码,其中包括汉字字模,图形码等;内部还有 256 字节的随机存取储存器,可以进行部分数据的暂存,其中高 128 字节(地址 80 H FFH )只能采用间接寻址的方式,而用使用直接寻址是指访问特殊功能寄存器。系统外部资源的分配外部进行并行地址扩展后主要是挂接了一大的外部数据存储器,这样可以存储数目较大数据,同时利用不同的片选地址控制系统需要的不同功能的芯片,在这次设计中,主要并行芯片有DS12C887,AD0809,ADC0832 。P1口利用P1.6P1.7模拟I2C总线,挂I2C器件,系统主要使用有时钟芯片PCF8563,存储芯片 AT24C256。人机界面接口主要是液晶显示和键盘,其中液晶器件也通过总线方式,进行连接;键盘由于是工作方式是串行的,所以连结在 P1 口,采用键盘管理芯片HD7279A实现键控。系统的结构框图如下: 电路图见附录1MCUAT89C55键盘时钟DS12C887存储器628512I2C AT24C256E2PROMPCF8563复位电路三 最小系统中主要功能模块的介绍 液晶显示模块显示功能是单片机最小系统中必不可少的一部分,显示的方法多种多样,现在常用的有两种方法:一是LED显示,二是LCD显示。在LCD显示应用不普遍时,主要是采用LED显示,但LED显示需要的电流比较大,在系统中功耗比较高,在电池供电的系统中显得有些不适用。随着生产工艺的更新,LCD的价格随之下降,LCD的应用也因为其本身的优点而被广泛的应用。液晶显示器具有体积小、质量轻、功耗低和可靠性高的优点,在便携式电子信息产品中得到了广泛的应用。特别是在电池供电的单片机产品中,液晶模块是首选的显示器件。液晶显示器种类很多,内部结构复杂,但液晶模块的接口比较规范,在使用液晶时,只需要针对液晶模块接口设计接口电路并进行软件编写,就可以达到应用液晶的目的。液晶模块主要有段式、字符式、图形式三种,在不同的应用场合可以选择不同的液晶,由于图形式液晶在借助子模提取软件可以任意的显示汉字和各种图形,故在系统设计时选用了图形点阵式液晶,由长沙太阳人电子有限公司生产的图形点阵式液晶,型号为SMG12864。下面针对此模块进行介绍: 接口信号说明编号符号引脚说明编号 符号 引脚说明 1 VSS电源地12 DB5DATA I/O 2 VDD电源正极 13 DB6DATA I/O 3 VO液晶显示偏压 14 DB7DATA I/O 4 RS数据命令选择端 15 CS1片选IC1信号 5 R/W使能信号 16CS2片选IC2信号 6 EDATA I/O 17 RST复位信号L 7 DB0DATA I/O 18 VEE负电源输出 8 DB1DATA I/O 19 NC空脚 9 DB2DATA I/O20 NC空脚 10 DB3DATA I/O 21 BLA背光源正极 11 DB4DATA I/O 22BLK背光源负极 控制器接口说明 基本操作时序 读状态:输入:RS=L ,R/W=H ,CS1&CS2= H ,E= H 输出:D0D7= 状态字 写指令: 输入:RS=L , R/W=L,D0D7= 指令,CS1&CS2=H ,E= 高脉冲 输出:无 读数据: 输入:RS=H,R/W=H ,CS1&CS2= H,E= H 输出: D0D7= 数据 写数据: 输入:RS=L ,R/W=L ,D0D7= 数据,CS1&CS2=H ,E= 高脉冲 输出:无 状态字说明STA04 未用 STA5 液晶显示状态 1 为关闭 0 为显示 STA6 未用 STA7 读写操作使能 1 为禁止 0 为 允许注:对控制器每次进行读写操作之前,都必须进行读写检测,确保 STA=0 指令说明初始化设置写指令 C0H:设置显示初始行;写指令3 FH:开显示;写指令3EH:关显示; 数据设置控制器内部设有一个数据地址页指针和一个数据地址列指针,用可通过他们访问内部的全部 512 字节随机存取储存器;数据指针的设置:指令 B8H+页码(07)设置数据地址页指针;指令 40H+列码(064)设置数据地址列指针液晶显示模块的读写时序 读操作时序 写操作时序 时间参数表 时序参数符号 极限值单位测试条件最小值典型值最大值E信号周期 tc1000ns引脚 EE脉冲宽度 tpw450nsE上升沿/下降沿宽度tr,tp25ns地址建立时间tsp1140ns引脚 E、RS、CSX、R/W地址保持时间THD110ns数据建立时间(读操作)tD320ns引脚DB0DB7数据保持时间(读操作)Thd220ns数据建立时间(写操作)Tsp2200ns数据保持时间(写操作)Thd210ns SMG128 × 64 的参考连接图如下:总线方式:见图2模拟口线方式:见图3在此系统中采用总线方式连接,见图 1 的液晶显示模块的连接。 图 2 总线方式 图 3 模拟口线方式 液晶显示的实现 硬件实现根据液晶的接口及系统电路,液晶的硬件接口电路如图1,采用总线方式连接,这样连接,对整个系统来说节约了资源,同时在编程方面也提供了良好的接口。 软件的实现软件主要是完成对液晶的初始化,初始化主要包括液晶开显示,清屏,初始化显示行与列,然后调用显示子程序完成图形、汉字的显示。在软件编写,一项重要的工作是制作这合适显示模,在制作提取显示码时,采用了液晶显示码专用提取软件(可以在网站下载到),利用该软件可以得到较为理想的显示码机显示效果。 键盘控制模块简介及应用实现键盘控制有许多不同的方法,在设计中考虑到手边现有的资源采用了键盘管理芯片进行键盘识别管理,键盘管理芯片型号为HD7279A。HD7279 是一片具有串行接口的可同时驱动8位共阴式数码管或只独立的智能显示驱动芯片,该芯片同时还可连接多达 64 键的键盘矩阵,单片即可完成显示键盘接口的全部功能。HD7279A内部含有译码器可直接接受 BCD 码或16进制码,并同时具有2种译码方式,此外具有多种控制指令。同时, HD7279A具有片选信号,可方便的实现多于8位的显示或多于64键接口。芯片特点: 串行接口,无需外围元器件可直接驱动引导 各位独立控制译码/不译码及消隐和闪烁属性 (循环)左移/(循环)右移指令 具有段寻址指令,方便控制独立引导 64键键盘控制器,内含去抖动电路基本电路: 图 4 HD7279 连接电路系统中的芯片应用 HD7279 芯片具有比较强大的功能,而在本电路设计中,只用其键盘的管理功能,在 HD7279 的基本应用电路的基础上作了相应的修改,去掉数码管显示部分,串行接口接在 P1 口上,电路图见5 图 5 键盘电路图功能应用说明及实现 引脚说明引脚名称说明1.2VDD正电源3.5NC空脚 无连接 必须悬空 4VSS接地 6CS片选输入端,此引脚为低电平时,可向芯片发送指令及读取键盘数据。 7 CLK同步时钟输入端 8DATA串行数据输入/输出端 9KEY按键有效输出端,平时为高电平,监测到有效按键便为低电平10-16SGSA段g段a 输出 17DP小数点驱动输出18-25DIG07数码07输出 26CLKO震荡输出端的27RCRC振荡器连接端 28RESET复位端 串行接口与指令HD7279 采用串行的方式与微处理器通信,串行数据从数据引脚送入芯片,并由 CLK 端同步,当片选信号变为低电平后,数据因脚上的数据在 CLK 引脚上的上升沿被写入 HD7279 的缓冲寄存器。HD7279 的指令结构有三种类型:不带数据的纯指令,指令的宽度为8个一点点,即微处理器需要发送8个CLK 脉冲。带有数据的指令,宽度为16个一点点,即微处理器需要发送16个CLK 脉冲。读取键盘数据指令,宽度为16个一点点,前8个为微处理器发送到HD7279的指令,后8个一点点为HD7279返回的键盘代码。执行此指令时,HD7279 的数据端在第9个CLK脉冲的上升沿变为输出状态,并与第16个脉冲的下降沿恢复为输入状态,等待接收下一指令。 串行接口的时序如下: 纯指令 带数据的指令 读键盘指令 键盘的初始化及编程应用在系统中主要是应用其键盘管理功能,首先在上电后,应使键盘复位,即向其写入复位命令(A4H)然后单片机检测键盘中断,在有键按下时,KEY脚以平时的高电平变为低电平,向单片机发出中断,当单片机检测到就进入中断读取键盘数据。其中发送命令子程序:SEND:MOV R6,#08H MOV A,#03H MOV DPTR,#002fH MOVX DPTR,A ACALL L_DELAYS_LOOP:MOV A,RAM MOV C,ACC.7 MOV DAT,C SETB CLK RL A MOV RAM,A ACALL S_DELAY CLR CLK ACALL S_DELAY DJNZ R6,S_LOOP CLR DAT RET接收数据子程序:RECEIVE:MOV R6,#08H SETB DAT ACALL L_DELAYR_LOOP:SETB CLK ACALL S_DELAY MOV A,RAM1 RL A MOV C,DAT MOV ACC.7,C MOV RAM1,A CLR CLK ACALL S_DELAY DJNZ R6,R_LOOP CLR DAT RET延时程序: L_DELAY:MOV R7,#28H DJNZ R7,$ RETS_DELAY:MOV R7,#08H DJNZ R7,$ RET四 I2C总线应用I2C总线的应用非常广泛,在很多的器件上都配有I2C总线接口,使用这些器件时一般都需要通过I2C总线进行控制。由于I2C器件的广泛应用,许多微处理器本就带有标准的I2C接口,而现在用的AT89C55自身不带有I2C总线接口,在实现对I2C器件控制时,主要是根据I2C总线的通信协议,来模拟I2C总线。 I2C总线的特点与应用I2C总线是一种具有自动寻址高低速设备同步和仲裁等功能的高性能串行总线,能够实现完善的全双工数据传输,它在各种总线中使用信号线较少,只有两根线同步时钟线SCL和数据线SDA,因此构成控制系统十分的方便、灵活。I2C总线具有标准的规范及种类较齐全的带有I2C接口的外围器件,如E2PROM,RAM,日历时钟,A/D,D/A等,在各类实际产品中有着广泛的应用。2.I2C总线的基本原理I2C总线只有两根信号线,数据线SDA和时钟线SCL,所有进入I2C总线系统中的设备都带有I2C总线接口,符合I2C总线电器规范的特性,只需将I2C总线上所有节点的串行数据线SDA和时钟线SCL分别与总线的SDA和SCL相连接即可。各节点供电可以不同,但需要共地,另外SDA 、SCL需分别接上拉电阻。当执行数据传送时,启动数据发送并产生时钟信号的器件称为主器件,被寻址的任何器件都可看作从器件,发送数据到总线上的器件称为发送器,从总线上接收数据的器件称为接收器。I2C总线是多主机总线,可以有两个或更多的能够控制总线的器件与总线连接,同时I2C总线还具有仲裁功能,当一个以上的主器件同时试图控制总线时,只允许一个有效,从而保证数据不被破坏。I2C总线的寻址采用纯软件的寻址方法,无需片选线的连接,这样就简化了总线数量。主机在发送完启动信号(STA)后,立即发送寻址字节来寻址被控器件,并规定数据传送方向。寻址字节由7位从机地址D7D1和1位方向位D0组成,当主机发送寻址字节时,总线上所有器件都将该寻址字节中的高7位地址与自己器件的地址比较,若两者相同,则该器件认为被主机寻址,并根据读、写位确定是从发送器或从接收器。连接到I2C总线上的每一个器件都有一个唯一的地址,以区别总线上的其它器件.I2C总线地址统一由I2C总线委员会分配,例如对于E2PROM 芯片规定其高4位D7D4地址是1010 低3位D3D1地址根据芯片引脚A2、A1、A0 的接法而定,若A2、A1、A0 均接地则该器件的7位 I2C总线的数据传输在I2C总线上每传输一位数据都有一个时钟脉冲相对应。注意这里的时钟脉冲不像一般的时钟一样必须是周期性的,它的时钟间隔可以不同。总线备用时(即处于非忙状态),SDA 和SCL都必须保持高电平状态,关闭I2C总线时才使SCL嵌位在低电平。只有当总线处于“非忙”状态时,数据传输才能被初始化。在数据传输期间,只要时钟线为高电平,数据线都必须保持稳定,只有在时钟线为低电平时,才允许数据线上的电平状态变化。在时钟线保持高电平期间,数据线出现下降沿为启动信号,上升沿为停止信号,启动和停止信号都由主机产生,总线上带有I2C总线接口的器件很容易检测到这些信号。I2C总线数据传输时必须遵循规定的数据传送格式如图3.1,所示启动信号表明一次传送的开始,其后为寻址字节,该寻址字节由高7位地址和最低1位方向位组成,方向位为“0” 表明主机对从机的写操作,为“1”表示读操作,接下来是从器件给出的应答位,然后依次是由方向位指定读、写操作的数据字节与应答位,在数据传送完成后为停止信号。其中在起动与停止信号之间传输的数据字节数由主机决定,字节数理论上没有限制,一般具有I2C接口的器件都设置有对内部单元地址操作时的自动加减功能,主机可以连续操作多个单元。注:第1组17为从器件地址(SLAW)8为读/写标志 9应答位 后面18为数据 图3.1 I2C总线的数据传输I2C总线上的应答信号是比较重要的,在编制控制程序时应该着重考虑.I2C 总线上每传送一个字节数据后,SDA 都必须有应答信号,此时主机的SCL 应产生一个与这个应答位相对应的额外的时钟脉冲.接收器输出低电平为应答信号(ACK), 输出高电平为非应答信号(A/C/K/). 发送器应在第9个时钟位上释放数据线,使其处于高电平状态,以便接收器在这一位上送出应答信号.当从机为接收器时,若由于某种原因不能产生应答时,必须释放总线,以便主机产生一个停止信号来终止总线数据的传输;当主机为接收器时,接收到最后一个数据字节后,必须发送一个非应答位(A/C/K/),使从发送器释放数据线,以便主机发送停止信号来终止数据的传输.下面介绍三种常用的数据传送格式. 主控器的写操作 主控器向被寻址的被控器件发送n个数据字节,整个传输过程中数据传输过程中数据传送方向不变。其数据格式如下S SLAW A data1 A data2 A datan-1 A datan A/|A P其中 黑体:主控器发送,被控器接收 非黑体:主控器接收,被控器发送A 应答信号 |A 非应答信号 S 起始信号 P 停止信号 SLAW 寻址字节(写)data1datan写入被控器的n个数据字节。 主控器的读操作 主控器从被控器中读出n个字节的操作,整个传输过程中除寻址字节外,都是被控器件发送,主控器件接收。数据格式如下:S SLAR A data1 A data2 A datan-1 A datan |A P其中 黑体:主控器发送,被控器接收 非黑体:主控器接收,被控器发送data1datan 被控器件读出的n个字节主控器件发送停止信号前应发送非应答位,向被控器表明读操作结束。 主控器的读写操作在一次数据传输过程中需要改变传送方向的操作,这时,起始信号和寻址字节都会重复一次,但两次读写方向相反。数据传输格式如下:S SLAW/R A data1 A data2 A datan A/|A SR SLAR/W A DATA1 ADATA2 A DATAN A/|A P其中:SR 重复起始位图中未标注数据字节的传送方向,其方向决定于寻址字节的方向。单片机与I2C总线连接的硬件实现 单片机的使用种类比较多,有些单片机自身带有I2C总线接口,这样就可以把带有I2C接口的器件直接接到I2C总线上就可以,在此设中采用的AT89C55芯片自身没有I2C接口,它类型的单片机也有好多没有I2C接口,但可以根据I2C总线上的传输协议来模拟I2C总线,其硬件连接十分简单,有单片机的P1口上任意两条口线,连接SCL,SDA即可,但须注意影子总线上加相应的上拉电阻,其连接如图4.1,主要连接器件有AT24C256,PCF8563 图4.1 I2C 总线硬件连接 模拟I2C总线软件的实现对标准的I2C总线的数据传送,规定了严格的时序要求,以保证数据传送的可靠性。再用单片机实现I2C总线协议时,就是按照I2C总线的时序进行数据的传输。由于模拟I2C总线有比较完整的软件包,这里不再重复,软件包见附录三 实验应用的I2C器件简介在此毕业设计中,主要应用的I2C器件是AT24CXX系列的E2PROM,和时钟芯片PCF8365。 AT24CXX系列E2PROM AT24CXX系列EEPROM为I2C总线存储器,具有I2C总线的单片机,编程较简单,如果无I2C总线接口的单片机,只要具有两个I/O口均可用模拟软件的方法对其进行读写,编程较复杂。以24C01为例,工作原理如下: .写方式:先向24C01发出一个1-0的起始信号,根据访问的地址发送一个1010XXX0信号,如果是24C01,XXX全为0000,因为24C01地址空间为00H-7FH。注意是逐位送出的。然后等待24C01(SDA)上的应答信号,低电平有效。 如果没有收到应答信号,继续发送开始信号。得到应答,根据访问的地址单元发送地址信号(8bit),也需检测应答信号。再发送数据信号,将数据(8bit)写入24C01中,也查询应答信号。收到应答信号后发送停止信号0-1。.读方式: 发送起始信号1010XXXX,检测应答信号,先虚写。根据访问的地址发送一个地址信号,检测应答。再送访问的读信号1010XXX1 (8bit),检查应答。再发送起始信号,检测应答通过SDA和时钟SCL逐位读出8bit数据。送出停止信号。 时钟芯片PCF8563PCF8563是Philips公司推出的一款带I2C总线具有极低功耗的多功能时钟/日历芯片,具有四种报警功能和定时功能;内部时钟电路、内部振荡电路、内部低电压检测以两线制I2C总线通信方式,不但使用外围电路简洁,而且增加了芯片的可靠性。PCF8563的SCL为时钟输入端,数据随时钟信号同步输入器件或从器件输出;SDA为双向引脚,用于串行数据的输入输出;INT是中断信号输出端,可通过设置报警寄存器按指定时间在该脚产生报警信号,低电平有效;SDA、SCL、INT均为漏极开路,必须上拉电阻;X1、X2分别为反相放大器的输入、输出端;可在X1端接入32.768kHz的石英晶振,配置成片内振荡器。本系统PCF8563与89C51接口采用图4.1所示接口方案。按I2C总线规约,PCF8563的从地址:读地址SLAR为A3H、写地址SLAW为A2H,PCF8563 I2C通信实现有字节写/读两种状态。适用80C51的虚拟I2C总线软件包。本系统直接调用该I2C总线软件包的数据读写子程序(其中WRNBYT为N字节的子程序,RDNBYT为读取N字节的字节),来实现PCF8563的I2C总线操作。内部寄存器表1 寄存器概况地址寄存器名称位7位6位5位4位3位2位1位000H控制/状态寄存器1TEST 0STOP 0TESTC 0 0 001H控制/状态寄存器20 00TT/TP AF TFAIETIE0DHCLKOU 输出寄存器FE FD1FD00EH定时器控制寄存器TE TD1TD0OFH定时器倒计数数值寄存器定时器倒计数数值(二制)表2 BCD格式寄存器概况地址寄存器名称位7位6位5位4位3位2位1位002H 秒VL0059BCD码格式数03H 分 0059BCD码格式数04H 时 0023BCD码格式数05H 日 0059BCD码格式数06H 星期 0607H 月/世纪 C0112BCD码格式数08H 年0099BCD码格式数09H分钟报警AE0059BCD码格式数0AH小时报警AE0023BCD码格式数0BH日报警AE0131BCD码格式数0CH星期报警AE06五 基于开发系统的系统试验调试及软件实现在单片机系统设计完成后,在此开发系统的系统上,做了一系统试验,主要是时钟的实时显示,及借助语音录放板作了语音录放。系统试验介绍 时钟显示时钟显示的实现主要是应用了实时时钟芯片DS12C887,芯片DS12C887是美国Dallas公司推出的一款优秀的时钟芯片,具有下列主要技术特点: 具有完备的时钟、闹钟及到2100年的日历功能,可选择12小时制或24小时制时,有AM和PM、星期、夏令时间操作,闰年自动补偿等功能。 具有可编程选择的周期性中断方式和多频率输出的方波发生器功能。 DS12887内部有14个时钟控制寄存器,包括10个时标寄存器,4个状态寄存器和114bit作掉电保护用的低功耗RAM。 由于该芯片具有多种周期中断速率时钟中断功能,因此可以满足各种不同的待机要求,最长可达24小时,使用非常方便。 时标可选择二进制或BCD码表示。正是因为其优越的特性在系统试验中,时钟芯片采用了此款芯片,同时在应用I2C总线器件时,也选用了一款时钟芯片PCF8563,在软件中编写了此部分程序,时间通过液晶显示,两芯片的时间显示通过按键可以进行互换,同时可以通过键盘实现时间的人工设定及修改。 语音录放的实现语音录放主要是借助具有音频采集功能及音频输出功能的电路来完成的,其中语音录放电路主要是应用A/D,D/A芯片配合滤波器,放大电路来实现的,A/D,D/A分别采的是AD0809,ADC0832。通过单片机开发系统板的控制接口实现语音的采集,语音的回放,在录音时,得到的语音数据暂时存放在开发板的存储器里,如果采样速率在8KHZ左右时,可录音时间为60秒左右。 系统试验调试及软件实现 硬件的调试硬件电路的制作与调试完成一项设计非常重要的一环,设计前期主要是电路原理图的设计及印刷电路板的设计,这里采用的主要设计软件是Protel 99se,在完成此项制作,在电路板制作好后,接下来的任务是焊接和测试,焊接是手工的,同时在配合软件调试时,又发现一些不合理的地方,并在原先的设计基础上作适当的修改。 软件的调试软件的调试主要是测试软件的编写,由于时间的急迫,同时在指导老师的建议,此次测试软件的编写采用了单片机通用的汇编语言,测试程序主要包括液晶显示,时钟芯片应用,单片机模拟I2C总线程序(主要是两个I2C器件的应用)。由于主要的显示器件采用的是液晶,所以所用要显示的内容均得通过液晶进行显示,由此可见显示程序是主要的部分。由于各部分程序都比较大下面仅就编程思想进行以下介绍: 显示程序在前面讲过液晶的显示主要包括汉字的显示及图形的显示,在这里把所用的显示均看作图形的显示,基本想法是因为液晶的显示点数是128×64,也就是横坐标可显示128点,纵坐标可显示64点,又由于此液晶的显示模式为纵向到向显示,也就是说如果汉字显示是16×16的话就是一屏可显示4行每行8个汉字,所以在显示汉字的时候可以在纵向点数(16点,即两个字节)不变的情况下,改变宽度,而图形显示的时候是按照16×128显示,也就列数固定而改变纵向的行数,但只能每8位的改变。在程序的编写时,首先根据液晶的电路连接和液晶的初始化要求进行初始化,然后把需要显示的内容利用显示模提取软件提取出显示码,根据具体的情况进行显示。程序主要包括液晶的初始化,即开显示向命令寄存器写3EH;显示出示行设置,向命令寄存器写C0H;然后根据显示内容,初始化显示行列汉字或图形的显示码进行显示。 控制程序 控制在此设计中,主要是利用键盘实现对事件的修改,和功能之间的互换。而键盘的控制采用了键盘管理芯片HD7279,这里只需根据中断读进键码值,根据不同的键值进行不同的显示和工作 时钟程序时钟芯片有两个一是DS12C887和PCF8563,其中PCF8563具有I2C总线接口故其软件实现可以借助于通用的I2C程序软件包(见下文),这里主要介绍DS12C887的编成。DS12C887内有电池掉电后还可工作,具有其特定的优势,在开机上电时,首先读取DS12C887的时钟数据,并进行显示,如有时间不准确,则进行修改。主要编成有:芯片的初始化,包括时间的初始化(这里指时间的初设定,由软件实现)和指令寄存器的相应设定(芯片的详细资料见附录4),其中指令寄存器的设定主要包括显示模式的设定和时钟芯片的启动 I2C总线程序开发系统应用的微控器本身没有I2C接口,但本身有I/O口,所以可以借助于I/O来模拟I2C总线,I2C总线程序主要是依照I2C总线协议来模拟,其具体软件包见附录2,其中主要包括九部分:发送起始位,发送停止位,发送应答位,发送非应答位,应答位检测子程序,发送一个字节子程序,向被控器件发送n个字节数据子程序(WRNBYT),从SDA上接收一个字节数据子程序(RDBYT),从SDA上接收n个字节数据子程序(RDBYT)。毕业设计总结单片机系统在开发应用中,发挥着其无以伦比的优势,一个好的开发平台可以使开发比较简单,此次毕业设计设计单片机系统正是开发了一个比较实用的平台,现在越来越多的显示采用液晶,故在设计中显示系统采用了液晶显示,显示时取得较好的画面效果,使人机对话界面更加友好;虽然液晶的显示程序的编写比较麻烦,但加上一些辅助的软件,写出一些比较实用的子程序后,再主程序里调用,就显得游刃有余。在这次毕业设计中,自己涉足了以前没有涉及的领域,比如I2C总线等,第一次接触一些芯片,及一些软件的应用,在设计开发中,自己能在老师同学的帮助下,自己动手完成,通过动手学到不少的知识,在学习新知识的同时也加强了对单片机的再了解,受益匪浅。在作毕业设计期间,毕业设计指导老师姜威老师给予大力帮助与支持,同时院领导、其他任课教师及本班同学也给我了不少帮助,在这里表示感谢。相关网址及主要参考书目:I2C总线应用系统技术 何立民 北京航空航天大学出版社嵌入式实时操作系统Small