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