STM32マイクロコントローラを使用してテストHIDキーボードを実装しました。
特別なことはありません。接続後10/秒に「A」連続ストリームを送るだけです。
Windowsではうまくいきます。ただし、Ubuntu 16システムに接続すると正しく認識されていますが、何も表示されず、dmesgにエラーも表示されません。
dmesgログ:
[ +9.163248] usb 2-1.1.2: new full-speed USB device number 34 using ehci-pci
[ +0.110516] usb 2-1.1.2: New USB device found, idVendor=0483, idProduct=5710
[ +0.000005] usb 2-1.1.2: New USB device strings: Mfr=1, Product=2, SerialNumber=3
[ +0.000003] usb 2-1.1.2: Product: Root Password Unlock Key
[ +0.000002] usb 2-1.1.2: Manufacturer: Nomadic Controls
[ +0.000002] usb 2-1.1.2: SerialNumber: 123456789
[ +0.002741] input: Nomadic Controls Root Password Unlock Key as /devices/pci0000:00/0000:00:1d.0/usb2/2-1/2-1.1/2-1.1.2/2-1.1.2:1.0/0003:0483:5710.0012/input/input39
[ +0.059560] hid-generic 0003:0483:5710.0012: input,hidraw2: USB HID v1.00 Keyboard [Nomadic Controls Root Password Unlock Key] on usb-0000:00:1d.0-1.1.2/input0
evtestでテストした結果、データが正しく機能していることがわかりました。何らかの理由で画面に表示されませんでした。
テストログ
Input device ID: bus 0x3 vendor 0x483 product 0x5710 version 0x100
Input device name: "Nomadic Controls Root Password Unlock Key"
Supported events:
Event type 0 (EV_SYN)
Event type 1 (EV_KEY)
Event code 1 (KEY_ESC)
Event code 2 (KEY_1)
Event code 3 (KEY_2)
Event code 4 (KEY_3)
Event code 5 (KEY_4)
Event code 6 (KEY_5)
Event code 7 (KEY_6)
Event code 8 (KEY_7)
Event code 9 (KEY_8)
Event code 10 (KEY_9)
Event code 11 (KEY_0)
Event code 12 (KEY_MINUS)
Event code 13 (KEY_EQUAL)
Event code 14 (KEY_BACKSPACE)
Event code 15 (KEY_TAB)
Event code 16 (KEY_Q)
Event code 17 (KEY_W)
Event code 18 (KEY_E)
Event code 19 (KEY_R)
Event code 20 (KEY_T)
Event code 21 (KEY_Y)
Event code 22 (KEY_U)
Event code 23 (KEY_I)
Event code 24 (KEY_O)
Event code 25 (KEY_P)
Event code 26 (KEY_LEFTBRACE)
Event code 27 (KEY_RIGHTBRACE)
Event code 28 (KEY_ENTER)
Event code 29 (KEY_LEFTCTRL)
Event code 30 (KEY_A)
Event code 31 (KEY_S)
Event code 32 (KEY_D)
Event code 33 (KEY_F)
Event code 34 (KEY_G)
Event code 35 (KEY_H)
Event code 36 (KEY_J)
Event code 37 (KEY_K)
Event code 38 (KEY_L)
Event code 39 (KEY_SEMICOLON)
Event code 40 (KEY_APOSTROPHE)
Event code 41 (KEY_GRAVE)
Event code 42 (KEY_LEFTSHIFT)
Event code 43 (KEY_BACKSLASH)
Event code 44 (KEY_Z)
Event code 45 (KEY_X)
Event code 46 (KEY_C)
Event code 47 (KEY_V)
Event code 48 (KEY_B)
Event code 49 (KEY_N)
Event code 50 (KEY_M)
Event code 51 (KEY_COMMA)
Event code 52 (KEY_DOT)
Event code 53 (KEY_SLASH)
Event code 54 (KEY_RIGHTSHIFT)
Event code 55 (KEY_KPASTERISK)
Event code 56 (KEY_LEFTALT)
Event code 57 (KEY_SPACE)
Event code 58 (KEY_CAPSLOCK)
Event code 59 (KEY_F1)
Event code 60 (KEY_F2)
Event code 61 (KEY_F3)
Event code 62 (KEY_F4)
Event code 63 (KEY_F5)
Event code 64 (KEY_F6)
Event code 65 (KEY_F7)
Event code 66 (KEY_F8)
Event code 67 (KEY_F9)
Event code 68 (KEY_F10)
Event code 69 (KEY_NUMLOCK)
Event code 70 (KEY_SCROLLLOCK)
Event code 71 (KEY_KP7)
Event code 72 (KEY_KP8)
Event code 73 (KEY_KP9)
Event code 74 (KEY_KPMINUS)
Event code 75 (KEY_KP4)
Event code 76 (KEY_KP5)
Event code 77 (KEY_KP6)
Event code 78 (KEY_KPPLUS)
Event code 79 (KEY_KP1)
Event code 80 (KEY_KP2)
Event code 81 (KEY_KP3)
Event code 82 (KEY_KP0)
Event code 83 (KEY_KPDOT)
Event code 86 (KEY_102ND)
Event code 87 (KEY_F11)
Event code 88 (KEY_F12)
Event code 96 (KEY_KPENTER)
Event code 97 (KEY_RIGHTCTRL)
Event code 98 (KEY_KPSLASH)
Event code 99 (KEY_SYSRQ)
Event code 100 (KEY_RIGHTALT)
Event code 102 (KEY_HOME)
Event code 103 (KEY_UP)
Event code 104 (KEY_PAGEUP)
Event code 105 (KEY_LEFT)
Event code 106 (KEY_RIGHT)
Event code 107 (KEY_END)
Event code 108 (KEY_DOWN)
Event code 109 (KEY_PAGEDOWN)
Event code 110 (KEY_INSERT)
Event code 111 (KEY_DELETE)
Event code 119 (KEY_PAUSE)
Event code 125 (KEY_LEFTMETA)
Event code 126 (KEY_RIGHTMETA)
Event code 127 (KEY_COMPOSE)
Event type 4 (EV_MSC)
Event code 4 (MSC_SCAN)
Event type 17 (EV_LED)
Event code 0 (LED_NUML) state 1
Event code 1 (LED_CAPSL) state 0
Event code 2 (LED_SCROLLL) state 0
Event code 3 (LED_COMPOSE) state 0
Event code 4 (LED_KANA) state 0
Key repeat handling:
Repeat type 20 (EV_REP)
Repeat code 0 (REP_DELAY)
Value 250
Repeat code 1 (REP_PERIOD)
Value 33
Properties:
Testing ... (interrupt to exit)
Event: time 1517685567.317551, type 1 (EV_KEY), code 30 (KEY_A), value 2
Event: time 1517685567.317551, -------------- SYN_REPORT ------------
Event: time 1517685567.357555, type 1 (EV_KEY), code 30 (KEY_A), value 2
Event: time 1517685567.357555, -------------- SYN_REPORT ------------
Event: time 1517685567.397568, type 1 (EV_KEY), code 30 (KEY_A), value 2
Event: time 1517685567.397568, -------------- SYN_REPORT ------------
Event: time 1517685567.421168, type 17 (EV_LED), code 0 (LED_NUML), value 0
Event: time 1517685567.421168, -------------- SYN_REPORT ------------
Event: time 1517685567.437542, type 1 (EV_KEY), code 30 (KEY_A), value 2
Event: time 1517685567.437542, -------------- SYN_REPORT ------------
Event: time 1517685567.477549, type 1 (EV_KEY), code 30 (KEY_A), value 2
Event: time 1517685567.477549, -------------- SYN_REPORT ------------
Event: time 1517685567.517555, type 1 (EV_KEY), code 30 (KEY_A), value 2
Event: time 1517685567.517555, -------------- SYN_REPORT ------------
Event: time 1517685567.557554, type 1 (EV_KEY), code 30 (KEY_A), value 2
Event: time 1517685567.557554, -------------- SYN_REPORT ------------
Event: time 1517685567.597552, type 1 (EV_KEY), code 30 (KEY_A), value 2
Event: time 1517685567.597552, -------------- SYN_REPORT ------------
Event: time 1517685567.637564, type 1 (EV_KEY), code 30 (KEY_A), value 2
ここで何が起こるのかご存知ですか?
答え1
機能するとevtest
、関連するすべてのカーネル層(HID、入力)が機能するため、問題は/dev/input/event*
XまたはWayland(実行中のすべての項目)に変換することです。だから何らかの理由でXevdev
ドライバやlibinput
(あなたが使用するものは何でも)HIDデバイスを選択しません。
X11の場合は、手がかりを見つけて強制的に含めるように/var/log/Xorg.0.log
カスタマイズを作成することもできます。xorg.conf
これにより、xev
Xイベントを表示してxinput
X入力デバイスを制御できます。ウェイランドについてはお手伝いできません。