基于I2C总线的键盘驱动的设计与实现
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
基于I2C总线的键盘驱动的设计与实现
随着嵌入式系统的飞速发展,嵌入式PC 在许多领域得到广泛应用。其中
嵌入式键盘作为一种人机交互工具,有着非常重要的作用。通常的键盘设计采
用阵列的设计方式,例如一个含有9 个键值的键盘需要6 个通用I/O 口来实
现通信。键盘的键值越多,需要的通用I/O 口也越多。
I2C(Inter-Integrated Circuit)总线是一种由Philips 公司开发的2 线式串行总线,用于连接微控制器及其外围设备。I2C 总线最主要的优点是其简单性和有效性。由于接口直接在组件上,因此I2C 总线占用的空间非常小。I2C 总线的另一个
优点是,它支持多主控(multimastering),其中任何能够进行发送和接收的设备
都可以成为主总线。一个主控能够控制信号的传输和时钟频率。但在任何时间
点上只能有一个主控。
I2C 的这些特点使得在许多设计中备受青睐,本文所介绍的MAX7347-7349
系列芯片,即是一款I2C 兼容芯片。它将键值扫描等一系列操作封装在芯片内
部完成,CPU 只需要通过I2C 总线与芯片通信,通过向芯片写入一定的命令完
成某些操作。从而简化了键盘驱动的处理。而且由于I2C 支持多主控,因此不
影响系统其他设备的操作。整个过程只需要3 个通用I/O 口与CPU 通信,可
以处理多达64 个键值的响应,有效地节省了通用I/O 口。
2 基本原理
2.1 键盘驱动实现原理
通常的键盘采用矩阵式原理,例如对于一个含20 个键值的键盘,采用4×5
的矩阵阵列,即4 行5 列。其中行和列直接与CPU 的I/O 口相连,4 个I/O 口作为中断I/O 口。一旦外部有键按下,就会产生中断,由于键盘被按下后,
该键对应的行和列被连通,因此根据判断各列对应的I/O 口的电平,可以得
到被按下键的位置,从而采取相应的响应。
本文所采用的MAX7347-7349 系列芯片内部有一个FIFO 队列,他在内部完成按键去抖、扫描键值、按键自动重复,以及某些时刻报警等一系列复杂的操作,而键盘驱动本身是需要通过发送一系列的命令来得到所需要的某些状态值,从而进行相应的操作。
2.2 I2C 总线通信原理
I2C 总线是由数据线SDA 和时钟SCL 构成的串行总线,可发送和接收数据。各种被控制电路均并联在这条总线上,每个电路和模块都有惟一的地址。CPU 会发出地址码用来选址,即接通需要控制的电路。所以,各控制电路虽然挂在同一条总线上,却彼此独立,互不相关。
I2C 总线定义了严格的传输信号来完成一次传输。
开始信号:当SCL 为高电平时,SDA 由高电平向低电平跳变,开始传送数据。
结束信号:当SCL 为低电平时,SDA 由低电平向高电平跳变,结束传送数据。如图1 所示。
注意:SDA 线上的数据状态仅在SCL 为低电平的期间才能改变,SCL 为高电平的期间,SDA 状态的改变会被识别为起始和停止条件。
应答信号:接收数据的IC 在接收到8 b 数据后,向发送数据的IC 发出特定的低电平脉冲,表示已收到数据。CPU 向受控单元发出1 个信号后,等待受控单元发出1 个应答信号,CPU 接收到应答信号后,根据实际情况做出是否继续传递信号的判断。若未收到应答信号,由判断为受控单元出现故障。如图2 所示。
3 具体实现
3.1 接口电路
如图3 所示MAX7347 芯片电路示意图。
其中11 个脚为键盘阵列输入连接到键盘外设,3 行8 列,最多可以控制24 个不同按键。3 个脚与PXA 270 直接通信,INT 为中断脚,按键按下为低电平,SCL 为I2C 兼容串行时钟输入,SDA 为I2C 兼容串行I/O 口。tips:感谢大家的阅读,本文由我司收集整编。仅供参阅!