1a251d657SJosé Expósito // SPDX-License-Identifier: GPL-2.0+ 2a251d657SJosé Expósito 3a251d657SJosé Expósito /* 4a251d657SJosé Expósito * HID driver for UC-Logic devices not fully compliant with HID standard 5a251d657SJosé Expósito * 6a251d657SJosé Expósito * Copyright (c) 2022 José Expósito <jose.exposito89@gmail.com> 7a251d657SJosé Expósito */ 8a251d657SJosé Expósito 9a251d657SJosé Expósito #include <kunit/test.h> 10a251d657SJosé Expósito #include "./hid-uclogic-params.h" 11a251d657SJosé Expósito 12a251d657SJosé Expósito #define MAX_EVENT_SIZE 12 13a251d657SJosé Expósito 14a251d657SJosé Expósito struct uclogic_raw_event_hook_test { 15a251d657SJosé Expósito u8 event[MAX_EVENT_SIZE]; 16a251d657SJosé Expósito size_t size; 17a251d657SJosé Expósito bool expected; 18a251d657SJosé Expósito }; 19a251d657SJosé Expósito 20a251d657SJosé Expósito static struct uclogic_raw_event_hook_test hook_events[] = { 21a251d657SJosé Expósito { 22a251d657SJosé Expósito .event = { 0xA1, 0xB2, 0xC3, 0xD4 }, 23a251d657SJosé Expósito .size = 4, 24a251d657SJosé Expósito }, 25a251d657SJosé Expósito { 26a251d657SJosé Expósito .event = { 0x1F, 0x2E, 0x3D, 0x4C, 0x5B, 0x6A }, 27a251d657SJosé Expósito .size = 6, 28a251d657SJosé Expósito }, 29a251d657SJosé Expósito }; 30a251d657SJosé Expósito 31a251d657SJosé Expósito static struct uclogic_raw_event_hook_test test_events[] = { 32a251d657SJosé Expósito { 33a251d657SJosé Expósito .event = { 0xA1, 0xB2, 0xC3, 0xD4 }, 34a251d657SJosé Expósito .size = 4, 35a251d657SJosé Expósito .expected = true, 36a251d657SJosé Expósito }, 37a251d657SJosé Expósito { 38a251d657SJosé Expósito .event = { 0x1F, 0x2E, 0x3D, 0x4C, 0x5B, 0x6A }, 39a251d657SJosé Expósito .size = 6, 40a251d657SJosé Expósito .expected = true, 41a251d657SJosé Expósito }, 42a251d657SJosé Expósito { 43a251d657SJosé Expósito .event = { 0xA1, 0xB2, 0xC3 }, 44a251d657SJosé Expósito .size = 3, 45a251d657SJosé Expósito .expected = false, 46a251d657SJosé Expósito }, 47a251d657SJosé Expósito { 48a251d657SJosé Expósito .event = { 0xA1, 0xB2, 0xC3, 0xD4, 0x00 }, 49a251d657SJosé Expósito .size = 5, 50a251d657SJosé Expósito .expected = false, 51a251d657SJosé Expósito }, 52a251d657SJosé Expósito { 53a251d657SJosé Expósito .event = { 0x2E, 0x3D, 0x4C, 0x5B, 0x6A, 0x1F }, 54a251d657SJosé Expósito .size = 6, 55a251d657SJosé Expósito .expected = false, 56a251d657SJosé Expósito }, 57a251d657SJosé Expósito }; 58a251d657SJosé Expósito 59*8387d39aSJinjie Ruan static void fake_work(struct work_struct *work) 60*8387d39aSJinjie Ruan { 61*8387d39aSJinjie Ruan 62*8387d39aSJinjie Ruan } 63*8387d39aSJinjie Ruan 64a251d657SJosé Expósito static void hid_test_uclogic_exec_event_hook_test(struct kunit *test) 65a251d657SJosé Expósito { 66a251d657SJosé Expósito struct uclogic_params p = {0, }; 67a251d657SJosé Expósito struct uclogic_raw_event_hook *filter; 68a251d657SJosé Expósito bool res; 69a251d657SJosé Expósito int n; 70a251d657SJosé Expósito 71a251d657SJosé Expósito /* Initialize the list of events to hook */ 72a251d657SJosé Expósito p.event_hooks = kunit_kzalloc(test, sizeof(*p.event_hooks), GFP_KERNEL); 73a251d657SJosé Expósito KUNIT_ASSERT_NOT_ERR_OR_NULL(test, p.event_hooks); 74a251d657SJosé Expósito INIT_LIST_HEAD(&p.event_hooks->list); 75a251d657SJosé Expósito 76a251d657SJosé Expósito for (n = 0; n < ARRAY_SIZE(hook_events); n++) { 77a251d657SJosé Expósito filter = kunit_kzalloc(test, sizeof(*filter), GFP_KERNEL); 78a251d657SJosé Expósito KUNIT_ASSERT_NOT_ERR_OR_NULL(test, filter); 79a251d657SJosé Expósito 80a251d657SJosé Expósito filter->size = hook_events[n].size; 81a251d657SJosé Expósito filter->event = kunit_kzalloc(test, filter->size, GFP_KERNEL); 82a251d657SJosé Expósito KUNIT_ASSERT_NOT_ERR_OR_NULL(test, filter->event); 83a251d657SJosé Expósito memcpy(filter->event, &hook_events[n].event[0], filter->size); 84a251d657SJosé Expósito 85*8387d39aSJinjie Ruan INIT_WORK(&filter->work, fake_work); 86*8387d39aSJinjie Ruan 87a251d657SJosé Expósito list_add_tail(&filter->list, &p.event_hooks->list); 88a251d657SJosé Expósito } 89a251d657SJosé Expósito 90a251d657SJosé Expósito /* Test uclogic_exec_event_hook() */ 91a251d657SJosé Expósito for (n = 0; n < ARRAY_SIZE(test_events); n++) { 92a251d657SJosé Expósito res = uclogic_exec_event_hook(&p, &test_events[n].event[0], 93a251d657SJosé Expósito test_events[n].size); 94a251d657SJosé Expósito KUNIT_ASSERT_EQ(test, res, test_events[n].expected); 95a251d657SJosé Expósito } 96a251d657SJosé Expósito } 97a251d657SJosé Expósito 98a251d657SJosé Expósito static struct kunit_case hid_uclogic_core_test_cases[] = { 99a251d657SJosé Expósito KUNIT_CASE(hid_test_uclogic_exec_event_hook_test), 100a251d657SJosé Expósito {} 101a251d657SJosé Expósito }; 102a251d657SJosé Expósito 103a251d657SJosé Expósito static struct kunit_suite hid_uclogic_core_test_suite = { 104a251d657SJosé Expósito .name = "hid_uclogic_core_test", 105a251d657SJosé Expósito .test_cases = hid_uclogic_core_test_cases, 106a251d657SJosé Expósito }; 107a251d657SJosé Expósito 108a251d657SJosé Expósito kunit_test_suite(hid_uclogic_core_test_suite); 109a251d657SJosé Expósito 110a251d657SJosé Expósito MODULE_DESCRIPTION("KUnit tests for the UC-Logic driver"); 111a251d657SJosé Expósito MODULE_LICENSE("GPL"); 112a251d657SJosé Expósito MODULE_AUTHOR("José Expósito <jose.exposito89@gmail.com>"); 113