diff options
author | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2012-05-08 18:46:14 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2012-05-08 18:46:14 -0400 |
commit | 68e24113457e437b1576670f2419b77ed0531e9e (patch) | |
tree | 4737e411b3df714ff1a2c911dbc66d0ba5e5cf5b /drivers/usb/serial/mct_u232.c | |
parent | d56ba3205fe2e61264ef41f29cd90a666df032e4 (diff) |
USB: serial: rework usb_serial_register/deregister_drivers()
This reworks the usb_serial_register_drivers() and
usb_serial_deregister_drivers() to not need a pointer to a struct
usb_driver anymore. The usb_driver structure is now created dynamically
and registered and unregistered as needed.
This saves lines of code in each usb-serial driver. All in-kernel users
of these functions were also fixed up at this time. The pl2303 driver
was tested that everything worked properly.
Thanks for the idea to do this from Alan Stern.
Cc: Adhir Ramjiawan <adhirramjiawan0@gmail.com>
Cc: Alan Stern <stern@rowland.harvard.edu>
Cc: Al Borchers <alborchers@steinerpoint.com>
Cc: Aleksey Babahin <tamerlan311@gmail.com>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Andrew Worsley <amworsley@gmail.com>
Cc: Bart Hartgers <bart.hartgers@gmail.com>
Cc: Bill Pemberton <wfp5p@virginia.edu>
Cc: Dan Carpenter <error27@gmail.com>
Cc: Dan Williams <dcbw@redhat.com>
Cc: Donald Lee <donald@asix.com.tw>
Cc: Eric Dumazet <eric.dumazet@gmail.com>
Cc: "Eric W. Biederman" <ebiederm@xmission.com>
Cc: Felipe Balbi <balbi@ti.com>
Cc: Gary Brubaker <xavyer@ix.netcom.com>
Cc: Jesper Juhl <jj@chaosbits.net>
Cc: Jiri Kosina <jkosina@suse.cz>
Cc: Johan Hovold <jhovold@gmail.com>
Cc: Julia Lawall <julia@diku.dk>
Cc: Kautuk Consul <consul.kautuk@gmail.com>
Cc: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Cc: Lonnie Mendez <dignome@gmail.com>
Cc: Matthias Bruestle and Harald Welte <support@reiner-sct.com>
Cc: Matthias Urlichs <smurf@smurf.noris.de>
Cc: Mauro Carvalho Chehab <mchehab@redhat.com>
Cc: Michal Sroczynski <msroczyn@gmail.com>
Cc: "Michał Wróbel" <michal.wrobel@flytronic.pl>
Cc: Oliver Neukum <oliver@neukum.name>
Cc: Paul Gortmaker <paul.gortmaker@windriver.com>
Cc: Peter Berger <pberger@brimson.com>
Cc: Preston Fick <preston.fick@silabs.com>
Cc: "Rafael J. Wysocki" <rjw@sisk.pl>
Cc: Rigbert Hamisch <rigbert@gmx.de>
Cc: Rusty Russell <rusty@rustcorp.com.au>
Cc: Simon Arlott <simon@fire.lp0.eu>
Cc: Support Department <support@connecttech.com>
Cc: Thomas Tuttle <ttuttle@chromium.org>
Cc: Uwe Bonnes <bon@elektron.ikp.physik.tu-darmstadt.de>
Cc: Wang YanQing <Udknight@gmail.com>
Cc: William Greathouse <wgreathouse@smva.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/usb/serial/mct_u232.c')
-rw-r--r-- | drivers/usb/serial/mct_u232.c | 14 |
1 files changed, 4 insertions, 10 deletions
diff --git a/drivers/usb/serial/mct_u232.c b/drivers/usb/serial/mct_u232.c index a63d1e8be911..d0ec1aa52719 100644 --- a/drivers/usb/serial/mct_u232.c +++ b/drivers/usb/serial/mct_u232.c | |||
@@ -73,20 +73,14 @@ static void mct_u232_unthrottle(struct tty_struct *tty); | |||
73 | /* | 73 | /* |
74 | * All of the device info needed for the MCT USB-RS232 converter. | 74 | * All of the device info needed for the MCT USB-RS232 converter. |
75 | */ | 75 | */ |
76 | static const struct usb_device_id id_table_combined[] = { | 76 | static const struct usb_device_id id_table[] = { |
77 | { USB_DEVICE(MCT_U232_VID, MCT_U232_PID) }, | 77 | { USB_DEVICE(MCT_U232_VID, MCT_U232_PID) }, |
78 | { USB_DEVICE(MCT_U232_VID, MCT_U232_SITECOM_PID) }, | 78 | { USB_DEVICE(MCT_U232_VID, MCT_U232_SITECOM_PID) }, |
79 | { USB_DEVICE(MCT_U232_VID, MCT_U232_DU_H3SP_PID) }, | 79 | { USB_DEVICE(MCT_U232_VID, MCT_U232_DU_H3SP_PID) }, |
80 | { USB_DEVICE(MCT_U232_BELKIN_F5U109_VID, MCT_U232_BELKIN_F5U109_PID) }, | 80 | { USB_DEVICE(MCT_U232_BELKIN_F5U109_VID, MCT_U232_BELKIN_F5U109_PID) }, |
81 | { } /* Terminating entry */ | 81 | { } /* Terminating entry */ |
82 | }; | 82 | }; |
83 | 83 | MODULE_DEVICE_TABLE(usb, id_table); | |
84 | MODULE_DEVICE_TABLE(usb, id_table_combined); | ||
85 | |||
86 | static struct usb_driver mct_u232_driver = { | ||
87 | .name = "mct_u232", | ||
88 | .id_table = id_table_combined, | ||
89 | }; | ||
90 | 84 | ||
91 | static struct usb_serial_driver mct_u232_device = { | 85 | static struct usb_serial_driver mct_u232_device = { |
92 | .driver = { | 86 | .driver = { |
@@ -94,7 +88,7 @@ static struct usb_serial_driver mct_u232_device = { | |||
94 | .name = "mct_u232", | 88 | .name = "mct_u232", |
95 | }, | 89 | }, |
96 | .description = "MCT U232", | 90 | .description = "MCT U232", |
97 | .id_table = id_table_combined, | 91 | .id_table = id_table, |
98 | .num_ports = 1, | 92 | .num_ports = 1, |
99 | .open = mct_u232_open, | 93 | .open = mct_u232_open, |
100 | .close = mct_u232_close, | 94 | .close = mct_u232_close, |
@@ -887,7 +881,7 @@ static int mct_u232_get_icount(struct tty_struct *tty, | |||
887 | return 0; | 881 | return 0; |
888 | } | 882 | } |
889 | 883 | ||
890 | module_usb_serial_driver(mct_u232_driver, serial_drivers); | 884 | module_usb_serial_driver(serial_drivers, id_table); |
891 | 885 | ||
892 | MODULE_AUTHOR(DRIVER_AUTHOR); | 886 | MODULE_AUTHOR(DRIVER_AUTHOR); |
893 | MODULE_DESCRIPTION(DRIVER_DESC); | 887 | MODULE_DESCRIPTION(DRIVER_DESC); |