aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/usb
diff options
context:
space:
mode:
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>2013-06-07 14:04:28 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2013-06-17 16:30:02 -0400
commite5b1e2062e0535e8ffef79bb34d857e21380d101 (patch)
tree75376f4cb69f6a1cd05b323803ae6a1a8fc4db90 /include/linux/usb
parent1508124d8a4e0995362d93d82e5555a74bfc998f (diff)
USB: serial: make minor allocation dynamic
This moves the allocation of minor device numbers from a static array to be dynamic, using the idr interface. This means that you could potentially get "gaps" in a minor number range for a single USB serial device with multiple ports, but all should still work properly. We remove the 'minor' field from the usb_serial structure, as it no longer makes any sense for it (use the field in the usb_serial_port structure if you really want to know this number), and take the fact that we were overloading a number in this field to determine if we had initialized the minor numbers or not, and just use a flag variable instead. Note, we still have the limitation of 255 USB to serial devices in the system, as that is all we are registering with the TTY layer at this point in time. Tested-by: Tobias Winter <tobias@linuxdingsda.de> Reviewed-by: Johan Hovold <jhovold@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'include/linux/usb')
-rw-r--r--include/linux/usb/serial.h6
1 files changed, 2 insertions, 4 deletions
diff --git a/include/linux/usb/serial.h b/include/linux/usb/serial.h
index 3fa68b615ac1..9254c80a1cf8 100644
--- a/include/linux/usb/serial.h
+++ b/include/linux/usb/serial.h
@@ -21,7 +21,6 @@
21 21
22#define SERIAL_TTY_MAJOR 188 /* Nice legal number now */ 22#define SERIAL_TTY_MAJOR 188 /* Nice legal number now */
23#define SERIAL_TTY_MINORS 254 /* loads of devices :) */ 23#define SERIAL_TTY_MINORS 254 /* loads of devices :) */
24#define SERIAL_TTY_NO_MINOR 255 /* No minor was assigned */
25 24
26/* The maximum number of ports one device can grab at once */ 25/* The maximum number of ports one device can grab at once */
27#define MAX_NUM_PORTS 8 26#define MAX_NUM_PORTS 8
@@ -142,7 +141,6 @@ static inline void usb_set_serial_port_data(struct usb_serial_port *port,
142 * @dev: pointer to the struct usb_device for this device 141 * @dev: pointer to the struct usb_device for this device
143 * @type: pointer to the struct usb_serial_driver for this device 142 * @type: pointer to the struct usb_serial_driver for this device
144 * @interface: pointer to the struct usb_interface for this device 143 * @interface: pointer to the struct usb_interface for this device
145 * @minor: the starting minor number for this device
146 * @num_ports: the number of ports this device has 144 * @num_ports: the number of ports this device has
147 * @num_interrupt_in: number of interrupt in endpoints we have 145 * @num_interrupt_in: number of interrupt in endpoints we have
148 * @num_interrupt_out: number of interrupt out endpoints we have 146 * @num_interrupt_out: number of interrupt out endpoints we have
@@ -161,7 +159,7 @@ struct usb_serial {
161 unsigned char disconnected:1; 159 unsigned char disconnected:1;
162 unsigned char suspending:1; 160 unsigned char suspending:1;
163 unsigned char attached:1; 161 unsigned char attached:1;
164 unsigned char minor; 162 unsigned char minors_reserved:1;
165 unsigned char num_ports; 163 unsigned char num_ports;
166 unsigned char num_port_pointers; 164 unsigned char num_port_pointers;
167 char num_interrupt_in; 165 char num_interrupt_in;
@@ -321,7 +319,7 @@ static inline void usb_serial_console_disconnect(struct usb_serial *serial) {}
321#endif 319#endif
322 320
323/* Functions needed by other parts of the usbserial core */ 321/* Functions needed by other parts of the usbserial core */
324extern struct usb_serial *usb_serial_get_by_index(unsigned int minor); 322extern struct usb_serial_port *usb_serial_port_get_by_minor(unsigned int minor);
325extern void usb_serial_put(struct usb_serial *serial); 323extern void usb_serial_put(struct usb_serial *serial);
326extern int usb_serial_generic_open(struct tty_struct *tty, 324extern int usb_serial_generic_open(struct tty_struct *tty,
327 struct usb_serial_port *port); 325 struct usb_serial_port *port);