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

最新更新时间:2014-02-23来源: 电源网关键字:ARM  linux 手机看文章 扫描二维码
随时随地手机看文章

     1.引言

  ARM微处理器已广泛应用于工业控制、消费类电子产品、通信系统等领域。矩阵键盘是一种常用的键盘形式,它将按键设计成M行N列,这样共需M+N根信号线,却可驱动M×N个按键,大大节约了I/O资源。本文介绍了一种利用TQ2440开发板的GPIO口扩展5×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的其他设备中均未使用到,否则会引起该驱动程序或其他驱动程序初始化失败。

  考虑到手持终端设备按键的常用性与操作的方便性,只取矩阵键盘的前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 编辑:探路者 引用地址:基于ARM的矩阵键盘设计及其linux驱动实现

上一篇:远距离夜视监控:激光夜视技术应用及其选型
下一篇:图像采集存储系统选择应考虑的几大要素

推荐阅读最新更新时间:2023-10-12 22:35

英特尔试与ARM比功耗低 打移动市场翻身仗
备受“高功耗”煎熬的英特尔这会玩儿真的了。日前,英特尔发布Silvermont低功耗微架构,在理论上拿出了比ARM功耗还低的产品。 英特尔官方介绍,和上一代产品相比,Silvermont新歌能提升3倍,功耗降低5倍,而和目前ARM主流芯片相比,性能提升2倍,功耗降低4.3倍。 如果上述规格能完全被体现在芯片产品上,英特尔将在智能手机和平板电脑上有着非常大的优势。不过,这还需要2013年下半年相关Silvermont微架构的产品来证明。 22纳米和3D栅极结构是技术关键 在关键的数据上,Silvermont将功能的电压降到了1瓦以下的水平。英特尔中国客户端平台部经理张健表示,在拿出该架构后,英特尔在实
[半导体设计/制造]
英特尔试与<font color='red'>ARM</font>比功耗低 打移动市场翻身仗
一种应用于ARM7的CMOS图像采集系统
Samsung公司的S3C4510B是基于以太网系统高性价比的16/32位RISC微控制器,内含一个由ARM公司设计的16/32位 ARM7TDMI RISC处理器核,ARM7TDMI为低功耗、高性能的16/32核,它具有0.9MIPS/MHz的三级流水线结构,支持32位ARM指令集和16位 Thumb指令集,有着功能丰富的片内外围功能模块,可挂载大容量的存储器,最适合用于对价格及功耗敏感的应用场合。 CMOS(Complementary Metal Oxide Semiconfuctor),即“互补金属氧化物半导体”。它是计算机系统内一种重要的芯片,将它加工也可以作为图像采集系统中的感光传感器。随着 CMOS技术的发展及市场需求
[单片机]
一种应用于<font color='red'>ARM</font>7的CMOS图像采集系统
S2C发布基于FPGA新的Prototype Ready ARM11和ARM9模块
利用GUC的ARM测试芯片提供一个简单的原型验证环境   S2C今日宣布为其全面的Prototype Ready配件家族新增ARM1176和ARM926 GUC测试芯片模块,用于搭建基于FPGA的原型并将基于FPGA的原型验证板接到用户的目标操作环境。这两款新的ARM测试芯片模块可用于所有S2C SoC/ASIC原型验证硬件包括Virtex-7 TAI Logic Modules, Stratix-4 TAI Logic Modules, Stratix-4 TAI Verification modules, Virtex-6 TAI Logic Modules以及Virtex-6 TAI Verification M
[半导体设计/制造]
S2C发布基于FPGA新的Prototype Ready <font color='red'>ARM</font>11和<font color='red'>ARM</font>9模块
Linux下如何搭建stm32开发环境(一)
Linux对于开发者来说真的是一个非常好的系统,为开发者来说应该不陌生,通常我们在Windows下开发stm32很方便,有非常多的工具,IDE等支持,同样是操作系统,Linux开发STM32也一点不会差。 Linux下开发stm32也有很多方法: 1.使用makefile 2.使用eclipse 3.使用stm32cubemx+sw4stm32 4.... 有大神使用第一种,本人对makefile一知半解,拿不出手。第二种,windows下可以使用eclipse开发,eclipse有linux版本,所以应该也是可以的,不过本人并没有试过。这里要说的就是第三种,当然除了这些,像Mbed之类的在线开发工具,只要有网,无论什么平台都
[单片机]
<font color='red'>Linux</font>下如何搭建stm32开发环境(一)
Computex:高通正式进军PC市场 三大PC品牌力挺
手机芯片大厂高通(Qualcomm)与PC操作系统霸主微软(Microsoft)从2016年开始便连手开发能在Snapdragon处理器上执行的Windows 10操作系统,并对外公开展示其研发成果。 在2017年台北国际计算机展期间,双方进一步联合宣布,相关研发工作已经完成,采用Snapdragon 835处理器,并且可执行全功能Windows 10操作系统的二合一装置(2-in-1)最快在2017年底就有机会量产上市,首波推出相关终端产品的PC品牌业者为华硕、联想与惠普(HP)。 高通技术公司全球产品营销副总裁Don McGuire表示,根据微软与高通两家公司各自针对消费者所做的调查显示,大多数消费者对行动运算装置最大的期
[家用电子]
基于ARM处理器的异常处理分析
内容摘要:嵌入式系统要求对异常及中断处理器能快速响应。文中分析了ARM体系结构下异常处理特点,提出一种基于ARM处理器的高效异常处理解决方案,以LPC3250硬件平台为基础,对该方案进行了设计与实现。测试结果表明,该方案的异常处理更为高效。 在航空航天、工业控制及医疗等领域中,嵌入式系统的安全性、可靠性以及高效性作用显著,而异常是系统在运行过程中的突发事件,异常处理是否高效将直接影响整个系统的工作效率。为了确保嵌入式系统高效安全的运行,对处理器非正常模式下高效的异常处理机制的研究具有重要意义。 1 异常概述 嵌入式系统中异常/中断是指由处理器内部或外部源产生并引起系统处理的一个事件。根据事件源的不同将异常分为“
[单片机]
基于<font color='red'>ARM</font>处理器的异常处理分析
栈在程序中的作用(ARM结构)
大家肯定学习过了栈这一结构,也知道栈的基本特性,可是栈如何在程序中起作用,特别是C语言中,是不多的。所以今天就来分享一下栈在程序中的作用。 首先读这篇文章之前,读者首先要了解两个基本的概念。 1、根据SP指针指向的位置,栈可以分为满栈和空栈 (1)满栈:堆栈指针SP总是指向最后压入堆栈的数据。 (2)空栈:堆栈指针SP总是指向下一个将要放入数据的空位置。 2、根据SP指针移动的方向,栈可以分为升栈和降栈 (1)升栈:随着数据的入栈,SP指针从低地址—— 高地址 (2)降栈:随着数据的入栈,SP指针从高地址—— 低地址 ARM采用的是 满降栈。 下面是一个栈在程序运用中的实例 第一排为源代码
[单片机]
栈在程序中的作用(<font color='red'>ARM</font>结构)
8051、ARM和DSP指令周期的测试与分析
在实时控制系统中,选择微控制器的指标时最重要的是计算速度的问题。指令周期是反映计算速度的一个重要指标,为此本文对三种最具代表性的微控制器(AT89S51单片机、ARM7TDMI核的LPC2114型单片机和TMS320F2812)的指令周期进行了分析和测试。为了能观察到指令周期,将三种控制器的GPIO口设置为数字输出口,并采用循环不断地置位和清零,通过观察GPIO口的波形变化得到整个循环的周期。为了将整个循环的周期与具体的每一条指令的指令周期对应起来,通过C语言源程序得到汇编语言指令来计算每一条汇编语言的指令周期。 1 AT89S51工作机制及指令周期的测试 AT89S51单片机的时钟采用内部方式,时钟发生器对振荡脉冲进行
[应用]
小广播
最新电源管理文章
换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved