2006-04-13 19:09:52 +04:00
/*
* Funsoft Serial USB driver
*
* Copyright ( C ) 2006 Greg Kroah - Hartman < gregkh @ suse . de >
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License version
* 2 as published by the Free Software Foundation .
*/
# include <linux/kernel.h>
# include <linux/init.h>
# include <linux/tty.h>
# include <linux/module.h>
# include <linux/usb.h>
2006-07-12 08:22:58 +04:00
# include <linux/usb/serial.h>
2008-07-22 14:11:34 +04:00
# include <linux/uaccess.h>
2006-12-02 05:24:38 +03:00
static int debug ;
2006-04-13 19:09:52 +04:00
2010-01-10 17:34:24 +03:00
static const struct usb_device_id id_table [ ] = {
2006-04-13 19:09:52 +04:00
{ USB_DEVICE ( 0x1404 , 0xcddc ) } ,
{ } ,
} ;
MODULE_DEVICE_TABLE ( usb , id_table ) ;
static struct usb_driver funsoft_driver = {
. name = " funsoft " ,
. probe = usb_serial_probe ,
. disconnect = usb_serial_disconnect ,
. id_table = id_table ,
. no_dynamic_id = 1 ,
} ;
static struct usb_serial_driver funsoft_device = {
. driver = {
. owner = THIS_MODULE ,
. name = " funsoft " ,
} ,
. id_table = id_table ,
2006-12-17 23:50:24 +03:00
. usb_driver = & funsoft_driver ,
2006-04-13 19:09:52 +04:00
. num_ports = 1 ,
} ;
static int __init funsoft_init ( void )
{
int retval ;
retval = usb_serial_register ( & funsoft_device ) ;
if ( retval )
return retval ;
retval = usb_register ( & funsoft_driver ) ;
if ( retval )
usb_serial_deregister ( & funsoft_device ) ;
return retval ;
}
static void __exit funsoft_exit ( void )
{
usb_deregister ( & funsoft_driver ) ;
usb_serial_deregister ( & funsoft_device ) ;
}
module_init ( funsoft_init ) ;
module_exit ( funsoft_exit ) ;
MODULE_LICENSE ( " GPL " ) ;
2006-12-02 05:24:38 +03:00
module_param ( debug , bool , S_IRUGO | S_IWUSR ) ;
MODULE_PARM_DESC ( debug , " Debug enabled or not " ) ;