基于ARM的矩阵键盘设计及其linux驱动实现

2020-10-19来源: elecfans关键字:ARM  矩阵键盘  linux驱动

  1.引言

  ARM微处理器已广泛应用于工业控制、消费类电子产品、通信系统等领域。矩阵键盘是一种常用的键盘形式,它将按键设计成M行N列,这样共需M+N根信号线,却可驱动M&TImes;N个按键,大大节约了I/O资源。本文介绍了一种利用TQ2440开发板的GPIO口扩展5&TImes;4矩阵键盘的方法,并将所有按键重新布局成手持终端的键盘形式,方便操作。


  2.硬件设计

  本设计扩展5行4列的矩阵键盘,如图1所示。其中行线ROW1-ROW5连接S3C2440的中断引脚EINT8,EINT9,EINT11,EINT13,EINT14[1]。这些中断引脚本身连有10kΩ的上拉电阻,把中断引脚电平拉高,确保按键空闲时不会触发中断。列线COL1-COL4连接S3C2440的普通I/O口GPF3,GPF4,GPG7,GPG10.这里需要注意的问题是:确保行线所用的中断在Linux的其他设备中均未使用到,否则会引起该驱动程序或其他驱动程序初始化失败。

  5行4列的矩阵键盘电路原理图

  考虑到手持终端设备按键的常用性与操作的方便性,只取矩阵键盘的前18键,并将它们重新布局为图2的形式。其中Ent键具有二重功能,即确认功能(短按)和开关机功能(长按),此功能将在驱动程序中实现。

  键盘布局

  3.矩阵键盘的Linux驱动程序设计

  3.1 键盘驱动总体概述

  驱动程序是操作系统内核和硬件设备之间的接口。设备驱动程序为应用程序屏蔽了硬件的细节,使应用程序可以像操作普通文件一样操作硬件设备[2]。驱动程序没有main函数,它以一个模块初始化函数作为入口,并且它完成初始化之后不再运行,等待系统调用。


  驱动程序是linux内核的一部分,所以在程序编写上要采用linux的表达方式。首先将列I/O端口定义为数组:col_table [] ={ S3C2410_GPF3,S3C2410_GPF4, …},行I/O端口定义为结构型:

  button_irqs [] ={ {IRQ_EINT8,S3C2410_GPG0,S3C2410_GPG0_EINT8, 0,“R1″},

  {IRQ_EINT9,S3C2410_GPG1,S3C2410_GPG1_EINT9, 1,”R2″},

  …}。//中断号(irq),引脚(pin),引脚设置,序号,名称

  矩阵键盘是作为Linux的一个字符设备注册到系统中的。我们首先向系统注册矩阵键盘设备,包括设备号,设备名及file_operaTIons结构体;file_operaTIons结构体的成员函数是字符设备驱动程序设计的主体内容,这些函数实际会在应用程序进行Linux的open()、write()、read()、close()等系统调用时最终被调用[3]。用户对键盘没有写操作,其file_operations结构体的成员函数为open()、read()、close()、poll()。


  中断的注册和行列初始化在打开键盘时(即open()函数中)实现。注册中断包括:中断号,中断入口程序,中断方式,中断名和代号。关键语句为:request_irq(button_irqs[i].irq,buttons_interrupt,IRQ_TYPE_EDGE_FALLING,button_irqs[i].name,(void*)&button_irqs[i])。IRQ_TYPE_EDGE_FALLING意思为下降沿触发。然后再进行行列初始化:设置行线为中断,使能上拉,在linux中其表达方式为:

  s3c2410_gpio_cfgpin(button_irqs[i]。

  pin,S3C2410_GPIO_SFN2); //设置第i行引脚为中断

  s3c2410_gpio_pullup(button_irqs[i]。

  pin,1); //第i行引脚上拉

  设置列线为输出,置低电平。语句表达同理,由于篇幅所限,这里不再一一列出。

  read()函数实现从设备中读取数据。该函数实现无按键按下时程序进入休眠,关键代码:

  static DECLARE_WAIT_QUEUE_HEAD(button_waitq); //生成一个等待队列头队列,名为button_waitq

  static volatile int ev_press = 0;//置1,表示有键按下

  ev_press为0时执行语句:wait_event_interruptible(button_waitq,ev_press),程序即进入休眠。ev_press为1时把数据从内核空间复制到用户空间,关键语句:

  copy_to_user(buff,(const void *)key_values,min(sizeof(key_values),count));//buff为用户空间的指针,key_values为内核空间指针,最后一个参数为从内核空间向用户空间拷贝数据的字节数,我们取实际大小与用户指定大小中的最小值。数据复制成功时返回零;出错时返回没有复制成功的数据字节数。

  close()函数实现关闭矩阵键盘设备,释放已注册的中断,关键语句:free_irq(button_irqs[i].irq,(void *)&button_irqs[i])。

  Poll()函数实现轮询,如果没有按键数据,调用linux的poll_wait函数等待;如果有按键数据,则select函数会立刻返回。


  3.2 中断处理及键盘扫描程序

  中断处理函数的名称为上面注册的buttons_interrupt.具体程序流程如图3所示。当有按键按下时,该键所在行列导通。列的低电平将该行电平拉低,进而触发中断。然后,进入中断处理函数。由于按键存在抖动的问题,单靠一次中断的触发就判定有按键按下是不可靠的,所以采用定时器延时10ms后再进入键盘扫描函数。

  键盘扫描程序流程图

  本设计的键盘扫描程序采用先确定行再确定列的方法,最后对行列进行一定的运算即得键值。首先确定行:逐行扫描,判断是否有行引脚为低电平。若有,保存该行值(row)。继续确定列:逐列置低电平,当该列为按下所在列时,才会使该行再次为低电平,从而确定列(column)。再对行列进行运算:k=row*4+column,则将矩阵键盘的每一键对应为键号0-19.键盘布局为图2所示形式后,我们只取矩阵键盘的前18键(键号0-17),键值保存为k+1.对于Ent键,通过按下的时间长短区分是确定功能还是开关机功能,按下时间小于0.5秒为确认功能,按下时间大于1.6秒为开关机功能,时间在0.5秒-1.6秒的视为无效操作。计时方法为:

  若该行仍为低电平且整数cnt小于1700:延时1ms,cnt++;根据cnt值即得按下时间。

  开关机功能保存为第18键号,键值19.


  4.驱动程序的测试

  测试程序属于上层应用程序,直接调用键盘驱动程序提供的接口即可实现度键盘的操作。我们调用open()函数实现矩阵键盘设备的打开,再调用read()函数即可将键盘数据读取出来并保存到自己定义的数组中,最后使用printf()函数将测试结果显示出来。

  功运用到笔者的项目中,键盘输入的正确率和反应时间均符合设计要求。


  5.总结

  本文介绍了一种直接从ARM的I/O口扩展矩阵键盘的方法,它无需增加其它接口元器件,设计快速实用,并实现了在Linux系统下的驱动,为ARM嵌入式设备扩展手持终端式键盘提供了一种解决方案。

关键字:ARM  矩阵键盘  linux驱动 编辑:什么鱼 引用地址:http://news.eeworld.com.cn/mcu/ic513592.html 本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:基于UDP协议的ARM与X86平台之间的通讯方案
下一篇:基于ARM的汽车射频识别防盗系统的设计方案

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

苹果自研Arm处理器性能值得期待吗?
11月10日苹果的特别活动快要到了,在此活动上苹果大概率会发布搭载苹果自研Arm处理器的MacBook。而这颗苹果自研Arm处理器——或许会被称为A14X Bionic的性能,已经被曝光了。Expreview超能网引外媒报道,在Geekbench 5上发现了这颗A14X的跑分情况,显示该处理器的基础频率为1.8GHz,并且频率可以最高自己上到3.1GHz,它是一个8核处理器,并且GPU部分包含8GB的显存。从数据来看,A14X的单核基准测试得分为1634,而A12Z的得分为1118,A14的单核测试得分为1583,所以说相较A14,新的MacBook上的Arm处理器单核性能提升不大,毕竟单核性能的提升难度是很大的。多核方面
发表于 2020-11-08
Arm Ethos-U65 microNPU对边缘计算市场意味着什么?
本文作者:NXP边缘处理的技术总监、系统架构师和总工程师Ben Eckermann2020年10月19日,Arm宣布了Ethos-U65 微型NPU。NPU是一个神经处理单元,microNPU顾名思义是一个非常小的NPU,通常针对面积受限的嵌入式和物联网设备。早在2020年2月,NXP就宣布了选择Ethos-U55 microNPU作为Cortex-M系统。Ethos-U55是专为微控制器设计的,与Cortex-M处理器以及MCU中的系统SRAM和flash协同工作,以提供MCU客户所需的性能和效率的结合。但Ethos-U55并不一定适合于在基于Cortex-A的应用处理器上运行的本地复杂ML应用程序。通过我们与Arm的技术合作
发表于 2020-11-06
<font color='red'>Arm</font> Ethos-U65 microNPU对边缘计算市场意味着什么?
解析瑞萨新款MCU RA6M4三大特点
本文作者:瑞萨高级工程师 Stefan Ingenhaag随着最新一代RA系列MCU发布,将帮助您完成最新的创意和理念。基于最新一代Armv8-M体系结构的最先进的Arm Cortex-M33内核、卓越的嵌入式闪存、尖端的安全性、强大的性能和一流的外围IP,所有这些都高度集成在一颗MCU中,并具有最佳易用性,以确保产品快速上市。1更小的BOM和PCB尺寸RA系列以其独特的集成度降低系统成本。集成的安全元素只是众多示例中的一个,内部闪存可以取消对外部EEPROM的需求,高精度片上振荡器无需外围晶振,MCU采用宽输入电压范围的单轨电源工作。利用这些特性可减少许多外部组件和GPIO,从而能够选择更小的封装,减少PCB尺寸和BOM成本
发表于 2020-11-05
解析瑞萨新款MCU RA6M4三大特点
ARM中国闹剧:英伟达400亿收购交易的主要阻碍
据报道,英伟达计划以400亿美元收购英国芯片设计公司Arm。但这笔交易在中国面临着新的难题。据报道,Arm的中国合资公司首席执行官吴雄昂(Allen Wu)持有该合资公司17%的股份。根据公司注册文件,吴雄昂于去年11月接手了一家关键投资公司,目前控制着Arm中国六分之四的股东。吴雄昂控制的两家公司已在深圳提起诉讼,指控Arm和其在合资公司的主要合伙人(私募股权公司厚朴投资)在6月份将其非法免职。目前,吴雄昂仍管理着Arm中国的日常运营工作,并掌管着该公司的印章,对公司业务仍具有合法控制权。这也使得吴雄昂成为英伟达收购交易的一个主要障碍。一名熟悉Arm中国董事会的知情人士说,他认为这笔交易的成功率只有50%。另外两名知情人士透露
发表于 2020-11-04
苹果ARM自研处理器成本曝光:仅Intel的四分之一、续航更长
      如果不出意外,苹果预计本月将发布新品,其就是之前传闻多次的基于ARM架构的Mac新电脑。  据外媒最新报道称,基于ARM架构自研芯片的新Mac,会率先在笔记本上使用,其会是搭载A14X处理器的MacBook,同样基于台积电5nm工艺,不过性能要比A14更强。  报道中还提到,苹果自研ARM芯片的成本(5nmA14X),只有Intel处理器的1/4,价格便宜的同时,续航表现更加出色,续航表现可以长达15至20小时。  行业人士直言,成本和性能(移动芯片)越来越不占优势的Intel,在苹果的地位岌岌可危,而后者后续会进一步降低相应的采购比例,这对于Intel来说并不是一个好消息
发表于 2020-11-02
ARM在嵌入式系统中的应用
  随着ARM处理器的流行,为了使更多工程师了解ARM傅立叶撰写了系列开发文章,主要解决什么是ARM,ARM在产品项目中的开发流程,LINUX,WINCE,VXWORKS等操作系统在ARM处理器上的应用等内容。希望对初学者有所帮助。  1.嵌入式系统概述  应该肯定地讲我们每一位都已经使用过嵌入式系统有关的产品,嵌入式系统已经深入到我们生活的每一个角落。他所涉及的领域广泛到我们的想象力能及的任何地方。嵌入式系统是相对桌面系统来讲的,凡是带有微处理器的专用软硬件系统都可以称为嵌入式系统。作为系统核心的微处理器又包括三类:微控制器(MCU)、数字信号处理器(DSP)、嵌入式微处理器(MPU)。嵌入式比较准确一个定义如下:系统以应用
发表于 2020-10-30
<font color='red'>ARM</font>在嵌入式系统中的应用
小广播
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2020 EEWORLD.com.cn, Inc. All rights reserved