2005-04-17 02:20:36 +04:00
/*
Keyspan USB to Serial Converter driver
( C ) Copyright ( C ) 2000 - 2001
Hugh Blemings < hugh @ blemings . org >
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation ; either version 2 of the License , or
( at your option ) any later version .
See http : //misc.nu/hugh/keyspan.html for more information.
Code in this driver inspired by and in a number of places taken
from Brian Warner ' s original Keyspan - PDA driver .
This driver has been put together with the support of Innosys , Inc .
and Keyspan , Inc the manufacturers of the Keyspan USB - serial products .
Thanks Guys : )
Thanks to Paulus for miscellaneous tidy ups , some largish chunks
of much nicer and / or completely new code and ( perhaps most uniquely )
having the patience to sit down and explain why and where he ' d changed
stuff .
Tip ' o the hat to IBM ( and previously Linuxcare : ) for supporting
staff in their work on open source projects .
See keyspan . c for update history .
*/
# ifndef __LINUX_USB_SERIAL_KEYSPAN_H
# define __LINUX_USB_SERIAL_KEYSPAN_H
/* Function prototypes for Keyspan serial converter */
2008-07-22 14:09:07 +04:00
static int keyspan_open ( struct tty_struct * tty ,
2009-09-20 00:13:26 +04:00
struct usb_serial_port * port ) ;
2009-06-11 15:26:29 +04:00
static void keyspan_close ( struct usb_serial_port * port ) ;
static void keyspan_dtr_rts ( struct usb_serial_port * port , int on ) ;
2005-04-17 02:20:36 +04:00
static int keyspan_startup ( struct usb_serial * serial ) ;
2009-06-02 19:53:55 +04:00
static void keyspan_disconnect ( struct usb_serial * serial ) ;
static void keyspan_release ( struct usb_serial * serial ) ;
2008-07-22 14:09:07 +04:00
static int keyspan_write_room ( struct tty_struct * tty ) ;
2005-04-17 02:20:36 +04:00
2008-07-22 14:09:07 +04:00
static int keyspan_write ( struct tty_struct * tty ,
struct usb_serial_port * port ,
2005-04-17 02:20:36 +04:00
const unsigned char * buf ,
int count ) ;
static void keyspan_send_setup ( struct usb_serial_port * port ,
int reset_port ) ;
2008-07-22 14:09:07 +04:00
static void keyspan_set_termios ( struct tty_struct * tty ,
struct usb_serial_port * port ,
2006-12-08 13:38:45 +03:00
struct ktermios * old ) ;
2008-07-22 14:09:07 +04:00
static void keyspan_break_ctl ( struct tty_struct * tty ,
2005-04-17 02:20:36 +04:00
int break_state ) ;
2008-07-22 14:09:07 +04:00
static int keyspan_tiocmget ( struct tty_struct * tty ,
2005-04-17 02:20:36 +04:00
struct file * file ) ;
2008-07-22 14:09:07 +04:00
static int keyspan_tiocmset ( struct tty_struct * tty ,
2005-04-17 02:20:36 +04:00
struct file * file , unsigned int set ,
unsigned int clear ) ;
static int keyspan_fake_startup ( struct usb_serial * serial ) ;
static int keyspan_usa19_calc_baud ( u32 baud_rate , u32 baudclk ,
u8 * rate_hi , u8 * rate_low ,
u8 * prescaler , int portnum ) ;
static int keyspan_usa19w_calc_baud ( u32 baud_rate , u32 baudclk ,
u8 * rate_hi , u8 * rate_low ,
u8 * prescaler , int portnum ) ;
static int keyspan_usa28_calc_baud ( u32 baud_rate , u32 baudclk ,
u8 * rate_hi , u8 * rate_low ,
u8 * prescaler , int portnum ) ;
static int keyspan_usa19hs_calc_baud ( u32 baud_rate , u32 baudclk ,
u8 * rate_hi , u8 * rate_low ,
u8 * prescaler , int portnum ) ;
static int keyspan_usa28_send_setup ( struct usb_serial * serial ,
struct usb_serial_port * port ,
int reset_port ) ;
static int keyspan_usa26_send_setup ( struct usb_serial * serial ,
struct usb_serial_port * port ,
int reset_port ) ;
static int keyspan_usa49_send_setup ( struct usb_serial * serial ,
struct usb_serial_port * port ,
int reset_port ) ;
static int keyspan_usa90_send_setup ( struct usb_serial * serial ,
struct usb_serial_port * port ,
int reset_port ) ;
2007-05-18 23:10:41 +04:00
static int keyspan_usa67_send_setup ( struct usb_serial * serial ,
struct usb_serial_port * port ,
int reset_port ) ;
2005-04-17 02:20:36 +04:00
/* Values used for baud rate calculation - device specific */
# define KEYSPAN_INVALID_BAUD_RATE (-1)
# define KEYSPAN_BAUD_RATE_OK (0)
# define KEYSPAN_USA18X_BAUDCLK (12000000L) /* a guess */
# define KEYSPAN_USA19_BAUDCLK (12000000L)
# define KEYSPAN_USA19W_BAUDCLK (24000000L)
# define KEYSPAN_USA19HS_BAUDCLK (14769231L)
# define KEYSPAN_USA28_BAUDCLK (1843200L)
# define KEYSPAN_USA28X_BAUDCLK (12000000L)
# define KEYSPAN_USA49W_BAUDCLK (48000000L)
/* Some constants used to characterise each device. */
# define KEYSPAN_MAX_NUM_PORTS (4)
# define KEYSPAN_MAX_FLIPS (2)
/* Device info for the Keyspan serial converter, used
by the overall usb - serial probe function */
# define KEYSPAN_VENDOR_ID (0x06cd)
/* Product IDs for the products supported, pre-renumeration */
# define keyspan_usa18x_pre_product_id 0x0105
# define keyspan_usa19_pre_product_id 0x0103
# define keyspan_usa19qi_pre_product_id 0x010b
# define keyspan_mpr_pre_product_id 0x011b
# define keyspan_usa19qw_pre_product_id 0x0118
# define keyspan_usa19w_pre_product_id 0x0106
# define keyspan_usa28_pre_product_id 0x0101
# define keyspan_usa28x_pre_product_id 0x0102
# define keyspan_usa28xa_pre_product_id 0x0114
# define keyspan_usa28xb_pre_product_id 0x0113
# define keyspan_usa49w_pre_product_id 0x0109
# define keyspan_usa49wlc_pre_product_id 0x011a
/* Product IDs post-renumeration. Note that the 28x and 28xb
have the same id ' s post - renumeration but behave identically
2008-06-27 04:08:16 +04:00
so it ' s not an issue . As such , the 28 xb is not listed in any
of the device tables . */
2005-04-17 02:20:36 +04:00
# define keyspan_usa18x_product_id 0x0112
# define keyspan_usa19_product_id 0x0107
# define keyspan_usa19qi_product_id 0x010c
# define keyspan_usa19hs_product_id 0x0121
# define keyspan_mpr_product_id 0x011c
# define keyspan_usa19qw_product_id 0x0119
# define keyspan_usa19w_product_id 0x0108
# define keyspan_usa28_product_id 0x010f
# define keyspan_usa28x_product_id 0x0110
# define keyspan_usa28xa_product_id 0x0115
2007-05-18 23:10:41 +04:00
# define keyspan_usa28xb_product_id 0x0110
# define keyspan_usa28xg_product_id 0x0135
2005-04-17 02:20:36 +04:00
# define keyspan_usa49w_product_id 0x010a
# define keyspan_usa49wlc_product_id 0x012a
2007-05-18 23:10:41 +04:00
# define keyspan_usa49wg_product_id 0x0131
2005-04-17 02:20:36 +04:00
struct keyspan_device_details {
/* product ID value */
int product_id ;
2007-05-18 23:10:41 +04:00
enum { msg_usa26 , msg_usa28 , msg_usa49 , msg_usa90 , msg_usa67 } msg_format ;
2005-04-17 02:20:36 +04:00
/* Number of physical ports */
int num_ports ;
/* 1 if endpoint flipping used on input, 0 if not */
int indat_endp_flip ;
/* 1 if endpoint flipping used on output, 0 if not */
int outdat_endp_flip ;
/* Table mapping input data endpoint IDs to physical
port number and flip if used */
int indat_endpoints [ KEYSPAN_MAX_NUM_PORTS ] ;
/* Same for output endpoints */
int outdat_endpoints [ KEYSPAN_MAX_NUM_PORTS ] ;
/* Input acknowledge endpoints */
int inack_endpoints [ KEYSPAN_MAX_NUM_PORTS ] ;
/* Output control endpoints */
int outcont_endpoints [ KEYSPAN_MAX_NUM_PORTS ] ;
/* Endpoint used for input status */
int instat_endpoint ;
2007-05-18 23:10:41 +04:00
/* Endpoint used for input data 49WG only */
int indat_endpoint ;
2005-04-17 02:20:36 +04:00
/* Endpoint used for global control functions */
int glocont_endpoint ;
int ( * calculate_baud_rate ) ( u32 baud_rate , u32 baudclk ,
u8 * rate_hi , u8 * rate_low , u8 * prescaler , int portnum ) ;
u32 baudclk ;
} ;
/* Now for each device type we setup the device detail
structure with the appropriate information ( provided
in Keyspan ' s documentation ) */
static const struct keyspan_device_details usa18x_device_details = {
. product_id = keyspan_usa18x_product_id ,
. msg_format = msg_usa26 ,
. num_ports = 1 ,
. indat_endp_flip = 0 ,
. outdat_endp_flip = 1 ,
. indat_endpoints = { 0x81 } ,
. outdat_endpoints = { 0x01 } ,
. inack_endpoints = { 0x85 } ,
. outcont_endpoints = { 0x05 } ,
. instat_endpoint = 0x87 ,
2007-05-18 23:10:41 +04:00
. indat_endpoint = - 1 ,
2005-04-17 02:20:36 +04:00
. glocont_endpoint = 0x07 ,
. calculate_baud_rate = keyspan_usa19w_calc_baud ,
. baudclk = KEYSPAN_USA18X_BAUDCLK ,
} ;
static const struct keyspan_device_details usa19_device_details = {
. product_id = keyspan_usa19_product_id ,
. msg_format = msg_usa28 ,
. num_ports = 1 ,
. indat_endp_flip = 1 ,
. outdat_endp_flip = 1 ,
. indat_endpoints = { 0x81 } ,
. outdat_endpoints = { 0x01 } ,
. inack_endpoints = { 0x83 } ,
. outcont_endpoints = { 0x03 } ,
. instat_endpoint = 0x84 ,
2007-05-18 23:10:41 +04:00
. indat_endpoint = - 1 ,
2005-04-17 02:20:36 +04:00
. glocont_endpoint = - 1 ,
. calculate_baud_rate = keyspan_usa19_calc_baud ,
. baudclk = KEYSPAN_USA19_BAUDCLK ,
} ;
static const struct keyspan_device_details usa19qi_device_details = {
. product_id = keyspan_usa19qi_product_id ,
. msg_format = msg_usa28 ,
. num_ports = 1 ,
. indat_endp_flip = 1 ,
. outdat_endp_flip = 1 ,
. indat_endpoints = { 0x81 } ,
. outdat_endpoints = { 0x01 } ,
. inack_endpoints = { 0x83 } ,
. outcont_endpoints = { 0x03 } ,
. instat_endpoint = 0x84 ,
2007-05-18 23:10:41 +04:00
. indat_endpoint = - 1 ,
2005-04-17 02:20:36 +04:00
. glocont_endpoint = - 1 ,
. calculate_baud_rate = keyspan_usa28_calc_baud ,
. baudclk = KEYSPAN_USA19_BAUDCLK ,
} ;
static const struct keyspan_device_details mpr_device_details = {
. product_id = keyspan_mpr_product_id ,
. msg_format = msg_usa28 ,
. num_ports = 1 ,
. indat_endp_flip = 1 ,
. outdat_endp_flip = 1 ,
. indat_endpoints = { 0x81 } ,
. outdat_endpoints = { 0x01 } ,
. inack_endpoints = { 0x83 } ,
. outcont_endpoints = { 0x03 } ,
. instat_endpoint = 0x84 ,
2007-05-18 23:10:41 +04:00
. indat_endpoint = - 1 ,
2005-04-17 02:20:36 +04:00
. glocont_endpoint = - 1 ,
. calculate_baud_rate = keyspan_usa28_calc_baud ,
. baudclk = KEYSPAN_USA19_BAUDCLK ,
} ;
static const struct keyspan_device_details usa19qw_device_details = {
. product_id = keyspan_usa19qw_product_id ,
. msg_format = msg_usa26 ,
. num_ports = 1 ,
. indat_endp_flip = 0 ,
. outdat_endp_flip = 1 ,
. indat_endpoints = { 0x81 } ,
. outdat_endpoints = { 0x01 } ,
. inack_endpoints = { 0x85 } ,
. outcont_endpoints = { 0x05 } ,
. instat_endpoint = 0x87 ,
2007-05-18 23:10:41 +04:00
. indat_endpoint = - 1 ,
2005-04-17 02:20:36 +04:00
. glocont_endpoint = 0x07 ,
. calculate_baud_rate = keyspan_usa19w_calc_baud ,
. baudclk = KEYSPAN_USA19W_BAUDCLK ,
} ;
static const struct keyspan_device_details usa19w_device_details = {
. product_id = keyspan_usa19w_product_id ,
. msg_format = msg_usa26 ,
. num_ports = 1 ,
. indat_endp_flip = 0 ,
. outdat_endp_flip = 1 ,
. indat_endpoints = { 0x81 } ,
. outdat_endpoints = { 0x01 } ,
. inack_endpoints = { 0x85 } ,
. outcont_endpoints = { 0x05 } ,
. instat_endpoint = 0x87 ,
2007-05-18 23:10:41 +04:00
. indat_endpoint = - 1 ,
2005-04-17 02:20:36 +04:00
. glocont_endpoint = 0x07 ,
. calculate_baud_rate = keyspan_usa19w_calc_baud ,
. baudclk = KEYSPAN_USA19W_BAUDCLK ,
} ;
static const struct keyspan_device_details usa19hs_device_details = {
. product_id = keyspan_usa19hs_product_id ,
. msg_format = msg_usa90 ,
. num_ports = 1 ,
. indat_endp_flip = 0 ,
. outdat_endp_flip = 0 ,
. indat_endpoints = { 0x81 } ,
. outdat_endpoints = { 0x01 } ,
. inack_endpoints = { - 1 } ,
. outcont_endpoints = { 0x02 } ,
. instat_endpoint = 0x82 ,
2007-05-18 23:10:41 +04:00
. indat_endpoint = - 1 ,
2005-04-17 02:20:36 +04:00
. glocont_endpoint = - 1 ,
. calculate_baud_rate = keyspan_usa19hs_calc_baud ,
. baudclk = KEYSPAN_USA19HS_BAUDCLK ,
} ;
static const struct keyspan_device_details usa28_device_details = {
. product_id = keyspan_usa28_product_id ,
. msg_format = msg_usa28 ,
. num_ports = 2 ,
. indat_endp_flip = 1 ,
. outdat_endp_flip = 1 ,
. indat_endpoints = { 0x81 , 0x83 } ,
. outdat_endpoints = { 0x01 , 0x03 } ,
. inack_endpoints = { 0x85 , 0x86 } ,
. outcont_endpoints = { 0x05 , 0x06 } ,
. instat_endpoint = 0x87 ,
2007-05-18 23:10:41 +04:00
. indat_endpoint = - 1 ,
2005-04-17 02:20:36 +04:00
. glocont_endpoint = 0x07 ,
. calculate_baud_rate = keyspan_usa28_calc_baud ,
. baudclk = KEYSPAN_USA28_BAUDCLK ,
} ;
static const struct keyspan_device_details usa28x_device_details = {
. product_id = keyspan_usa28x_product_id ,
. msg_format = msg_usa26 ,
. num_ports = 2 ,
. indat_endp_flip = 0 ,
. outdat_endp_flip = 1 ,
. indat_endpoints = { 0x81 , 0x83 } ,
. outdat_endpoints = { 0x01 , 0x03 } ,
. inack_endpoints = { 0x85 , 0x86 } ,
. outcont_endpoints = { 0x05 , 0x06 } ,
. instat_endpoint = 0x87 ,
2007-05-18 23:10:41 +04:00
. indat_endpoint = - 1 ,
2005-04-17 02:20:36 +04:00
. glocont_endpoint = 0x07 ,
. calculate_baud_rate = keyspan_usa19w_calc_baud ,
. baudclk = KEYSPAN_USA28X_BAUDCLK ,
} ;
static const struct keyspan_device_details usa28xa_device_details = {
. product_id = keyspan_usa28xa_product_id ,
. msg_format = msg_usa26 ,
. num_ports = 2 ,
. indat_endp_flip = 0 ,
. outdat_endp_flip = 1 ,
. indat_endpoints = { 0x81 , 0x83 } ,
. outdat_endpoints = { 0x01 , 0x03 } ,
. inack_endpoints = { 0x85 , 0x86 } ,
. outcont_endpoints = { 0x05 , 0x06 } ,
. instat_endpoint = 0x87 ,
2007-05-18 23:10:41 +04:00
. indat_endpoint = - 1 ,
2005-04-17 02:20:36 +04:00
. glocont_endpoint = 0x07 ,
. calculate_baud_rate = keyspan_usa19w_calc_baud ,
. baudclk = KEYSPAN_USA28X_BAUDCLK ,
} ;
2007-05-18 23:10:41 +04:00
static const struct keyspan_device_details usa28xg_device_details = {
. product_id = keyspan_usa28xg_product_id ,
. msg_format = msg_usa67 ,
. num_ports = 2 ,
. indat_endp_flip = 0 ,
. outdat_endp_flip = 0 ,
. indat_endpoints = { 0x84 , 0x88 } ,
. outdat_endpoints = { 0x02 , 0x06 } ,
. inack_endpoints = { - 1 , - 1 } ,
. outcont_endpoints = { - 1 , - 1 } ,
. instat_endpoint = 0x81 ,
. indat_endpoint = - 1 ,
. glocont_endpoint = 0x01 ,
. calculate_baud_rate = keyspan_usa19w_calc_baud ,
. baudclk = KEYSPAN_USA28X_BAUDCLK ,
} ;
2005-04-17 02:20:36 +04:00
/* We don't need a separate entry for the usa28xb as it appears as a 28x anyway */
static const struct keyspan_device_details usa49w_device_details = {
. product_id = keyspan_usa49w_product_id ,
. msg_format = msg_usa49 ,
. num_ports = 4 ,
. indat_endp_flip = 0 ,
. outdat_endp_flip = 0 ,
. indat_endpoints = { 0x81 , 0x82 , 0x83 , 0x84 } ,
. outdat_endpoints = { 0x01 , 0x02 , 0x03 , 0x04 } ,
. inack_endpoints = { - 1 , - 1 , - 1 , - 1 } ,
. outcont_endpoints = { - 1 , - 1 , - 1 , - 1 } ,
. instat_endpoint = 0x87 ,
2007-05-18 23:10:41 +04:00
. indat_endpoint = - 1 ,
2005-04-17 02:20:36 +04:00
. glocont_endpoint = 0x07 ,
. calculate_baud_rate = keyspan_usa19w_calc_baud ,
. baudclk = KEYSPAN_USA49W_BAUDCLK ,
} ;
static const struct keyspan_device_details usa49wlc_device_details = {
. product_id = keyspan_usa49wlc_product_id ,
. msg_format = msg_usa49 ,
. num_ports = 4 ,
. indat_endp_flip = 0 ,
. outdat_endp_flip = 0 ,
. indat_endpoints = { 0x81 , 0x82 , 0x83 , 0x84 } ,
. outdat_endpoints = { 0x01 , 0x02 , 0x03 , 0x04 } ,
. inack_endpoints = { - 1 , - 1 , - 1 , - 1 } ,
. outcont_endpoints = { - 1 , - 1 , - 1 , - 1 } ,
. instat_endpoint = 0x87 ,
2007-05-18 23:10:41 +04:00
. indat_endpoint = - 1 ,
2005-04-17 02:20:36 +04:00
. glocont_endpoint = 0x07 ,
. calculate_baud_rate = keyspan_usa19w_calc_baud ,
. baudclk = KEYSPAN_USA19W_BAUDCLK ,
} ;
2007-05-18 23:10:41 +04:00
static const struct keyspan_device_details usa49wg_device_details = {
. product_id = keyspan_usa49wg_product_id ,
. msg_format = msg_usa49 ,
. num_ports = 4 ,
. indat_endp_flip = 0 ,
. outdat_endp_flip = 0 ,
. indat_endpoints = { - 1 , - 1 , - 1 , - 1 } , /* single 'global' data in EP */
. outdat_endpoints = { 0x01 , 0x02 , 0x04 , 0x06 } ,
. inack_endpoints = { - 1 , - 1 , - 1 , - 1 } ,
. outcont_endpoints = { - 1 , - 1 , - 1 , - 1 } ,
. instat_endpoint = 0x81 ,
. indat_endpoint = 0x88 ,
. glocont_endpoint = 0x00 , /* uses control EP */
. calculate_baud_rate = keyspan_usa19w_calc_baud ,
. baudclk = KEYSPAN_USA19W_BAUDCLK ,
} ;
2005-04-17 02:20:36 +04:00
static const struct keyspan_device_details * keyspan_devices [ ] = {
& usa18x_device_details ,
& usa19_device_details ,
& usa19qi_device_details ,
& mpr_device_details ,
& usa19qw_device_details ,
& usa19w_device_details ,
& usa19hs_device_details ,
& usa28_device_details ,
& usa28x_device_details ,
& usa28xa_device_details ,
2007-05-18 23:10:41 +04:00
& usa28xg_device_details ,
2005-04-17 02:20:36 +04:00
/* 28xb not required as it renumerates as a 28x */
& usa49w_device_details ,
& usa49wlc_device_details ,
2007-05-18 23:10:41 +04:00
& usa49wg_device_details ,
2005-04-17 02:20:36 +04:00
NULL ,
} ;
2010-01-10 17:34:24 +03:00
static const struct usb_device_id keyspan_ids_combined [ ] = {
2005-04-17 02:20:36 +04:00
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa18x_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19w_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19qi_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19qw_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_mpr_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28x_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28xa_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28xb_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa49w_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa49wlc_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa18x_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19w_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19qi_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19qw_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19hs_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_mpr_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28x_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28xa_product_id ) } ,
2007-05-18 23:10:41 +04:00
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28xg_product_id ) } ,
2005-04-17 02:20:36 +04:00
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa49w_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa49wlc_product_id ) } ,
2007-05-18 23:10:41 +04:00
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa49wg_product_id ) } ,
2005-04-17 02:20:36 +04:00
{ } /* Terminating entry */
} ;
MODULE_DEVICE_TABLE ( usb , keyspan_ids_combined ) ;
static struct usb_driver keyspan_driver = {
. name = " keyspan " ,
. probe = usb_serial_probe ,
. disconnect = usb_serial_disconnect ,
. id_table = keyspan_ids_combined ,
2005-11-17 00:41:28 +03:00
. no_dynamic_id = 1 ,
2005-04-17 02:20:36 +04:00
} ;
/* usb_device_id table for the pre-firmware download keyspan devices */
2010-01-10 17:34:24 +03:00
static const struct usb_device_id keyspan_pre_ids [ ] = {
2005-04-17 02:20:36 +04:00
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa18x_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19qi_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19qw_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19w_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_mpr_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28x_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28xa_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28xb_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa49w_pre_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa49wlc_pre_product_id ) } ,
{ } /* Terminating entry */
} ;
2010-01-10 17:34:24 +03:00
static const struct usb_device_id keyspan_1port_ids [ ] = {
2005-04-17 02:20:36 +04:00
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa18x_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19qi_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19qw_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19w_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa19hs_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_mpr_product_id ) } ,
{ } /* Terminating entry */
} ;
2010-01-10 17:34:24 +03:00
static const struct usb_device_id keyspan_2port_ids [ ] = {
2005-04-17 02:20:36 +04:00
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28x_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28xa_product_id ) } ,
2007-05-18 23:10:41 +04:00
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa28xg_product_id ) } ,
2005-04-17 02:20:36 +04:00
{ } /* Terminating entry */
} ;
2010-01-10 17:34:24 +03:00
static const struct usb_device_id keyspan_4port_ids [ ] = {
2005-04-17 02:20:36 +04:00
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa49w_product_id ) } ,
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa49wlc_product_id ) } ,
2007-05-18 23:10:41 +04:00
{ USB_DEVICE ( KEYSPAN_VENDOR_ID , keyspan_usa49wg_product_id ) } ,
2005-04-17 02:20:36 +04:00
{ } /* Terminating entry */
} ;
/* Structs for the devices, pre and post renumeration. */
2005-06-21 08:15:16 +04:00
static struct usb_serial_driver keyspan_pre_device = {
2005-06-21 08:15:16 +04:00
. driver = {
. owner = THIS_MODULE ,
2005-06-21 08:15:16 +04:00
. name = " keyspan_no_firm " ,
2005-06-21 08:15:16 +04:00
} ,
2005-06-21 08:15:16 +04:00
. description = " Keyspan - (without firmware) " ,
2005-04-17 02:20:36 +04:00
. id_table = keyspan_pre_ids ,
. num_ports = 1 ,
. attach = keyspan_fake_startup ,
} ;
2005-06-21 08:15:16 +04:00
static struct usb_serial_driver keyspan_1port_device = {
2005-06-21 08:15:16 +04:00
. driver = {
. owner = THIS_MODULE ,
2005-06-21 08:15:16 +04:00
. name = " keyspan_1 " ,
2005-06-21 08:15:16 +04:00
} ,
2005-06-21 08:15:16 +04:00
. description = " Keyspan 1 port adapter " ,
2005-04-17 02:20:36 +04:00
. id_table = keyspan_1port_ids ,
. num_ports = 1 ,
. open = keyspan_open ,
. close = keyspan_close ,
2009-06-11 15:26:29 +04:00
. dtr_rts = keyspan_dtr_rts ,
2005-04-17 02:20:36 +04:00
. write = keyspan_write ,
. write_room = keyspan_write_room ,
. set_termios = keyspan_set_termios ,
. break_ctl = keyspan_break_ctl ,
. tiocmget = keyspan_tiocmget ,
. tiocmset = keyspan_tiocmset ,
. attach = keyspan_startup ,
2009-06-02 19:53:55 +04:00
. disconnect = keyspan_disconnect ,
. release = keyspan_release ,
2005-04-17 02:20:36 +04:00
} ;
2005-06-21 08:15:16 +04:00
static struct usb_serial_driver keyspan_2port_device = {
2005-06-21 08:15:16 +04:00
. driver = {
. owner = THIS_MODULE ,
2005-06-21 08:15:16 +04:00
. name = " keyspan_2 " ,
2005-06-21 08:15:16 +04:00
} ,
2005-06-21 08:15:16 +04:00
. description = " Keyspan 2 port adapter " ,
2005-04-17 02:20:36 +04:00
. id_table = keyspan_2port_ids ,
. num_ports = 2 ,
. open = keyspan_open ,
. close = keyspan_close ,
2009-06-11 15:26:29 +04:00
. dtr_rts = keyspan_dtr_rts ,
2005-04-17 02:20:36 +04:00
. write = keyspan_write ,
. write_room = keyspan_write_room ,
. set_termios = keyspan_set_termios ,
. break_ctl = keyspan_break_ctl ,
. tiocmget = keyspan_tiocmget ,
. tiocmset = keyspan_tiocmset ,
. attach = keyspan_startup ,
2009-06-02 19:53:55 +04:00
. disconnect = keyspan_disconnect ,
. release = keyspan_release ,
2005-04-17 02:20:36 +04:00
} ;
2005-06-21 08:15:16 +04:00
static struct usb_serial_driver keyspan_4port_device = {
2005-06-21 08:15:16 +04:00
. driver = {
. owner = THIS_MODULE ,
2005-06-21 08:15:16 +04:00
. name = " keyspan_4 " ,
2005-06-21 08:15:16 +04:00
} ,
2005-06-21 08:15:16 +04:00
. description = " Keyspan 4 port adapter " ,
2005-04-17 02:20:36 +04:00
. id_table = keyspan_4port_ids ,
. num_ports = 4 ,
. open = keyspan_open ,
. close = keyspan_close ,
2009-06-11 15:26:29 +04:00
. dtr_rts = keyspan_dtr_rts ,
2005-04-17 02:20:36 +04:00
. write = keyspan_write ,
. write_room = keyspan_write_room ,
. set_termios = keyspan_set_termios ,
. break_ctl = keyspan_break_ctl ,
. tiocmget = keyspan_tiocmget ,
. tiocmset = keyspan_tiocmset ,
. attach = keyspan_startup ,
2009-06-02 19:53:55 +04:00
. disconnect = keyspan_disconnect ,
. release = keyspan_release ,
2005-04-17 02:20:36 +04:00
} ;
# endif