|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
输入设备总类繁杂,包括按键,键盘,触摸屏,鼠标,摇杆等等,它们本身都是字符设备,不过内核为了能将这些设备的共性抽象出来,简化驱动的开发,建立了一个 Input 子系统。用户只需要根据内核提供的 input 子系统下提供的 API 函数接口,完成设备的注册即可。在本章节中我们来学习一下如何使用 Linux内核中的 input 子系统。, Y2 {3 r; s% ]/ a) V7 {
1.运行测试
; V' W" x2 @. X- i1.1 编译驱动程序; K$ m8 i8 X, P/ Q+ t6 \/ ~
和前面章节中驱动测试程序一样需要一个 Makefile 文件,只是将 obj-m 的值改为 key_input.o,Makefile 文1 b3 h2 q: @, [4 y3 q
件内容如下:$ U5 O( B7 L$ N$ |! E1 Y
KERNELDIR := /home/topeet/kernel/linux-imx-rel_imx_4.1.15_2.1.0_ga% L0 `. L- `% B4 C
CURRENT_PATH := $(shell pwd)2 s2 _' |0 _4 B# w# w1 K B6 v
obj-m := key_input.o
% y/ y ^7 v1 @& y) c0 S5 i' Xbuild: kernel_modules
, V. S V% c- L) Skernel_modules:6 U$ O# W5 ~4 ?1 \# y. R D; h
$(MAKE) -C $(KERNELDIR) M=$(CURRENT_PATH) modules* g2 m0 s! `6 I+ H
clean:6 r( c' z5 x8 N% n1 V/ p2 o/ ]' j
$(MAKE) -C $(KERNELDIR) M=$(CURRENT_PATH) clean! H- \# w7 p: f% N$ s
首先我们在终端输入两个命令(设置两个环境变量):# x/ V, @. f' W9 T8 B( n5 }
export ARCH=ARM3 e* n3 T( h4 b. j$ V0 [
export CROSS_COMPILE=arm-linux-gnueabihf-1 H2 t; l" p; z E# S0 F7 O& C' Y
然后执行“make”命令编译模块,编译完成生成 key_input.ko 模块文件。
( u }/ b! Y( r* s. a9 N2.编译应用测试程序
( b+ c' ?; h1 Q7 _" m) Q输入如下命令编译应用测试程序:
2 w3 I' h) x9 u5 X+ _5 M. [arm-linux-gnueabihf-gcc -o key_input_test key_input_test.c
' @1 W2 b$ m! D8 Y) C) }编译完成后,会生成 key_input_test 可执行文件。 j: l+ O: N1 u5 v; R5 U+ n
3.运行测试
7 R: i+ x( T# v启动开发板,将编译好的 key_input.ko 模块文件和 key_input_test 应用程序拷贝到/lib/modules/4.1.15 目录下(检查开发板根文件系统中有没有“/lib/modules/4.1.15”这个目录,如果没有的话需要自行创建一下。开发板中使用的是光盘资料里面提供的 busybox 文件系统,光盘资料的“i.MX6UL 终结者光盘资料\08_开发板系统镜像\03_文件系统镜像\01_Busybox 文件系统”目录下)。在加载驱动模块文件之前,先看一下在/dev/input 目录下都有哪些文件,结果如下图所示:7 {5 j' l+ B8 J/ L3 d4 |+ Q
8 w/ f5 o7 c& y
在/dev/input 目录下已经存在了不少的 event 事件,然后输入下面命令加载模块:; I3 T7 a9 Z3 ~6 N) }
depmod
) q' g# L( m1 ]5 Y' O$ \9 Kmodprobe key_input
5 M' d' e; W/ m; {驱动加载成功后在来看一下在/dev/input 目录下有哪些文件,结果如下图所示:4 V# C/ r8 K$ F8 a" y. y9 k* H
![]()
' A0 ^( m+ }- h9 u0 s+ L可以看出,多了一个 event3 文件,因此/dev/input/event3 就是我们注册的驱动所对应的设备文件。然后key_input_test 应用程序通过读取/dev/input/event3 设备文件来获取输入事件信息,测试命令如下:
, ?/ K; D/ \7 @./key_input_test /dev/input/event3! _/ l/ a* J6 y9 J4 {
按下开发板上的按键 KEY0,有如下现象:
! F" \0 ]" m7 H4 t $ C7 L4 F! W2 t/ u- ]0 }; W
可以看出,当我们按下或者释放开发板上的按键以后都会在终端上输出相应的内容,提示我们哪个按键按下或释放了,在 Linux 内核中 KEY_0 为 11。
5 c0 I% _1 D ~$ P1 W3 t另外,我们也可以不用 key_input_test 应用程序 来测试驱动,可以直接使用 hexdump 命令来查看
& N! S) W/ } C8 |0 u" `/dev/input/event3 文件内容,输入如下命令:' K$ J7 Z6 V- g5 L$ h. u
hexdump /dev/input/event3
% u" y, y' H; K按下开发板上的按键 KEY0,有如下现象: f3 l3 h4 ~* n" P/ \% ?$ V) N. p, {
9 [) W$ V' d( U9 K6 J
上图就是 input_event 类型的原始事件数据值,采用十六进制表示,这些原始数据的含义如下:
8 e) I$ c' u! \![]()
( O. k) \7 @: g4 k2 |) Ftype 为事件类型,EV_KEY 事件值为 1,EV_SYN 事件值为 0。因此第 1 行表示 EV_KEY 事件,第 2 行表示 EV_SYN 事件。code 为事件编码,也就是按键号,KEY_0 这个按键编号为 11,对应的十六进制为0xb,因此第 1 行表示 KEY_0 这个按键事件,最后的 value 就是按键值,为 1 表示按下,为 0 的话表示松开。
- H% P4 L, g9 h5 x综上所述,上图中的原始事件值含义如下:" X; T2 R( g3 H+ m# S% J9 {
第 1 行,按键(KEY_0)按下事件。
, E# x8 B% H# I第 2 行,EV_SYN 同步事件,因为每次上报按键事件以后都要同步的上报一个 EV_SYN 事件。
! u. u H/ y+ p8 S- `* {第 3 行,按键(KEY_0)松开事件。3 y1 ^5 H: g) w# I" Y" c- D2 `6 {
第 4 行,EV_SYN 同步事件,和第 2 行一样。- ^8 Z7 P7 [6 M$ ?4 E( h8 F
![]()
1 K' s, X, v: V, E: ] |
|