| #!/bin/env python3 |
| # SPDX-License-Identifier: GPL-2.0 |
| # -*- coding: utf-8 -*- |
| # |
| # Copyright (c) 2020 Benjamin Tissoires <benjamin.tissoires@gmail.com> |
| # Copyright (c) 2020 Red Hat, Inc. |
| # |
| |
| from .test_keyboard import ArrayKeyboard, TestArrayKeyboard |
| from hidtools.util import BusType |
| |
| import libevdev |
| import logging |
| |
| logger = logging.getLogger("hidtools.test.ite-keyboard") |
| |
| KERNEL_MODULE = ("itetech", "hid_ite") |
| |
| |
| class KbdData(object): |
| pass |
| |
| |
| # The ITE keyboards have an issue regarding the Wifi key: |
| # nothing comes in when pressing the key, but we get a null |
| # event on the key release. |
| # This test covers this case. |
| class ITEKeyboard(ArrayKeyboard): |
| # fmt: off |
| report_descriptor = [ |
| 0x06, 0x85, 0xff, # Usage Page (Vendor Usage Page 0xff85) |
| 0x09, 0x95, # Usage (Vendor Usage 0x95) 3 |
| 0xa1, 0x01, # Collection (Application) 5 |
| 0x85, 0x5a, # .Report ID (90) 7 |
| 0x09, 0x01, # .Usage (Vendor Usage 0x01) 9 |
| 0x15, 0x00, # .Logical Minimum (0) 11 |
| 0x26, 0xff, 0x00, # .Logical Maximum (255) 13 |
| 0x75, 0x08, # .Report Size (8) 16 |
| 0x95, 0x10, # .Report Count (16) 18 |
| 0xb1, 0x00, # .Feature (Data,Arr,Abs) 20 |
| 0xc0, # End Collection 22 |
| 0x05, 0x01, # Usage Page (Generic Desktop) 23 |
| 0x09, 0x06, # Usage (Keyboard) 25 |
| 0xa1, 0x01, # Collection (Application) 27 |
| 0x85, 0x01, # .Report ID (1) 29 |
| 0x75, 0x01, # .Report Size (1) 31 |
| 0x95, 0x08, # .Report Count (8) 33 |
| 0x05, 0x07, # .Usage Page (Keyboard) 35 |
| 0x19, 0xe0, # .Usage Minimum (224) 37 |
| 0x29, 0xe7, # .Usage Maximum (231) 39 |
| 0x15, 0x00, # .Logical Minimum (0) 41 |
| 0x25, 0x01, # .Logical Maximum (1) 43 |
| 0x81, 0x02, # .Input (Data,Var,Abs) 45 |
| 0x95, 0x01, # .Report Count (1) 47 |
| 0x75, 0x08, # .Report Size (8) 49 |
| 0x81, 0x03, # .Input (Cnst,Var,Abs) 51 |
| 0x95, 0x05, # .Report Count (5) 53 |
| 0x75, 0x01, # .Report Size (1) 55 |
| 0x05, 0x08, # .Usage Page (LEDs) 57 |
| 0x19, 0x01, # .Usage Minimum (1) 59 |
| 0x29, 0x05, # .Usage Maximum (5) 61 |
| 0x91, 0x02, # .Output (Data,Var,Abs) 63 |
| 0x95, 0x01, # .Report Count (1) 65 |
| 0x75, 0x03, # .Report Size (3) 67 |
| 0x91, 0x03, # .Output (Cnst,Var,Abs) 69 |
| 0x95, 0x06, # .Report Count (6) 71 |
| 0x75, 0x08, # .Report Size (8) 73 |
| 0x15, 0x00, # .Logical Minimum (0) 75 |
| 0x26, 0xff, 0x00, # .Logical Maximum (255) 77 |
| 0x05, 0x07, # .Usage Page (Keyboard) 80 |
| 0x19, 0x00, # .Usage Minimum (0) 82 |
| 0x2a, 0xff, 0x00, # .Usage Maximum (255) 84 |
| 0x81, 0x00, # .Input (Data,Arr,Abs) 87 |
| 0xc0, # End Collection 89 |
| 0x05, 0x0c, # Usage Page (Consumer Devices) 90 |
| 0x09, 0x01, # Usage (Consumer Control) 92 |
| 0xa1, 0x01, # Collection (Application) 94 |
| 0x85, 0x02, # .Report ID (2) 96 |
| 0x19, 0x00, # .Usage Minimum (0) 98 |
| 0x2a, 0x3c, 0x02, # .Usage Maximum (572) 100 |
| 0x15, 0x00, # .Logical Minimum (0) 103 |
| 0x26, 0x3c, 0x02, # .Logical Maximum (572) 105 |
| 0x75, 0x10, # .Report Size (16) 108 |
| 0x95, 0x01, # .Report Count (1) 110 |
| 0x81, 0x00, # .Input (Data,Arr,Abs) 112 |
| 0xc0, # End Collection 114 |
| 0x05, 0x01, # Usage Page (Generic Desktop) 115 |
| 0x09, 0x0c, # Usage (Wireless Radio Controls) 117 |
| 0xa1, 0x01, # Collection (Application) 119 |
| 0x85, 0x03, # .Report ID (3) 121 |
| 0x15, 0x00, # .Logical Minimum (0) 123 |
| 0x25, 0x01, # .Logical Maximum (1) 125 |
| 0x09, 0xc6, # .Usage (Wireless Radio Button) 127 |
| 0x95, 0x01, # .Report Count (1) 129 |
| 0x75, 0x01, # .Report Size (1) 131 |
| 0x81, 0x06, # .Input (Data,Var,Rel) 133 |
| 0x75, 0x07, # .Report Size (7) 135 |
| 0x81, 0x03, # .Input (Cnst,Var,Abs) 137 |
| 0xc0, # End Collection 139 |
| 0x05, 0x88, # Usage Page (Vendor Usage Page 0x88) 140 |
| 0x09, 0x01, # Usage (Vendor Usage 0x01) 142 |
| 0xa1, 0x01, # Collection (Application) 144 |
| 0x85, 0x04, # .Report ID (4) 146 |
| 0x19, 0x00, # .Usage Minimum (0) 148 |
| 0x2a, 0xff, 0xff, # .Usage Maximum (65535) 150 |
| 0x15, 0x00, # .Logical Minimum (0) 153 |
| 0x26, 0xff, 0xff, # .Logical Maximum (65535) 155 |
| 0x75, 0x08, # .Report Size (8) 158 |
| 0x95, 0x02, # .Report Count (2) 160 |
| 0x81, 0x02, # .Input (Data,Var,Abs) 162 |
| 0xc0, # End Collection 164 |
| 0x05, 0x01, # Usage Page (Generic Desktop) 165 |
| 0x09, 0x80, # Usage (System Control) 167 |
| 0xa1, 0x01, # Collection (Application) 169 |
| 0x85, 0x05, # .Report ID (5) 171 |
| 0x19, 0x81, # .Usage Minimum (129) 173 |
| 0x29, 0x83, # .Usage Maximum (131) 175 |
| 0x15, 0x00, # .Logical Minimum (0) 177 |
| 0x25, 0x01, # .Logical Maximum (1) 179 |
| 0x95, 0x08, # .Report Count (8) 181 |
| 0x75, 0x01, # .Report Size (1) 183 |
| 0x81, 0x02, # .Input (Data,Var,Abs) 185 |
| 0xc0, # End Collection 187 |
| ] |
| # fmt: on |
| |
| def __init__( |
| self, |
| rdesc=report_descriptor, |
| name=None, |
| input_info=(BusType.USB, 0x06CB, 0x2968), |
| ): |
| super().__init__(rdesc, name, input_info) |
| |
| def event(self, keys, reportID=None, application=None): |
| application = application or "Keyboard" |
| return super().event(keys, reportID, application) |
| |
| |
| class TestITEKeyboard(TestArrayKeyboard): |
| kernel_modules = [KERNEL_MODULE] |
| |
| def create_device(self): |
| return ITEKeyboard() |
| |
| def test_wifi_key(self): |
| uhdev = self.uhdev |
| syn_event = self.syn_event |
| |
| # the following sends a 'release' event on the Wifi key. |
| # the kernel is supposed to translate this into Wifi key |
| # down and up |
| r = [0x03, 0x00] |
| uhdev.call_input_event(r) |
| expected = [syn_event] |
| expected.append(libevdev.InputEvent(libevdev.EV_KEY.KEY_RFKILL, 1)) |
| events = uhdev.next_sync_events() |
| self.debug_reports([r], uhdev, events) |
| self.assertInputEventsIn(expected, events) |
| |
| expected = [syn_event] |
| expected.append(libevdev.InputEvent(libevdev.EV_KEY.KEY_RFKILL, 0)) |
| # the kernel sends the two down/up key events in a batch, no need to |
| # call events = uhdev.next_sync_events() |
| self.debug_reports([], uhdev, events) |
| self.assertInputEventsIn(expected, events) |