2005-04-16 15:20:36 -07:00
/*
* IO Edgeport Driver tables
*
* Copyright ( C ) 2001
* Greg Kroah - Hartman ( greg @ kroah . com )
*
* 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 .
2008-07-22 11:16:34 +01:00
*
2005-04-16 15:20:36 -07:00
*/
# ifndef IO_TABLES_H
# define IO_TABLES_H
static struct usb_device_id edgeport_2port_id_table [ ] = {
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_2 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_2I ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_421 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_21 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_2_DIN ) } ,
{ }
} ;
static struct usb_device_id edgeport_4port_id_table [ ] = {
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_4 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_RAPIDPORT_4 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_4T ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_MT4X56USB ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_4I ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_8_DUAL_CPU ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_4_DIN ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_22I ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_412_4 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_COMPATIBLE ) } ,
{ }
} ;
static struct usb_device_id edgeport_8port_id_table [ ] = {
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_8 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_16_DUAL_CPU ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_8I ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_8R ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_8RR ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_412_8 ) } ,
{ }
} ;
2007-01-18 00:20:19 -08:00
static struct usb_device_id Epic_port_id_table [ ] = {
{ USB_DEVICE ( USB_VENDOR_ID_NCR , NCR_DEVICE_ID_EPIC_0202 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_NCR , NCR_DEVICE_ID_EPIC_0203 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_NCR , NCR_DEVICE_ID_EPIC_0310 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_NCR , NCR_DEVICE_ID_EPIC_0311 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_NCR , NCR_DEVICE_ID_EPIC_0312 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_AXIOHM , AXIOHM_DEVICE_ID_EPIC_A758 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_AXIOHM , AXIOHM_DEVICE_ID_EPIC_A794 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_AXIOHM , AXIOHM_DEVICE_ID_EPIC_A225 ) } ,
{ }
} ;
2005-04-16 15:20:36 -07:00
/* Devices that this driver supports */
static struct usb_device_id id_table_combined [ ] = {
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_4 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_RAPIDPORT_4 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_4T ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_MT4X56USB ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_2 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_4I ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_2I ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_421 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_21 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_8_DUAL_CPU ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_8 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_2_DIN ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_4_DIN ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_16_DUAL_CPU ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_22I ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_412_4 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_COMPATIBLE ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_8I ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_8R ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_8RR ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_ION , ION_DEVICE_ID_EDGEPORT_412_8 ) } ,
2007-01-18 00:20:19 -08:00
{ USB_DEVICE ( USB_VENDOR_ID_NCR , NCR_DEVICE_ID_EPIC_0202 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_NCR , NCR_DEVICE_ID_EPIC_0203 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_NCR , NCR_DEVICE_ID_EPIC_0310 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_NCR , NCR_DEVICE_ID_EPIC_0311 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_NCR , NCR_DEVICE_ID_EPIC_0312 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_AXIOHM , AXIOHM_DEVICE_ID_EPIC_A758 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_AXIOHM , AXIOHM_DEVICE_ID_EPIC_A794 ) } ,
{ USB_DEVICE ( USB_VENDOR_ID_AXIOHM , AXIOHM_DEVICE_ID_EPIC_A225 ) } ,
2008-07-22 11:16:34 +01:00
{ } /* Terminating entry */
2005-04-16 15:20:36 -07:00
} ;
2008-07-22 11:16:34 +01:00
MODULE_DEVICE_TABLE ( usb , id_table_combined ) ;
2005-04-16 15:20:36 -07:00
2006-12-17 21:50:24 +01:00
static struct usb_driver io_driver = {
. name = " io_edgeport " ,
. probe = usb_serial_probe ,
. disconnect = usb_serial_disconnect ,
. id_table = id_table_combined ,
. no_dynamic_id = 1 ,
} ;
2005-06-20 21:15:16 -07:00
static struct usb_serial_driver edgeport_2port_device = {
2005-06-20 21:15:16 -07:00
. driver = {
. owner = THIS_MODULE ,
2005-06-20 21:15:16 -07:00
. name = " edgeport_2 " ,
2005-06-20 21:15:16 -07:00
} ,
2005-06-20 21:15:16 -07:00
. description = " Edgeport 2 port adapter " ,
2006-12-17 21:50:24 +01:00
. usb_driver = & io_driver ,
2005-04-16 15:20:36 -07:00
. id_table = edgeport_2port_id_table ,
. num_ports = 2 ,
. open = edge_open ,
. close = edge_close ,
. throttle = edge_throttle ,
. unthrottle = edge_unthrottle ,
. attach = edge_startup ,
2009-06-02 11:53:55 -04:00
. disconnect = edge_disconnect ,
. release = edge_release ,
2005-04-16 15:20:36 -07:00
. ioctl = edge_ioctl ,
. set_termios = edge_set_termios ,
. tiocmget = edge_tiocmget ,
. tiocmset = edge_tiocmset ,
. write = edge_write ,
. write_room = edge_write_room ,
. chars_in_buffer = edge_chars_in_buffer ,
. break_ctl = edge_break ,
. read_int_callback = edge_interrupt_callback ,
. read_bulk_callback = edge_bulk_in_callback ,
. write_bulk_callback = edge_bulk_out_data_callback ,
} ;
2005-06-20 21:15:16 -07:00
static struct usb_serial_driver edgeport_4port_device = {
2005-06-20 21:15:16 -07:00
. driver = {
. owner = THIS_MODULE ,
2005-06-20 21:15:16 -07:00
. name = " edgeport_4 " ,
2005-06-20 21:15:16 -07:00
} ,
2005-06-20 21:15:16 -07:00
. description = " Edgeport 4 port adapter " ,
2006-12-17 21:50:24 +01:00
. usb_driver = & io_driver ,
2005-04-16 15:20:36 -07:00
. id_table = edgeport_4port_id_table ,
. num_ports = 4 ,
. open = edge_open ,
. close = edge_close ,
. throttle = edge_throttle ,
. unthrottle = edge_unthrottle ,
. attach = edge_startup ,
2009-06-02 11:53:55 -04:00
. disconnect = edge_disconnect ,
. release = edge_release ,
2005-04-16 15:20:36 -07:00
. ioctl = edge_ioctl ,
. set_termios = edge_set_termios ,
. tiocmget = edge_tiocmget ,
. tiocmset = edge_tiocmset ,
. write = edge_write ,
. write_room = edge_write_room ,
. chars_in_buffer = edge_chars_in_buffer ,
. break_ctl = edge_break ,
. read_int_callback = edge_interrupt_callback ,
. read_bulk_callback = edge_bulk_in_callback ,
. write_bulk_callback = edge_bulk_out_data_callback ,
} ;
2005-06-20 21:15:16 -07:00
static struct usb_serial_driver edgeport_8port_device = {
2005-06-20 21:15:16 -07:00
. driver = {
. owner = THIS_MODULE ,
2005-06-20 21:15:16 -07:00
. name = " edgeport_8 " ,
2005-06-20 21:15:16 -07:00
} ,
2005-06-20 21:15:16 -07:00
. description = " Edgeport 8 port adapter " ,
2006-12-17 21:50:24 +01:00
. usb_driver = & io_driver ,
2005-04-16 15:20:36 -07:00
. id_table = edgeport_8port_id_table ,
. num_ports = 8 ,
. open = edge_open ,
. close = edge_close ,
. throttle = edge_throttle ,
. unthrottle = edge_unthrottle ,
. attach = edge_startup ,
2009-06-02 11:53:55 -04:00
. disconnect = edge_disconnect ,
. release = edge_release ,
2005-04-16 15:20:36 -07:00
. ioctl = edge_ioctl ,
. set_termios = edge_set_termios ,
. tiocmget = edge_tiocmget ,
. tiocmset = edge_tiocmset ,
. write = edge_write ,
. write_room = edge_write_room ,
. chars_in_buffer = edge_chars_in_buffer ,
. break_ctl = edge_break ,
. read_int_callback = edge_interrupt_callback ,
. read_bulk_callback = edge_bulk_in_callback ,
. write_bulk_callback = edge_bulk_out_data_callback ,
} ;
2007-01-18 00:20:19 -08:00
static struct usb_serial_driver epic_device = {
. driver = {
. owner = THIS_MODULE ,
. name = " epic " ,
} ,
. description = " EPiC device " ,
. id_table = Epic_port_id_table ,
. num_ports = 1 ,
. open = edge_open ,
. close = edge_close ,
. throttle = edge_throttle ,
. unthrottle = edge_unthrottle ,
. attach = edge_startup ,
2009-06-02 11:53:55 -04:00
. disconnect = edge_disconnect ,
. release = edge_release ,
2007-01-18 00:20:19 -08:00
. ioctl = edge_ioctl ,
. set_termios = edge_set_termios ,
. tiocmget = edge_tiocmget ,
. tiocmset = edge_tiocmset ,
. write = edge_write ,
. write_room = edge_write_room ,
. chars_in_buffer = edge_chars_in_buffer ,
. break_ctl = edge_break ,
. read_int_callback = edge_interrupt_callback ,
. read_bulk_callback = edge_bulk_in_callback ,
. write_bulk_callback = edge_bulk_out_data_callback ,
} ;
2005-04-16 15:20:36 -07:00
# endif