Android底层开发之Linux输入子系统要不要推断系统休眠状态上报键值
Android底层开发之Linux输入子系统要不要推断系统休眠状态上报键值
题外话:一个问题研究到最后,那边记录文档的前半部分基本上都是没用的,甚至是错误的。
重点在最后,前边不过一些假想猜測。
http://blog.csdn.net/kangear/article/details/40072707
在调试一下红外遥控器input驱动时,直接採用的是一个半成品的驱动在上边实现的自己的设备的匹配,但同一时候遇到了一些关于input输入子系统的疑惑。
按键一般有「按下和抬起」两个状态一般使用0和1来分别表示。一般例如以下方式上报按键键值就能够完毕「按下和抬起」两个状态的收集。
input_event(ddata->input, EV_KEY, KEY_POWER, 1);
input_sync(ddata->input);
可是近期遇到一个奇怪的问题是内核中的KEY_WAKEUP唤醒键值使用上述方法上报时。用户空间仅仅能检測到状态0,第二次按键时才会有状态1。这样导致Android系统不能正常唤醒,须要按两次才干唤醒系统。
眼下的解决方法是将之前上报KEY_WAKEUP的地上改为KEY_POWER键值。可是好奇心引着我弄清楚它们是怎么回事。
经验出这里边上报例如以下一样连续上报1/0状态才干够在用户空间正常的检測到1/0状态。
input_event(ddata->input, EV_KEY, KEY_WAKEUP, 1);
input_sync(ddata->input);
input_event(ddata->input, EV_KEY, KEY_WAKEUP, 0);
input_sync(ddata->input);
直觉告诉我能够是因为我对这个两个api的不了解造成的。比較是凡事必有因的。
除了KEY_WAKEUP换个其他键值试试。结果和KEY_WAKEUPG一样不能同步,能够判断出是非POWER按键就不行。这能够能所在代码位置有关系:
}else if ((get_suspend_state())&&(ddata->keycode==KEY_POWER)){
input_event(ddata->input, EV_KEY, KEY_POWER, 1);
input_sync(ddata->input);
}
再进一步測试在非PM_SUSPEND_ON电源模式下,全部的按键都是怎样的。測试结果是全部的非POWER按键都出现了按键不能同步的问题。可是不能以点概面。使用GPIO连接的物理按键并不会有此问题。那么就排除了input子系统中做了手脚。
问题出就出在了Remote control驱动中对的处理。
找出了问题所在了。确实是出在了Remote control驱动中,上报键值对PM状态进行了推断,假设
static void remotectl_timer(unsigned long _data)
if(ddata->press != ddata->pre_press) {
ddata->pre_press = ddata->press = 0;
if (get_suspend_state()==0){
//input_event(ddata->input, EV_KEY, ddata->keycode, 1);
//input_sync(ddata->input);
input_event(ddata->input, EV_KEY, ddata->keycode, 0);
input_sync(ddata->input);
}else if ((get_suspend_state())&&(ddata->keycode==KEY_POWER)){
//input_event(ddata->input, EV_KEY, KEY_WAKEUP, 1);
//input_sync(ddata->input);
input_event(ddata->input, EV_KEY, KEY_WAKEUP, 0);
input_sync(ddata->input);
}
}
将过滤条件去除后,能够和GPIO连接的物理按键一样的效果了,即不管系统处理什么样的状态。休眠或者唤醒状态都上传了键值。同一时候这也给我带来了一个疑惑,按键驱动中要不要进行suspend状态推断。依据Android中的经验全部的状态都要上传的。响应不响应是看上层系统的决定。可是假设对于普通的嵌入式Linux系统就不一定了,假设input子系统在系统休眠的时候上传了键值。那么相应的应用层能够就会直接去响应键值。要使用哪种方法实现,这是一个悖论!结合Android的宏这样实现了:
diff --git a/drivers/input/remotectl/rkxx_remotectl.c b/drivers/input/remotectl/rkxx_remotectl.c
index db91516..201c5dd 100644
--- a/drivers/input/remotectl/rkxx_remotectl.c
+++ b/drivers/input/remotectl/rkxx_remotectl.c
@@ -306,6 +306,10 @@ static void remotectl_do_something(unsigned long data)
if ((ddata->scanData&0x0ff) == ((~ddata->scanData >> 8)&0x0ff)){
if (remotectl_keycode_lookup(ddata)){
ddata->press = 1;
+#ifdef CONFIG_ANDROID // Android OS needs input event whatever suspend state
+ input_event(ddata->input, EV_KEY, ddata->keycode, 1);
+ input_sync(ddata->input);
+#else
if (ddata->keycode==KEY_POWER || get_suspend_state()==PM_SUSPEND_ON){
input_event(ddata->input, EV_KEY, ddata->keycode, 1);
input_sync(ddata->input);
@@ -314,6 +318,7 @@ static void remotectl_do_something(unsigned long data)
}
//input_event(ddata->input, EV_KEY, ddata->keycode, ddata->press);
//input_sync(ddata->input);
+#endif // CONFIG_ANDROID
ddata->state = RMC_SEQUENCE;
}else{
ddata->state = RMC_PRELOAD;
@@ -437,6 +442,10 @@ static void remotectl_timer(unsigned long _data)
if(ddata->press != ddata->pre_press) {
ddata->pre_press = ddata->press = 0;
+#ifdef CONFIG_ANDROID // Android OS needs input event whatever suspend state
+ input_event(ddata->input, EV_KEY, ddata->keycode, 0);
+ input_sync(ddata->input);
+#else
if (get_suspend_state()==0){
//input_event(ddata->input, EV_KEY, ddata->keycode, 1);
//input_sync(ddata->input);
@@ -448,6 +457,7 @@ static void remotectl_timer(unsigned long _data)
input_event(ddata->input, EV_KEY, KEY_WAKEUP, 0);
input_sync(ddata->input);
}
+#endif // CONFIG_ANDROID
}
#ifdef CONFIG_PM
remotectl_wakeup(_data);
假设是Android系统。那么不管kernel处理什么样的休眠状态都实时地上报键值。
这样保证在休眠播放音乐的时候能够控制音频大小。这也正是眼下Android手机的实现方式。
http://blog.csdn.net/kangear/article/details/40072707
另一点:按键中的状0,并非input_sync(ddata->input);发出的,它只会发出当前的值。它不过一个「同步」,意思是数据都准备好了,能够发送了。
还是没有对驱动了解的非常清楚加上自己的一些瞎想像误导了自己。内核input驱动中是不区分POWER键,WAKEUP键;真是有差异了,问题一定是出在了自己的驱动代码中。
Android底层开发之Linux输入子系统要不要推断系统休眠状态上报键值的更多相关文章
- Linux输入子系统详解
input输入子系统框架 linux输入子系统(linux input subsystem)从上到下由三层实现,分别为:输入子系统事件处理层(EventHandler).输入子系统核心层(Input ...
- linux输入子系统
linux输入子系统(linux input subsystem)从上到下由三层实现,分别为:输入子系统事件处理层(EventHandler).输入子系统核心层(InputCore)和输入子系统设备驱 ...
- linux输入子系统(input subsystem)之evdev.c事件处理过程
1.代码 input_subsys.drv.c 在linux输入子系统(input subsystem)之按键输入和LED控制的基础上有小改动,input_subsys_test.c不变. input ...
- Android安全开发之ZIP文件目录遍历
1.ZIP文件目录遍历简介 因为ZIP压缩包文件中允许存在“../”的字符串,攻击者可以利用多个“../”在解压时改变ZIP包中某个文件的存放位置,覆盖掉应用原有的文件.如果被覆盖掉的文件是动态链接s ...
- Android驱动开发之Hello实例
Android驱动开发之Hello实例: 驱动部分 modified: kernel/arch/arm/configs/msm8909-1gb_w100_hd720p-perf_defconf ...
- Linux输入子系统(转)
Linux输入子系统(Input Subsystem) 1.1.input子系统概述 输入设备(如按键,键盘,触摸屏,鼠标等)是典型的字符设备,其一般的工作机制是低层在按键,触摸等动作发生时产生一个中 ...
- Linux输入子系统(一) _驱动编码
输入设备都有共性:中断驱动+字符IO,基于分层的思想,Linux内核将这些设备的公有的部分提取出来,基于cdev提供接口,设计了输入子系统,所有使用输入子系统构建的设备都使用主设备号13,同时输入子系 ...
- Android 安全开发之 ZIP 文件目录遍历
1.ZIP文件目录遍历简介 因为ZIP压缩包文件中允许存在"../"的字符串,攻击者可以利用多个"../"在解压时改变ZIP包中某个文件的存放位置,覆盖掉应用原 ...
- linux输入子系统简述【转】
本文转载自:http://blog.csdn.net/xubin341719/article/details/7678035 1,linux输入子系统简述 其实驱动这部分大多还是转载别人的,linux ...
随机推荐
- 洛谷 P1683 入门
P1683 入门 题目描述 不是任何人都可以进入桃花岛的,黄药师最讨厌象郭靖一样呆头呆脑的人.所以,他在桃花岛的唯一入口处修了一条小路,这条小路全部用正方形瓷砖铺设而成.有的瓷砖可以踩,我们认为是安全 ...
- HTML5吃豆豆游戏开发实战(一)使用Canvas绘制游戏主角
近期在学习HTML5.爱因斯坦曾说过,"最好的学习就是自己去经历". 于是.我想在学习HTML5的同一时候.做一款简单的小游戏,这样学习起来也会非常有趣的.我想做的是曾经小时候玩儿 ...
- SSL通关之代码演示样例(四)
实际开发过程中,server端是不须要多加代码处理的,由于ssl验证过程是由server(tomcat.nginx等)完毕的. 这段代码也是參考了网上的: 新建一个web项目,项目结构和须要引入的ja ...
- jquery05 继承
<!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...
- js---12数据类型,数据类型转换,NaN,
<!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...
- vim 基础学习之插入模式
插入模式1.字符编码,插入特殊字符 <C-v>{3位} 如,你想输入A,你可以在输入模式下<C-v>065(必须是3位) <C-v>u{4位} 如,你想输入¿,你可 ...
- 将BT下载对抗到底
将BT下载对抗到底 随着互联网业务的多元化,各种P2P应用也越来越多,在企业中多数流量都会被类似于BT的下载所占用,BT之所以会危害到局域网,是因为它占用了大量网络带宽.网络管理员可以通过一 ...
- tomcat:web容器
Web容器和应用服务器除了你所说的request response之外还有很多其他重要的功能. 1. 多线程和并发处理,估计你写的socket程序支持不了几个并发访问吧 2. 安全性 3. 生命周期管 ...
- logback 生成日志
<?xml version="1.0" encoding="UTF-8"?> <configuration> <appender ...
- 微信小程序从零开始开发步骤(八)引入框架WeUI
首先来看下WeUI的官方介绍: WeUI 是一套同微信原生视觉体验一致的基础样式库,由微信官方设计团队为微信内网页和微信小程序量身设计,令用户的使用感知更加统一.在微信小程序的开发过程中,涉及到的前端 ...