1/* 2 * USB Serial "Simple" driver 3 * 4 * Copyright (C) 2001-2006,2008,2013 Greg Kroah-Hartman <greg@kroah.com> 5 * Copyright (C) 2005 Arthur Huillet (ahuillet@users.sf.net) 6 * Copyright (C) 2005 Thomas Hergenhahn <thomas.hergenhahn@suse.de> 7 * Copyright (C) 2009 Outpost Embedded, LLC 8 * Copyright (C) 2010 Zilogic Systems <code@zilogic.com> 9 * Copyright (C) 2013 Wei Shuai <cpuwolf@gmail.com> 10 * Copyright (C) 2013 Linux Foundation 11 * 12 * This program is free software; you can redistribute it and/or 13 * modify it under the terms of the GNU General Public License version 14 * 2 as published by the Free Software Foundation. 15 */ 16 17#include <linux/kernel.h> 18#include <linux/tty.h> 19#include <linux/module.h> 20#include <linux/usb.h> 21#include <linux/usb/serial.h> 22 23#define DEVICE_N(vendor, IDS, nport) \ 24static const struct usb_device_id vendor##_id_table[] = { \ 25 IDS(), \ 26 { }, \ 27}; \ 28static struct usb_serial_driver vendor##_device = { \ 29 .driver = { \ 30 .owner = THIS_MODULE, \ 31 .name = #vendor, \ 32 }, \ 33 .id_table = vendor##_id_table, \ 34 .num_ports = nport, \ 35}; 36 37#define DEVICE(vendor, IDS) DEVICE_N(vendor, IDS, 1) 38 39/* Medtronic CareLink USB driver */ 40#define CARELINK_IDS() \ 41 { USB_DEVICE(0x0a21, 0x8001) } /* MMT-7305WW */ 42DEVICE(carelink, CARELINK_IDS); 43 44/* ZIO Motherboard USB driver */ 45#define ZIO_IDS() \ 46 { USB_DEVICE(0x1CBE, 0x0103) } 47DEVICE(zio, ZIO_IDS); 48 49/* Funsoft Serial USB driver */ 50#define FUNSOFT_IDS() \ 51 { USB_DEVICE(0x1404, 0xcddc) } 52DEVICE(funsoft, FUNSOFT_IDS); 53 54/* Infineon Flashloader driver */ 55#define FLASHLOADER_IDS() \ 56 { USB_DEVICE_INTERFACE_CLASS(0x058b, 0x0041, USB_CLASS_CDC_DATA) }, \ 57 { USB_DEVICE(0x8087, 0x0716) } 58DEVICE(flashloader, FLASHLOADER_IDS); 59 60/* Google Serial USB SubClass */ 61#define GOOGLE_IDS() \ 62 { USB_VENDOR_AND_INTERFACE_INFO(0x18d1, \ 63 USB_CLASS_VENDOR_SPEC, \ 64 0x50, \ 65 0x01) } 66DEVICE(google, GOOGLE_IDS); 67 68/* ViVOpay USB Serial Driver */ 69#define VIVOPAY_IDS() \ 70 { USB_DEVICE(0x1d5f, 0x1004) } /* ViVOpay 8800 */ 71DEVICE(vivopay, VIVOPAY_IDS); 72 73/* Motorola USB Phone driver */ 74#define MOTO_IDS() \ 75 { USB_DEVICE(0x05c6, 0x3197) }, /* unknown Motorola phone */ \ 76 { USB_DEVICE(0x0c44, 0x0022) }, /* unknown Motorola phone */ \ 77 { USB_DEVICE(0x22b8, 0x2a64) }, /* Motorola KRZR K1m */ \ 78 { USB_DEVICE(0x22b8, 0x2c84) }, /* Motorola VE240 phone */ \ 79 { USB_DEVICE(0x22b8, 0x2c64) } /* Motorola V950 phone */ 80DEVICE(moto_modem, MOTO_IDS); 81 82/* Novatel Wireless GPS driver */ 83#define NOVATEL_IDS() \ 84 { USB_DEVICE(0x09d7, 0x0100) } /* NovAtel FlexPack GPS */ 85DEVICE_N(novatel_gps, NOVATEL_IDS, 3); 86 87/* HP4x (48/49) Generic Serial driver */ 88#define HP4X_IDS() \ 89 { USB_DEVICE(0x03f0, 0x0121) } 90DEVICE(hp4x, HP4X_IDS); 91 92/* Suunto ANT+ USB Driver */ 93#define SUUNTO_IDS() \ 94 { USB_DEVICE(0x0fcf, 0x1008) }, \ 95 { USB_DEVICE(0x0fcf, 0x1009) } /* Dynastream ANT USB-m Stick */ 96DEVICE(suunto, SUUNTO_IDS); 97 98/* Siemens USB/MPI adapter */ 99#define SIEMENS_IDS() \ 100 { USB_DEVICE(0x908, 0x0004) } 101DEVICE(siemens_mpi, SIEMENS_IDS); 102 103/* All of the above structures mushed into two lists */ 104static struct usb_serial_driver * const serial_drivers[] = { 105 &carelink_device, 106 &zio_device, 107 &funsoft_device, 108 &flashloader_device, 109 &google_device, 110 &vivopay_device, 111 &moto_modem_device, 112 &novatel_gps_device, 113 &hp4x_device, 114 &suunto_device, 115 &siemens_mpi_device, 116 NULL 117}; 118 119static const struct usb_device_id id_table[] = { 120 CARELINK_IDS(), 121 ZIO_IDS(), 122 FUNSOFT_IDS(), 123 FLASHLOADER_IDS(), 124 GOOGLE_IDS(), 125 VIVOPAY_IDS(), 126 MOTO_IDS(), 127 NOVATEL_IDS(), 128 HP4X_IDS(), 129 SUUNTO_IDS(), 130 SIEMENS_IDS(), 131 { }, 132}; 133MODULE_DEVICE_TABLE(usb, id_table); 134 135module_usb_serial_driver(serial_drivers, id_table); 136MODULE_LICENSE("GPL"); 137