专栏首页Linux驱动Linux-hexdump命令调试event驱动—详解(13)

Linux-hexdump命令调试event驱动—详解(13)

hexdump: 查看文件的内容,比如二进制文件中包含的某些字符串,通常用来调试驱动用

描述:

我们以event1为例,当我们insmod挂载了键盘驱动后,出现一个event1设备,

此时没有按键按下,所以event1里面的数据是没有的,那么数据又是从来哪里来?

通过键盘驱动的read函数,若有按键按下,就会上传按键数据给用户层hexdump

因为键盘驱动的input_handler 是:evdev_handler

所以键盘驱动的read函数是: evdev_handler->evdev_fops->evdev_read

进入evdev_read()函数,如下图所示:

evdev_event_to_user()这个函数从字面上来看,显然就是用来上传给用户层的函数,其中buffer是函数参数,指向用户层,

所以数据就是event.

我们来看看event的结构体:input_event

struct input_event {
struct timeval time;  //事件发生的时间
__u16 type;            //  哪类事件, 比如键盘事件
__u16 code;     // 对应的事件里支持的哪个变量,比如按键K
__s32 value;   // 对应的变量里的数值, 比如松开按键则是1,反之为0
};

把 time里的成员展开如下:

 struct input_event {
long   tv_sec; /* seconds */          //秒
long   tv_usec;    /* microseconds */     //微妙

__u16 type;            //  哪类事件, 比如键盘事件
__u16 code;     // 对应的事件里支持的哪个变量,比如按键K
__s32 value;   // 对应的变量里的数值, 比如松开按键则是1,反之为0
};

所以我们hexdump调试任何输入子系统event XX驱动时,有信息就会打印上面数据

 1.调试键盘驱动

(键盘驱动代码:http://www.cnblogs.com/lifexy/p/7553861.html)

以按开发板的按键 KEY_L,为例(因为数据是从低到高打印的,所以数据是反的):

# hexdump /dev/event1     //按键键盘驱动

/*按下时:*/
//hexdump序列号          秒             微妙         键盘事件    code=KEY_L     value=1(按下)
 0000000             07c6 0000      faa2 000b      0001        0026          0001 0000
//hexdump序列号          秒             微妙         同步事件       code        value=0 
 0000010            07c6 0000      faac 000b       0000        0000          0000 0000

/*松开时:*/
//hexdump序列号          秒             微妙         键盘事件     code=0x26     value=0(松开)
 0000020             07c6 0000     cf67 000d        0001        0026         0000 0000
//hexdump序列号          秒             微妙         同步事件      code         value=0 
 0000030             07c6 0000     cf70 000d        0000        0000         0000 0000

2.调试触摸屏驱动

(触摸屏驱动代码: )

 /dev/event0            //触摸屏驱动
# hexdump /dev/event0 
//hexdump序列号          秒             微妙        绝对坐标事件    code=ABS_X   X坐标值 
0000000               0412 0000      6ef0 000c      0003          0000      0239 0000
//hexdump序列号          秒             微妙        绝对坐标事件    code=ABS_Y   Y坐标值
0000010                 0412 0000    6f08 000c      0003          0001      01ae 0000
//hexdump序列号          秒             微妙        绝对坐标事件    code=压力     压力值
0000020             0412 0000        6f0c 000c      0003          0018      0001 0000
//hexdump序列号          秒             微妙        键盘事件       code=触摸按键  value=1(按下)
0000030              0412 0000       6f10 000c      0001          014a      0001 0000
//hexdump序列号          秒             微妙        同步事件      
0000040             0412 0000        6f13 000c      0000          0000      0000 0000

//hexdump序列号          秒             微妙        绝对坐标事件    code=压力     压力值
00000b0               023b 0000      872d 000c      0003          0018      0000 0000

//hexdump序列号          秒             微妙        键盘事件      code=触摸按键  value=0(松开)
00000b0            0412 0000         1f5b 000d     0001          014a       0000 0000
//hexdump序列号          秒             微妙        同步事件      
00000c0             0412 0000        1f70 000d     0000          0000       0000 0000

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 10.按键之互斥、阻塞机制(详解)

    本节目标: 学习原子操作和互斥信号量,实现互斥机制,同一时刻只能一个应用程序使用驱动程序 学习阻塞和非阻塞操作 当设备被一个程序打开时,存在被另一个程序打开的可...

    张诺谦
  • 贪心算法-跳跃游戏二

    给定一个非负整数数组,假定你的初始位置为数组第一个下标。 数组中的每个元素代表你在那个位置能够跳跃的最大长度。 你的目标是到达最后一个下标,并且使用最少的跳跃次...

    张诺谦
  • 13.JAVA-包package、import使用

    之前我们学习java时,生成的class文件都是位于当前目录中,假如出现了同名文件,则会出现文件覆盖问题,因此就需要设置不同的目录(定义包),来解决同名文件冲突...

    张诺谦
  • 深入分析——HashSet是否真的无序?(JDK8)

    《Core Java Volume I—Fundamentals》中对HashSet的描述是这样的:

    BWH_Steven
  • 为什么Java中int型数据取值范围是[-2^31,2^31-1]

    1、为什么Java中int型数据取值范围是[-2^31,2^31-1],多么神奇的问题,网上找了很多,找不到点子上,自己瞎总结一下子。

    别先生
  • 1-1 Java基础-位运算

    位运算其实就是移位运算,将内存里面的二进制进行移位 比如二进制=101向右移1位 010|1 移位之后的1其实已经不被计算在内了, 变成内存里面的垃圾 在...

    suveng
  • 分布式id生成算法SnowFlake

    10位记录工作机器id;即datacenterId (5位数据id) + workerId (5位机器id)

    chenchenchen
  • 原 PostgreSQL的基础数据类型分析记录

    王果壳
  • 把模块有关联的放在一个文件夹中 在python2中调用文件夹名会直接失败 在python3中调用会成功,但是调用不能成功的解决方案

    把模块有关联的放在一个文件夹中 在python2中调用文件夹名会直接失败 在python3中调用会成功,但是调用不能成功 解决办法是: 在该文件夹下加入空文件_...

    Angel_Kitty
  • 计算机的世界:[-bit之魂-]

    关于数字化个人认为是计算机世界对现实世界的映射(或称采样或模拟)。 现实世界包括客观存在和人类文明衍生物(自然科学和广义文学)。 数字化就是将这些映射为二...

    张风捷特烈

扫码关注云+社区

领取腾讯云代金券