基于51单片机和FPGA的人机交互系统的设计
本文以C8051F020单片机与FPGA互连系统为控制核心,以液晶显示控制器T6963C为例,结合行扫描键盘,简述了一种人机交互功能的设计。
1 系统设计方案
FPGA可在很大程度上扩展单片机的资源,然而人机交互功能仍应尽量减少对单片机及FPGA的资源消耗,以便将更多的片内资源用于其他功能的扩展。采用 FPGA扫描键盘可以节省单片机的资源,同时也能灵活地实现键盘的扩展。而考虑到液晶控制较复杂,依然采用单片机控制
LCD,使LCD的各种功能得到最大程度的利用,其系统框图如图1所示。
2 硬件电路及FPGA接口设计
2.1 总线接口设计
这里采用单片机C8051F020与CycloneⅡFPGA互连的系统。C8051F020器件是完全集成的混合信号系统级MCU芯片,具有64个数字 I/O引脚,与8051完全兼容,而且速度得到了极大提高,70%的指令执行时间为l或2个系统时钟周期,只有4条指令的执行时间大于4个系统时钟周期。 此外,C8051F020系列MCU对CIP-51内核和外设有几项关键性的改进,提高了整体性能,更易于在最终应用中使用。如提供22个中断源、7个复 位源、可编程交叉开关、8位A/D转换器、12位D/A转换器等。
CycloneⅡ系列FPGA将低功耗FPGA的密度规模扩展至68 416个逻辑单元,并提供高达622个可用的I/O接口以及高达1.1 Mb的片内存储单元。CycloneⅡ系列成功实现了高效与低功耗的结合,可用于自动化、通信、视频播放等领域。为兼顾成本问题,本系统采用性价比较高的EP2C8型FPGA作为接口器件。
为使单片机的资源可以得到最大的开发,将单片机的高端口,即P4~P7接入FPGA,并通过FPGA对外部设备进行访问。在FPGA中通过Vel-ilog HDL语言编程实现了3-8译码器,从而实现了对单片机地址总线的扩展。该3-8译码器对LCD以及键盘的键值读取提供使能信号,如图2所示。
2.2 T6963C及其接口设计
T6963C液晶显示控制器多用于小规模的液晶显示器件,常被装配在图形液晶显示模块上,以内藏控制器型图形液晶显示模块的形式出现。
单片机对T6963C有2种访问方式:直接访问与间接访问。直接访问利用三总线以I/O设备访问形式进行控制;间接访问则由单片机提供并行接口,以程序控制时序的方式进行控制。为简化程序,这里采用直接访问方式。
该LCM的FS1引脚用于控制显示字符的字体。FS1为高时,LCD显示6x8字符;FS1为低时,LCD显示8x8字符。经实践,在显示英文与数字 时,6x8字符更为美观;在显示中文字符时,8x8字符更为方便。一般系统采用将FS1接地或接高的方式来固定字体,而本系统采用P2.1对FS进行控 制,通过改变地址实现改变字体的功能,使得界面的显示更灵活。
2. 3 键盘电路设计
键盘是常用的单片机输入设备,分为编码键盘和非编码键盘。键盘上闭合键的识别由专用硬件译码器实现,并产生键编号或键值的称为编码键盘;靠软件识别的称为 非编码键盘。在单片机组成的测控系统及智能化仪器中使用最多的是非编码键盘,本系统设计在FPGA中编程实现3x6键盘的行扫描。
由于按键的机械特性,在闭合和断开的瞬间会伴随着一连串的抖动,键抖动会引起一次按键被误读多次,所以必须进行去抖处理,常用的方法为延时去抖动。 FPGA产生键值之后向单片机发送中断,并等待单片机读取键值。由于人脑反应时间相对较长,键盘中断可以处于相对较低的优先级,因此本文将键盘中断接于外 部中断7。
3 软件设计
软件设计遵循结构化和层次化的设计原则。底层函数直接与硬件沟通,而上层函数直接通过调用底层函数来实现相应功能,从而使上层函数与硬件环境彻底分开。当硬件环境发生变化时,仅修改底层函数便能实现程序的移植。
3.1 液晶驱动模块的编程设计
本模块的底层函数需要实现写控制字、写参数、查忙等功能。由于采用直接访问,写控制字与写参数的函数只需向控制口或数据口的地址送数即可。由于LCD是慢 速器件,因此在每次写控制字及写参数之前都需要进行查忙。T6963C的状态字共有7位有效的状态位,如表1所示。其中STA1~STA3最为常用,一般 情况下可以不需要对STA5~STA7进行杏忙的程序。
3.1.1 液晶驱动模块的初始化
T6963C的最大特点是具有独特的硬件初始值设置功能,显示驱动所需的参数如占空比系数。驱动传输的字节数/行及字符的字体选择等均由引脚电平设置,这 样T6963C的初始化在上电时就已经基本设置完成,软件操作的重心就可以全部用于显示画面的设计上。因此,初始化时仅需根据实际情况设置文本区域和图形 区域的首地址和宽度,以及CGRAM偏置地址、合成方式、光标形状等即可正常使用。
液晶驱动模块的初始化函数如下:
3.1.2 英文及汉字的文本显示
由于英文及数字等常用字符的字模已经固化在CGROM中,因此进行英文的显示时,只需指定显示的地址,再输入该字符对应的标号即可。汉字 的显示与英文的显示类似。然而出于其复杂性,一个汉字需要使用4组点阵才能完整显示。在初始化后将汉字的4部分字模顺序输入CGRAM中,在使用时仅需计 算好每一部分的显示地址即可对汉字进行完美显示。
对于一串英文字符的输入,可以利用字符串的特性进行操作。通过检测‘\0’字符来判断英文字符串的结尾,从而避免了在调用此显示函数时人工计算句子长度的 工作。英文字符的ASCII码值与其在CGROM中对应的标号恰相差0x20,因此仅需简单的减法即可实现标号的转换。此外,在进行英文的连续显示时,使 用了T6963C的数据自动写指令,从而提高了显示效率。
对于一串中文的显示,则仅需通过循环调用单个中文的显示程序进行实现。注意由于C51语言中字符串无法支持中文,因此必须人工计算中文字串的长度并将其作为函数传递给此显示函数。
人机交互 C805lF T6963C FPGA 键盘扫描 相关文章:
- 嵌入式系统中文输入法的设计(03-02)
- 基于Qtopia的嵌入式中文输入法设计 (07-15)
- 数字机顶盒人机交互组件的设计(02-27)
- 基于Qt的自主式水下机器人监控系统设计(03-18)
- 基于Linux和QT/E的软键盘设计(05-18)
- 一种嵌入式显示系统的软件设计及应用(01-08)