usb-serial-simple.c 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * USB Serial "Simple" driver
  4. *
  5. * Copyright (C) 2001-2006,2008,2013 Greg Kroah-Hartman <greg@kroah.com>
  6. * Copyright (C) 2005 Arthur Huillet (ahuillet@users.sf.net)
  7. * Copyright (C) 2005 Thomas Hergenhahn <thomas.hergenhahn@suse.de>
  8. * Copyright (C) 2009 Outpost Embedded, LLC
  9. * Copyright (C) 2010 Zilogic Systems <code@zilogic.com>
  10. * Copyright (C) 2013 Wei Shuai <cpuwolf@gmail.com>
  11. * Copyright (C) 2013 Linux Foundation
  12. */
  13. #include <linux/kernel.h>
  14. #include <linux/tty.h>
  15. #include <linux/module.h>
  16. #include <linux/usb.h>
  17. #include <linux/usb/serial.h>
  18. #define DEVICE_N(vendor, IDS, nport) \
  19. static const struct usb_device_id vendor##_id_table[] = { \
  20. IDS(), \
  21. { }, \
  22. }; \
  23. static struct usb_serial_driver vendor##_device = { \
  24. .driver = { \
  25. .name = #vendor, \
  26. }, \
  27. .id_table = vendor##_id_table, \
  28. .num_ports = nport, \
  29. };
  30. #define DEVICE(vendor, IDS) DEVICE_N(vendor, IDS, 1)
  31. /* Medtronic CareLink USB driver */
  32. #define CARELINK_IDS() \
  33. { USB_DEVICE(0x0a21, 0x8001) } /* MMT-7305WW */
  34. DEVICE(carelink, CARELINK_IDS);
  35. /* Infineon Flashloader driver */
  36. #define FLASHLOADER_IDS() \
  37. { USB_DEVICE_INTERFACE_CLASS(0x058b, 0x0041, USB_CLASS_CDC_DATA) }, \
  38. { USB_DEVICE(0x8087, 0x0716) }, \
  39. { USB_DEVICE(0x8087, 0x0801) }
  40. DEVICE(flashloader, FLASHLOADER_IDS);
  41. /* Funsoft Serial USB driver */
  42. #define FUNSOFT_IDS() \
  43. { USB_DEVICE(0x1404, 0xcddc) }
  44. DEVICE(funsoft, FUNSOFT_IDS);
  45. /* Google Serial USB SubClass */
  46. #define GOOGLE_IDS() \
  47. { USB_VENDOR_AND_INTERFACE_INFO(0x18d1, \
  48. USB_CLASS_VENDOR_SPEC, \
  49. 0x50, \
  50. 0x01) }
  51. DEVICE(google, GOOGLE_IDS);
  52. /* HP4x (48/49) Generic Serial driver */
  53. #define HP4X_IDS() \
  54. { USB_DEVICE(0x03f0, 0x0121) }
  55. DEVICE(hp4x, HP4X_IDS);
  56. /* KAUFMANN RKS+CAN VCP */
  57. #define KAUFMANN_IDS() \
  58. { USB_DEVICE(0x16d0, 0x0870) }
  59. DEVICE(kaufmann, KAUFMANN_IDS);
  60. /* Libtransistor USB console */
  61. #define LIBTRANSISTOR_IDS() \
  62. { USB_DEVICE(0x1209, 0x8b00) }
  63. DEVICE(libtransistor, LIBTRANSISTOR_IDS);
  64. /* Motorola USB Phone driver */
  65. #define MOTO_IDS() \
  66. { USB_DEVICE(0x05c6, 0x3197) }, /* unknown Motorola phone */ \
  67. { USB_DEVICE(0x0c44, 0x0022) }, /* unknown Motorola phone */ \
  68. { USB_DEVICE(0x22b8, 0x2a64) }, /* Motorola KRZR K1m */ \
  69. { USB_DEVICE(0x22b8, 0x2c84) }, /* Motorola VE240 phone */ \
  70. { USB_DEVICE(0x22b8, 0x2c64) } /* Motorola V950 phone */
  71. DEVICE(moto_modem, MOTO_IDS);
  72. /* Motorola Tetra driver */
  73. #define MOTOROLA_TETRA_IDS() \
  74. { USB_DEVICE(0x0cad, 0x9011) }, /* Motorola Solutions TETRA PEI */ \
  75. { USB_DEVICE(0x0cad, 0x9012) }, /* MTP6550 */ \
  76. { USB_DEVICE(0x0cad, 0x9013) }, /* MTP3xxx */ \
  77. { USB_DEVICE(0x0cad, 0x9015) }, /* MTP85xx */ \
  78. { USB_DEVICE(0x0cad, 0x9016) } /* TPG2200 */
  79. DEVICE(motorola_tetra, MOTOROLA_TETRA_IDS);
  80. /* Nokia mobile phone driver */
  81. #define NOKIA_IDS() \
  82. { USB_DEVICE(0x0421, 0x069a) } /* Nokia 130 (RM-1035) */
  83. DEVICE(nokia, NOKIA_IDS);
  84. /* Novatel Wireless GPS driver */
  85. #define NOVATEL_IDS() \
  86. { USB_DEVICE(0x09d7, 0x0100) } /* NovAtel FlexPack GPS */
  87. DEVICE_N(novatel_gps, NOVATEL_IDS, 3);
  88. /* OWON electronic test and measurement equipment driver */
  89. #define OWON_IDS() \
  90. { USB_DEVICE(0x5345, 0x1234) } /* HDS200 oscilloscopes and others */
  91. DEVICE(owon, OWON_IDS);
  92. /* Siemens USB/MPI adapter */
  93. #define SIEMENS_IDS() \
  94. { USB_DEVICE(0x908, 0x0004) }
  95. DEVICE(siemens_mpi, SIEMENS_IDS);
  96. /* Suunto ANT+ USB Driver */
  97. #define SUUNTO_IDS() \
  98. { USB_DEVICE(0x0fcf, 0x1008) }, \
  99. { USB_DEVICE(0x0fcf, 0x1009) } /* Dynastream ANT USB-m Stick */
  100. DEVICE(suunto, SUUNTO_IDS);
  101. /* ViVOpay USB Serial Driver */
  102. #define VIVOPAY_IDS() \
  103. { USB_DEVICE(0x1d5f, 0x1004) } /* ViVOpay 8800 */
  104. DEVICE(vivopay, VIVOPAY_IDS);
  105. /* ZIO Motherboard USB driver */
  106. #define ZIO_IDS() \
  107. { USB_DEVICE(0x1CBE, 0x0103) }
  108. DEVICE(zio, ZIO_IDS);
  109. /* All of the above structures mushed into two lists */
  110. static struct usb_serial_driver * const serial_drivers[] = {
  111. &carelink_device,
  112. &flashloader_device,
  113. &funsoft_device,
  114. &google_device,
  115. &hp4x_device,
  116. &kaufmann_device,
  117. &libtransistor_device,
  118. &moto_modem_device,
  119. &motorola_tetra_device,
  120. &nokia_device,
  121. &novatel_gps_device,
  122. &owon_device,
  123. &siemens_mpi_device,
  124. &suunto_device,
  125. &vivopay_device,
  126. &zio_device,
  127. NULL
  128. };
  129. static const struct usb_device_id id_table[] = {
  130. CARELINK_IDS(),
  131. FLASHLOADER_IDS(),
  132. FUNSOFT_IDS(),
  133. GOOGLE_IDS(),
  134. HP4X_IDS(),
  135. KAUFMANN_IDS(),
  136. LIBTRANSISTOR_IDS(),
  137. MOTO_IDS(),
  138. MOTOROLA_TETRA_IDS(),
  139. NOKIA_IDS(),
  140. NOVATEL_IDS(),
  141. OWON_IDS(),
  142. SIEMENS_IDS(),
  143. SUUNTO_IDS(),
  144. VIVOPAY_IDS(),
  145. ZIO_IDS(),
  146. { },
  147. };
  148. MODULE_DEVICE_TABLE(usb, id_table);
  149. module_usb_serial_driver(serial_drivers, id_table);
  150. MODULE_DESCRIPTION("USB Serial 'Simple' driver");
  151. MODULE_LICENSE("GPL v2");