.第三章系统总体设计和主要芯片介绍3.1系统总体设计本设计主要由单片机、矩阵键盘、液晶显示器和密码存储等部分组成。
其中矩阵键盘用于输入数字密码和进行各种功能的实现。
由用户通过连接单片机的矩阵键盘输入密码,后经过单片机对用户输入的密码与自己保存的密码进行对比,从而判断密码是否正确,然后控制引脚的高低电平传到开锁电路或者报警电路控制开锁还是报警,实际使用时只要将单片机的负载由继电器换成电子密码锁的电磁铁吸合线圈即可。
系统整体框图如图 3-1所示。
键盘输入模块显示模块复位电路报警电路AT89S52开锁电路密码存储模块图 3-1系统结构框图各模块功能如下:1.键盘输入模块:分为密码输入按键与几个功能按键,用于完成密码锁输入功能。
2.显示模块:用于完成对系统状态显示及操作提示功能。
3.复位电路:完成系统的复位。
4.报警电路:用于完成输错密码时候的警报功能。
5.密码存储模块:用于完成掉电存储功能,使修改的密码断电后仍能保存。
6.开锁电路:应用继电器及发光二极管模拟开锁,完成开锁及开锁提示。
3.2主要芯片介绍3.2.1 AT89S52AT89S52 单片机是一个低功耗,高性能CMOS 8 位单片机,片内含8K Bytes ISP(In-system programmable)的可反复擦写 1000 次的 Flash 只读程序存储器,器件采用 ATMEL 公司的高密度、非易失性存储技术制造,兼容标准 MCS-51 指令系统及 80C51 引脚结构,芯片内集成了通用8 位中央处理器和ISP Flash存储单元,功能强大的微型计算机的 AT89S52 可为许多嵌入式控制应用系统提供高性价比的解决方案[10]。
AT89S52 具有以下标准功能:8k 字节 Flash,256 字节 RAM ,32 位 I/O 口线,看门狗定时器, 2 个数据指针,三个 16 位定时器 /计数器,一个 6 向量 2 级中断结构,全双工串行口,片内晶振及时钟电路。
另外, AT89S52 可降至 0Hz 静态逻辑操作,支持 2 种软件可选择节电模式。
空闲模式下,CPU 停止工作,允许 RAM 、定时器 /计数器、串口、中断继续工作。
掉电保护方式下, RAM 内容被保存,振荡器被冻结,单片机一切工作停止,直到下一个中断或硬件复位为止。
AT89S52 的管脚分布如图 3-2 所示。
图3-2 AT89S52 芯片管脚P0 口为一个 8 位漏级开路双向 I/O 口,每脚可吸收 8TTL 门电流。
当 P1 口的管脚第一次写 1 时,被定义为高阻输入。
P0 能够用于外部程序数据存储器,它可以被定义为数据 /地址的第八位。
P1 口是一个内部提供上拉电阻的8 位双向 I/O 口, P1 口缓冲器能接收输出4TTL 门电流。
P1 口管脚写入 1 后,被内部上拉为高,可用作输入,P1 口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。
P2 口为一个内部上拉电阻的8 位双向 I/O 口, P2 口缓冲器可接收,输出 4 个TTL 门电流,当 P2 口被写“ 1时”,其管脚被内部上拉电阻拉高,且作为输入。
并因此作为输入时, P2 口的管脚被外部拉低,将输出电流。
这是由于内部上拉的缘故。
P2 口当用于外部程序存储器或16 位地址外部数据存储器进行存取时,P2 口输出地址的高八位。
在给出地址“1时”,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,P2 口输出其特殊功能寄存器的内容。
P3 口作为 AT89S52 的一些特殊功能管脚备选功能,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(外部数据存储器读选通)AT89S52 主要特性如表 3-1 所示。
表 3-1AT89S52 主要特性兼容 MCS-51 指令系统8k 可反复擦写 (>1000 次) ISP FlashROM32 个双向 I/O 口 4.5-5.5V 工作电压3 个 16 位可编程定时 /计数器时钟频率 0-33MHz全双工 UART 串行中断口线256x8bit 内部 RAM2 个外部中断源低功耗空闲和省电模式中断唤醒省电模式 3 级加密位看门狗( WDT )电路软件设置空闲和省电功能灵活的 ISP 字节和分页编程双数据寄存器指针3.2.2存储芯片AT24C02AT24C02是美国 Atmel 公司的低功耗 CMOS 型E2PROM,内含 256× 8位存储空间,具有工作电压宽 (2.5~5.5 V)、擦写次数多 (大于 10000次)、写入速度快 (小于 10 ms)、抗干扰能力强、数据不易丢失、体积小等特点。
而且他是采用了I2C总线式进行数据读写的串行器件,占用很少的资源和I/O 线,并且支持在线编程,进行数据实时的存取十分方便。
AT24C02中带有的片内地址寄存器。
每写入或读出一个数据字节后,该地址寄存器自动加1,以实现对下一个存储单元的读写。
所有字节均以单一操作方式读取。
为降低总的写入时间,一次操作可写入多达 8个字节的数据。
I 2C总线是一种用于 IC器件之间连接的二线制总线。
他通过 SDA( 串行数据线 )及SCL(串行时钟线 )两根线在连到总线上的器件之间传送信息,并根据地址识别每个器件。
AT24C02正是运用了 I2C规程,使用主 /从机双向通信,主机 (通常为单片机 )和从机 (AT24C02)均可工作于接收器和发送器状态。
主机产生串行时钟信号(通过SCL引脚 )并发出控制字,控制总线的传送方向,并产生开始和停止的条件。
无论是主机还是从机,接收到一个字节后必须发出一个确认信号ACK 。
AT24C02的控制字由 8位二进制数构成,在开始信号发出以后,主机便会发出控制字,以选择从机并控制总线传送的方向。
管脚描述:SCL 为串行时钟:串行时钟输入管脚用于产生器件所有数据发送或接收的时钟这是一个输入管脚。
SDL 为串行数据 /地址:双向串行数据 /地址管脚用于器件所有数据的发送或接收SDL,是一个开漏输出管脚可与其它开漏输出或集电极开路输出进行线或。
A0、 A1、 A2 为器件地址输入端:当使用 24C02 时最大可级联 8个器件,如果只有一个24C02被总线寻址,这三个地址输入脚 A0 、A1 、A2可悬空或连接到 Vss。
WP为写保护:如果 WP 管脚连接到 Vcc 所有的内容都被写保护只能读当 WP, 管脚连接到Vss 或悬空 ,允许器件进行正常的读 /写操作[12]。
管脚图如图 3-3所示。
.图3-3 AT24C02 引脚图3.2.2 LCD1602显示器现在的字符型液晶模块已经是单片机应用设计中最常用的信息显示器件了。
1602 型 LCD 显示模块具有体积小,功耗低,显示内容丰富等特点。
1602 型 LCD 可以显示 2 行 16 个字符,有 8 位数据总线 D0~D7 和 RS,R/W,EN 三个控制端口,工作电压为 5V ,并且具有字符对比度调节和背光功能。
接口信号说明:1602 型 LCD 的接口信号说明如表3-2 所示。
表 3-2 1602型 LCD的接口信号说明第 1 脚VSS 电源地第 9 脚D2 双向数据线第 2 脚VDD +5V 电源第 10 脚D3 双向数据线第 3 脚VEE 液晶显示偏压信号第 11 脚D4 双向数据线第 4 脚RS 数据 /命令选择端第 12 脚D5 双向数据线第 5 脚R/ W 读 /写选择端第 13 脚D6 双向数据线第 6 脚 E 使能端第 14 脚D7 双向数据线第 7 脚D0 双向数据线第 15 脚BLA背光源正极第 8 脚D1 双向数据线第 16 脚BLK背光源负极主要技术参数:1602 型 LCD 的主要技术参数如表3-3 所示。
.表3-3 1602 型 LCD的主要技术参数显示容量16×2 个字符芯片工作电压 4.5~ 5.5V工作电流 2.0mA( 5.0V)模块最佳工作电压 5.0V字符尺寸2.95 ×4.35(WXH)mm基本操作程序:读状态:令 RS=L,RW=L , E=H输出:D0~D7=状态字读数据:令 RS=H,RW=H, E=H输出:无写指令:令 RS=L,RW=L ,D0~D7=指令码, E=高脉冲输出:D0~D7=数据写数据:令 RS=H,RW=L , D0~D7=数据,E=高脉冲输出:无第四章硬件设计本系统外围电路包括键盘输入部分、密码存储部分、复位部分、显示部分、报警部分、开锁部分组成,根据实际情况键盘输入部分选择4×4矩阵键盘,显示部分选择字符型液晶显示 LCD1602 ,密码存储部分选用 AT24C02 芯片来完成。
其原理图如图 4-1所示。
图 4-1电路原理图4.1键盘输入模块由于本设计所用到的按键数量较多而不适合用独立按键式键盘。
采用的是矩阵式按键键盘,它由行和列组成,也称行列式键盘,按键位于行列的交叉点上,密码锁的密码由键盘输入完成,与独立式按键键盘相比,要节省很多I/O口。
本设计中使用的这个 4×4键盘不但能完成密码的输入还能作特别功能键使用。
键盘的每个按键功能在程序设计中设置。
它与单片机的连接如图4-2所示。
图 4-2键盘输入模块4.2密码存储模块图4-3 所示 AT24C02 的 1、2、3 脚是三条地址线,用于确定芯片的硬件地址。
在AT89S51 试验开发板上它们都接地,第 5 脚和第 8 脚分别为正、负电源。
第 8脚 SDL 为串行数据输入 /输出,数据通过这条双向 I2C 总线串行传送,在 AT89S52 试验开发板上和单片机的 P3.6 连接。
第 6 脚 SCL 为串行时钟输入线,在 AT89S52 试验开发板上和单片机的 P3.7 连接。
SDL 和 SCL 都需要和正电源间各接一个 5.1K 的电阻上拉。
第 6 脚接 P3.5。
AT24C02 中带有片内地址寄存器。
每写入或读出一个数据字节后,该地址寄存器自动加1,以实现对下一个存储单元的读写。
所有字节均以单一操作方式读取。
为降低总的写入时间,一次操作可写入多达8 个字节的数据。
图 4-3密码存储电路.4.3复位部分单片机复位是使 CPU和系统中的其他功能部件都处在一个确定的初始状态,并从这个状态开始工作。
该电路在最简单的复位电路下增加了手动复位按键,在接通电源瞬间,电容 C1上的电压很小,复位下拉电阻上的电压接近电源电压,即RST为高电平,在电容充电的过程中RST端电压逐渐下降,当 RST端的电压小于某一数值后, CPU脱离复位状态,由于电容C1足够大,可以保证 RST高电平有效时间大于 24个振荡周期, CPU能够可靠复位。