diff options
Diffstat (limited to 'drivers/usb/serial/usb-serial.c')
-rw-r--r-- | drivers/usb/serial/usb-serial.c | 31 |
1 files changed, 22 insertions, 9 deletions
diff --git a/drivers/usb/serial/usb-serial.c b/drivers/usb/serial/usb-serial.c index 26e015c39a31..4b1bd7def4a5 100644 --- a/drivers/usb/serial/usb-serial.c +++ b/drivers/usb/serial/usb-serial.c | |||
@@ -662,16 +662,14 @@ exit: | |||
662 | 662 | ||
663 | static struct usb_serial_driver *search_serial_device(struct usb_interface *iface) | 663 | static struct usb_serial_driver *search_serial_device(struct usb_interface *iface) |
664 | { | 664 | { |
665 | struct list_head *p; | ||
666 | const struct usb_device_id *id; | 665 | const struct usb_device_id *id; |
667 | struct usb_serial_driver *t; | 666 | struct usb_serial_driver *drv; |
668 | 667 | ||
669 | /* Check if the usb id matches a known device */ | 668 | /* Check if the usb id matches a known device */ |
670 | list_for_each(p, &usb_serial_driver_list) { | 669 | list_for_each_entry(drv, &usb_serial_driver_list, driver_list) { |
671 | t = list_entry(p, struct usb_serial_driver, driver_list); | 670 | id = get_iface_id(drv, iface); |
672 | id = get_iface_id(t, iface); | ||
673 | if (id) | 671 | if (id) |
674 | return t; | 672 | return drv; |
675 | } | 673 | } |
676 | 674 | ||
677 | return NULL; | 675 | return NULL; |
@@ -811,9 +809,6 @@ int usb_serial_probe(struct usb_interface *interface, | |||
811 | /* END HORRIBLE HACK FOR PL2303 */ | 809 | /* END HORRIBLE HACK FOR PL2303 */ |
812 | #endif | 810 | #endif |
813 | 811 | ||
814 | /* found all that we need */ | ||
815 | dev_info(&interface->dev, "%s converter detected\n", type->description); | ||
816 | |||
817 | #ifdef CONFIG_USB_SERIAL_GENERIC | 812 | #ifdef CONFIG_USB_SERIAL_GENERIC |
818 | if (type == &usb_serial_generic_device) { | 813 | if (type == &usb_serial_generic_device) { |
819 | num_ports = num_bulk_out; | 814 | num_ports = num_bulk_out; |
@@ -847,6 +842,24 @@ int usb_serial_probe(struct usb_interface *interface, | |||
847 | serial->num_interrupt_in = num_interrupt_in; | 842 | serial->num_interrupt_in = num_interrupt_in; |
848 | serial->num_interrupt_out = num_interrupt_out; | 843 | serial->num_interrupt_out = num_interrupt_out; |
849 | 844 | ||
845 | /* check that the device meets the driver's requirements */ | ||
846 | if ((type->num_interrupt_in != NUM_DONT_CARE && | ||
847 | type->num_interrupt_in != num_interrupt_in) | ||
848 | || (type->num_interrupt_out != NUM_DONT_CARE && | ||
849 | type->num_interrupt_out != num_interrupt_out) | ||
850 | || (type->num_bulk_in != NUM_DONT_CARE && | ||
851 | type->num_bulk_in != num_bulk_in) | ||
852 | || (type->num_bulk_out != NUM_DONT_CARE && | ||
853 | type->num_bulk_out != num_bulk_out)) { | ||
854 | dbg("wrong number of endpoints"); | ||
855 | kfree(serial); | ||
856 | return -EIO; | ||
857 | } | ||
858 | |||
859 | /* found all that we need */ | ||
860 | dev_info(&interface->dev, "%s converter detected\n", | ||
861 | type->description); | ||
862 | |||
850 | /* create our ports, we need as many as the max endpoints */ | 863 | /* create our ports, we need as many as the max endpoints */ |
851 | /* we don't use num_ports here cauz some devices have more endpoint pairs than ports */ | 864 | /* we don't use num_ports here cauz some devices have more endpoint pairs than ports */ |
852 | max_endpoints = max(num_bulk_in, num_bulk_out); | 865 | max_endpoints = max(num_bulk_in, num_bulk_out); |