设备与游戏手柄适配
背景
CtsHardwareTestCases 2 cases FAIL
cts执行命令:
run cts -m CtsHardwareTestCases -t android.hardware.input.cts.tests.GameviceGv186Test#testAllMotions
run cts -m CtsHardwareTestCases -t android.hardware.input.cts.tests.RazerKishiTest#testAllMotions
以上命令为测试设备是否支持Gamevice、Razer Kishi(雷蛇骑士)这两款游戏手柄。
从报告中可以看到类似如下信息:
android.hardware.input.cts.tests.GameviceGv186Test#testAllMotions fail
java.lang.AssertionError: Assertion on entry 0 failed.
at android.hardware.input.cts.tests.InputTestCase.verifyFirstEvents(InputTestCase.java:280)
at android.hardware.input.cts.tests.InputTestCase.verifyEvents(InputTestCase.java:253)
at android.hardware.input.cts.tests.InputHidTestCase.testInputEvents(InputHidTestCase.java:261)
at android.hardware.input.cts.tests.GameviceGv186Test.testAllMotions(GameviceGv186Test.java:59)
... 8 trimmed
Caused by: java.lang.AssertionError: Initial check - Ignore move event.: Did not receive MotionEvent { action=ACTION_MOVE, actionButton=0, id[0]=0, x[0]=0.0, y[0]=0.0, toolType[0]=TOOL_TYPE_UNKNOWN, buttonState=0, classification=NONE, metaState=0, flags=0x0, edgeFlags=0x0, pointerCount=1, historySize=0, eventTime=0, downTime=0, deviceId=0, source=0x1000010, displayId=0, eventId=-259364074 }
at org.junit.Assert.fail(Assert.java:89)
at android.hardware.input.cts.tests.InputTestCase.failWithMessage(InputTestCase.java:390)
at android.hardware.input.cts.tests.InputTestCase.assertReceivedMotionEvent(InputTestCase.java:167)
at android.hardware.input.cts.tests.InputTestCase.verifyFirstEvents(InputTestCase.java:272)
... 12 more
java.lang.AssertionError: Assertion on entry 0 failed.
at android.hardware.input.cts.tests.InputTestCase.verifyFirstEvents(InputTestCase.java:280)
at android.hardware.input.cts.tests.InputTestCase.verifyEvents(InputTestCase.java:253)
at android.hardware.input.cts.tests.InputHidTestCase.testInputEvents(InputHidTestCase.java:261)
at android.hardware.input.cts.tests.GameviceGv186Test.testAllMotions(GameviceGv186Test.java:59)
... 8 trimmed
Caused by: java.lang.AssertionError: Initial check - Ignore move event.: Did not receive MotionEvent { action=ACTION_MOVE, actionButton=0, id[0]=0, x[0]=0.0, y[0]=0.0, toolType[0]=TOOL_TYPE_UNKNOWN, buttonState=0, classification=NONE, metaState=0, flags=0x0, edgeFlags=0x0, pointerCount=1, historySize=0, eventTime=0, downTime=0, deviceId=0, source=0x1000010, displayId=0, eventId=-426135120 }
at org.junit.Assert.fail(Assert.java:89)
at android.hardware.input.cts.tests.InputTestCase.failWithMessage(InputTestCase.java:390)
at android.hardware.input.cts.tests.InputTestCase.assertReceivedMotionEvent(InputTestCase.java:167)
at android.hardware.input.cts.tests.InputTestCase.verifyFirstEvents(InputTestCase.java:272)
... 12 more
经排查为缺少手柄usb驱动配置。
tp适配游戏手柄
添加游戏手柄usb驱动配置
kernel/msm-4.19/drivers/hid/hid-ids.h
#define USB_VENDOR_ID_GAMEVICE 0x27F8
#define USB_DEVICE_ID_GAMEVICE_GV186 0x0BBE
#define USB_DEVICE_ID_GAMEVICE_KISHI 0x0BBF
kernel/msm-4.19/drivers/hid/hid-quirks.c
{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_GAMEVICE, USB_DEVICE_ID_GAMEVICE_GV186),HID_QUIRK_INCREMENT_USAGE_ON_DUPLICATE },
{ HID_USB_DEVICE(USB_VENDOR_ID_GAMEVICE, USB_DEVICE_ID_GAMEVICE_KISHI),HID_QUIRK_INCREMENT_USAGE_ON_DUPLICATE },