18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * USB HID quirks support for Network Technologies, Inc. "USB-SUN" USB 48c2ecf20Sopenharmony_ci * adapter for pre-USB Sun keyboards 58c2ecf20Sopenharmony_ci * 68c2ecf20Sopenharmony_ci * Copyright (c) 2011 Google, Inc. 78c2ecf20Sopenharmony_ci * 88c2ecf20Sopenharmony_ci * Based on HID apple driver by 98c2ecf20Sopenharmony_ci * Copyright (c) 1999 Andreas Gal 108c2ecf20Sopenharmony_ci * Copyright (c) 2000-2005 Vojtech Pavlik <vojtech@suse.cz> 118c2ecf20Sopenharmony_ci * Copyright (c) 2005 Michael Haboustak <mike-@cinci.rr.com> for Concept2, Inc 128c2ecf20Sopenharmony_ci * Copyright (c) 2006-2007 Jiri Kosina 138c2ecf20Sopenharmony_ci * Copyright (c) 2008 Jiri Slaby <jirislaby@gmail.com> 148c2ecf20Sopenharmony_ci */ 158c2ecf20Sopenharmony_ci 168c2ecf20Sopenharmony_ci/* 178c2ecf20Sopenharmony_ci */ 188c2ecf20Sopenharmony_ci 198c2ecf20Sopenharmony_ci#include <linux/device.h> 208c2ecf20Sopenharmony_ci#include <linux/input.h> 218c2ecf20Sopenharmony_ci#include <linux/hid.h> 228c2ecf20Sopenharmony_ci#include <linux/module.h> 238c2ecf20Sopenharmony_ci 248c2ecf20Sopenharmony_ci#include "hid-ids.h" 258c2ecf20Sopenharmony_ci 268c2ecf20Sopenharmony_ciMODULE_AUTHOR("Jonathan Klabunde Tomer <jktomer@google.com>"); 278c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("HID driver for Network Technologies USB-SUN keyboard adapter"); 288c2ecf20Sopenharmony_ci 298c2ecf20Sopenharmony_ci/* 308c2ecf20Sopenharmony_ci * NTI Sun keyboard adapter has wrong logical maximum in report descriptor 318c2ecf20Sopenharmony_ci */ 328c2ecf20Sopenharmony_cistatic __u8 *nti_usbsun_report_fixup(struct hid_device *hdev, __u8 *rdesc, 338c2ecf20Sopenharmony_ci unsigned int *rsize) 348c2ecf20Sopenharmony_ci{ 358c2ecf20Sopenharmony_ci if (*rsize >= 60 && rdesc[53] == 0x65 && rdesc[59] == 0x65) { 368c2ecf20Sopenharmony_ci hid_info(hdev, "fixing up NTI USB-SUN keyboard adapter report descriptor\n"); 378c2ecf20Sopenharmony_ci rdesc[53] = rdesc[59] = 0xe7; 388c2ecf20Sopenharmony_ci } 398c2ecf20Sopenharmony_ci return rdesc; 408c2ecf20Sopenharmony_ci} 418c2ecf20Sopenharmony_ci 428c2ecf20Sopenharmony_cistatic const struct hid_device_id nti_devices[] = { 438c2ecf20Sopenharmony_ci { HID_USB_DEVICE(USB_VENDOR_ID_NTI, USB_DEVICE_ID_USB_SUN) }, 448c2ecf20Sopenharmony_ci { } 458c2ecf20Sopenharmony_ci}; 468c2ecf20Sopenharmony_ciMODULE_DEVICE_TABLE(hid, nti_devices); 478c2ecf20Sopenharmony_ci 488c2ecf20Sopenharmony_cistatic struct hid_driver nti_driver = { 498c2ecf20Sopenharmony_ci .name = "nti", 508c2ecf20Sopenharmony_ci .id_table = nti_devices, 518c2ecf20Sopenharmony_ci .report_fixup = nti_usbsun_report_fixup 528c2ecf20Sopenharmony_ci}; 538c2ecf20Sopenharmony_ci 548c2ecf20Sopenharmony_cimodule_hid_driver(nti_driver); 558c2ecf20Sopenharmony_ci 568c2ecf20Sopenharmony_ciMODULE_LICENSE("GPL"); 57