diff options
Diffstat (limited to 'kernel/drivers/usb/serial/visor.c')
-rw-r--r-- | kernel/drivers/usb/serial/visor.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/kernel/drivers/usb/serial/visor.c b/kernel/drivers/usb/serial/visor.c index 60afb39eb..337a0be89 100644 --- a/kernel/drivers/usb/serial/visor.c +++ b/kernel/drivers/usb/serial/visor.c @@ -544,6 +544,11 @@ static int treo_attach(struct usb_serial *serial) (serial->num_interrupt_in == 0)) return 0; + if (serial->num_bulk_in < 2 || serial->num_interrupt_in < 2) { + dev_err(&serial->interface->dev, "missing endpoints\n"); + return -ENODEV; + } + /* * It appears that Treos and Kyoceras want to use the * 1st bulk in endpoint to communicate with the 2nd bulk out endpoint, @@ -597,8 +602,10 @@ static int clie_5_attach(struct usb_serial *serial) */ /* some sanity check */ - if (serial->num_ports < 2) - return -1; + if (serial->num_bulk_out < 2) { + dev_err(&serial->interface->dev, "missing bulk out endpoints\n"); + return -ENODEV; + } /* port 0 now uses the modified endpoint Address */ port = serial->port[0]; |