hid-topseed.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * HID driver for TopSeed Cyberlink remote
  4. *
  5. * Copyright (c) 2008 Lev Babiev
  6. * based on hid-cherry driver
  7. *
  8. * Modified to also support BTC "Emprex 3009URF III Vista MCE Remote" by
  9. * Wayne Thomas 2010.
  10. *
  11. * Modified to support Conceptronic CLLRCMCE by
  12. * Kees Bakker 2010.
  13. */
  14. /*
  15. */
  16. #include <linux/device.h>
  17. #include <linux/hid.h>
  18. #include <linux/module.h>
  19. #include "hid-ids.h"
  20. #define ts_map_key_clear(c) hid_map_usage_clear(hi, usage, bit, max, \
  21. EV_KEY, (c))
  22. static int ts_input_mapping(struct hid_device *hdev, struct hid_input *hi,
  23. struct hid_field *field, struct hid_usage *usage,
  24. unsigned long **bit, int *max)
  25. {
  26. if ((usage->hid & HID_USAGE_PAGE) != HID_UP_LOGIVENDOR)
  27. return 0;
  28. switch (usage->hid & HID_USAGE) {
  29. case 0x00c: ts_map_key_clear(KEY_WLAN); break;
  30. case 0x00d: ts_map_key_clear(KEY_MEDIA); break;
  31. case 0x010: ts_map_key_clear(KEY_ZOOM); break;
  32. case 0x024: ts_map_key_clear(KEY_MENU); break;
  33. case 0x025: ts_map_key_clear(KEY_TV); break;
  34. case 0x027: ts_map_key_clear(KEY_MODE); break;
  35. case 0x031: ts_map_key_clear(KEY_AUDIO); break;
  36. case 0x032: ts_map_key_clear(KEY_TEXT); break;
  37. case 0x033: ts_map_key_clear(KEY_CHANNEL); break;
  38. case 0x047: ts_map_key_clear(KEY_MP3); break;
  39. case 0x048: ts_map_key_clear(KEY_TV2); break;
  40. case 0x049: ts_map_key_clear(KEY_CAMERA); break;
  41. case 0x04a: ts_map_key_clear(KEY_VIDEO); break;
  42. case 0x04b: ts_map_key_clear(KEY_ANGLE); break;
  43. case 0x04c: ts_map_key_clear(KEY_LANGUAGE); break;
  44. case 0x04d: ts_map_key_clear(KEY_SUBTITLE); break;
  45. case 0x050: ts_map_key_clear(KEY_RADIO); break;
  46. case 0x05a: ts_map_key_clear(KEY_TEXT); break;
  47. case 0x05b: ts_map_key_clear(KEY_RED); break;
  48. case 0x05c: ts_map_key_clear(KEY_GREEN); break;
  49. case 0x05d: ts_map_key_clear(KEY_YELLOW); break;
  50. case 0x05e: ts_map_key_clear(KEY_BLUE); break;
  51. default:
  52. return 0;
  53. }
  54. return 1;
  55. }
  56. static const struct hid_device_id ts_devices[] = {
  57. { HID_USB_DEVICE(USB_VENDOR_ID_TOPSEED, USB_DEVICE_ID_TOPSEED_CYBERLINK) },
  58. { HID_USB_DEVICE(USB_VENDOR_ID_BTC, USB_DEVICE_ID_BTC_EMPREX_REMOTE) },
  59. { HID_USB_DEVICE(USB_VENDOR_ID_BTC, USB_DEVICE_ID_BTC_EMPREX_REMOTE_2) },
  60. { HID_USB_DEVICE(USB_VENDOR_ID_TOPSEED2, USB_DEVICE_ID_TOPSEED2_RF_COMBO) },
  61. { HID_USB_DEVICE(USB_VENDOR_ID_CHICONY, USB_DEVICE_ID_CHICONY_WIRELESS) },
  62. { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_CHICONY, USB_DEVICE_ID_CHICONY_TOSHIBA_WT10A) },
  63. { }
  64. };
  65. MODULE_DEVICE_TABLE(hid, ts_devices);
  66. static struct hid_driver ts_driver = {
  67. .name = "topseed",
  68. .id_table = ts_devices,
  69. .input_mapping = ts_input_mapping,
  70. };
  71. module_hid_driver(ts_driver);
  72. MODULE_LICENSE("GPL");