Ti AM335X工控模块矩阵键盘电路的设计与驱动移植

本内容的验证使用的盈鹏飞嵌入式CoM-335x核心模块及评估板EAC-335X,简要介绍如下:

 

 

 前言

与按键相比,矩阵按键(键盘)使用更少的GPIO实现更多按键接口。以下,基于COM-335x核心模块,介绍linux嵌入式系统中矩阵键盘的编码实习过程,简单从原理、键值编码阐述。

1 原理简述

按按键的有效电平分,可分为高电平触发与低电平触发两种。一般地,高电平触发的按键,在原理设计上行地址通过电阻下拉;低电平触发,行地址上拉。分别如图1-1、图1-2所示,软件配置时需注意触发电平。

图1-1 高电平触发,行下拉

 

图1-2 低电平触发,行上拉

 软件层面,Linux input子系统提供支撑。其架构如图1-3,更多关于input子系统,请查阅资料或内核代码。

图1-3

 2 按键配置

按键配置关注两个问题,一是IO分配,二是键值。IO根据原理分配,注意有效电平、行配置为输入;键值有两种方式获得,人工计算与函数调用。以下分两节介绍第1章中按键该如何配置。

2.1 高电平触发的按键配置

,图1-1的按键为3行2列,行地址下拉。IO配置行输入、列输出、下拉、高电平触发,在COM-335x的dts中配置如下:

 注:以上代码清单中,红色字体为行地址的IO分配,黑色为列地址的IO分配。

 

注:

① 以上代码清单中,各个GPIO有效电平均为高,即:GPIO_ACTIVE_HIGH

 debounce-delay-ms表示去抖时间,单位为毫秒;

col-scan-delay-us 表示列扫描间隔时间,单位为微秒。

linux,keymap 属性的值为键值,该处通过计算得到。其计算公式如图2-1:

 

图2-1

 以“MENU”的键值为例,其“linux,keymap”的值计算方法如下:

 从include/dt-bindings/input/linux-event-codes.h文件中,找到MENU的值为139,即16进制的8B(共4位16进制数,不足的高位补0),如图2-2所示。

 图2-2

综上,32~25位为行号、24~17位为列好、低16位为键值,转换成16进制数方便阅读(4位2进制数表示1位16进制数)。0x0000008b 表示0行0列、键值为139。

2.2 低电平触发的按键配置

图1-2的按键为6行3列,行地址上拉。IO配置行输入、列输出、上拉、低电平触发,在COM-335x的dts中配置如下:

注:以上代码清单中,红色字体为行地址的IO分配,黑色为列地址的IO分配。

 

 

 

注:

gpio-activelow 表示低电平触发,若无该属性,则表示高电平有效;

② linux,no-autorepeat 表示禁用按键重复,即:长按某一按键时,只打印一次;

③ 调用MATRIX_KEY函数计算键值,这种方法比2.1节中直观,请函数运行如图2-3,键值的定义依然从include/dt-bindings/input/linux-event-codes.h 文件中获得。

 图2-3

 

 

### 回答1: ArrayList和LinkedList是两种不同类型的Java集合类。 ArrayList是基于数组实现的,查询和访问元素速度快,但是插入和删除元素速度较慢。 LinkedList是基于链表实现的,插入和删除元素速度快,但是查询和访问元素速度较慢。 总的来说,如果您的应用程序需要频繁地插入和删除元素,则应该使用LinkedList;如果您的应用程序需要频繁地查询和访问元素,则应该使用ArrayList。 ### 回答2: ArrayList和LinkedList是Java集合框架中常用的两种数据结构。 ArrayList是基于动态数组的实现,内部使用数组来存储元素。它的优点是可以随机访问,即通过索引来获取元素的时间复杂度为O(1),因为数组的内存是连续的。但是插入和删除元素时,需要移动后续元素的位置,时间复杂度为O(n)。因此,ArrayList适用于查询操作较多、增删操作较少的场景。 LinkedList是基于双向链表的实现,内部使用节点来存储元素,每个节点内保存有当前元素以及指向前后节点的引用。它的优点是在插入和删除元素时,只需要改变相邻节点的指针,时间复杂度为O(1)。但是在查询操作时,需要从头节点开始遍历,直到找到目标节点,时间复杂度为O(n)。因此,LinkedList适用于增删操作较多、查询操作较少的场景。 另外,ArrayList的内存空间是连续的,所以相对于LinkedList,它更加紧凑,不会浪费太多空间。而LinkedList每个节点在内存中是分散存储的,需要额外的指针来指向前后节点,因此它的内存占用更多。同时,由于ArrayList的大小是固定的,所以当元素数量超过容量时,需要扩容,而LinkedList则没有这个限制。 综上所述,ArrayList适用于查询操作更多、数组容量需要动态扩展的场景;而LinkedList适用于频繁增删操作、不需要随机访问的场景。选择使用哪种数据结构要根据具体的需求和场景来决定。 ### 回答3: ArrayList和LinkedList都是Java中的集合类,用于存储和操作一组元素。它们的区别主要体现在内部实现方式和性能上。 首先,ArrayList是基于数组实现的动态数组,而LinkedList是基于链表实现的双向链表。这导致它们在许多操作上的性能表现不同。 其次,ArrayList的优势在于随机访问元素的效率高,因为它可以通过索引直接定位元素。而LinkedList的优势在于插入和删除元素的效率高,因为它只需要修改前后元素的指针即可。 另外,ArrayList的缺点是在中间位置插入或删除元素时,需要移动后续元素来保持顺序,因此效率较低。而LinkedList的缺点是随机访问元素的效率较低,需要从头或尾开始遍历链表。 总的来说,如果需要频繁地进行随机访问操作,可以选择ArrayList;如果需要频繁地进行插入和删除操作,可以选择LinkedList。 除了性能差异外,它们的使用方式和功能几乎相同。无论是ArrayList还是LinkedList,都可以通过add、remove、get等方法来操作元素。另外,它们还都实现了List接口,可以使用统一的方式访问和操作集合中的元素。 综上所述,ArrayList和LinkedList的区别主要在于内部实现方式和性能方面。选择哪种集合类取决于具体的应用场景和需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值