Input机制之-Debug调试方法
项目碰到功能按键ASSIT点击没有反应的情况
确定哪部分出了问题
adb shell getevent
命令可以获取Android kernel层上报到/dev/input/目录下的原始数据
我们可以通过这个命令,判断驱动层是否能正常的生成数据,当我们点击ASSIT按钮,/dev/input/event2生成两条数据,分别为DOWN和UP事件,如上图表示,其中00fa(250)表示这个ASSIT按键在驱动层定义的键值,若这边没有数据表示驱动没有正常的上报数据,找驱动处理
-
adb shell input keyevent 219
命令可以模拟进行按键的点击,将点击事件直接通过InputDispatcher的injectInputEvent方法发送到Native层,若这边有问题表示InputDispatcher的拦截和分发存在问题,需要追踪源码,可以打开DEBUG_INBOUND_EVENT_DETAILS,DEBUG_OUTBOUND_EVENT_DETAILS等配置宏打印LOG,事件的拦截逻辑是在PhoneWindowManager中实现的,可以通过DEBUG_INPUT开关打印LOG -
adb shell dumpsys input
可以输出一些input系统运行时的一些信息,比如关键字RecentQueue,记录了10条最近的Input事件的信息。还有诸如PendingEvent,InboundQueue,Windows,Connections等信息。
通过这个可以确定InputReader是否正常的读取事件,若这边没有相关数据,就需要查看InputReader的逻辑了,若只是某一个特定功能按键有问题,可能是EventHub对特定/dev/input/的读取有问题或者驱动键值表文件配置问题导致事件无法正常转换,前者可以通过DEBUG_RAW_EVENTS配置宏打印LOG,后者可以导出手机中相应的/system/usr/keylayout/xxxx.kl和/system/usr/keychars/xxxx.kcm键值配置文件分析是否是转换错误
附MTK FAQ: