cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

usb-serial-simple.c (4379B)


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