mirror of
https://github.com/raspberrypi/linux.git
synced 2025-12-06 01:49:46 +00:00
USB: serial: iuu_phoenix: fix NULL-deref at open
commit90507d54f7upstream. Fix NULL-pointer dereference at open should the device lack a bulk-in or bulk-out endpoint: Unable to handle kernel NULL pointer dereference at virtual address 00000030 ... PC is at iuu_open+0x78/0x59c [iuu_phoenix] Fixes:07c3b1a100("USB: remove broken usb-serial num_endpoints check") Signed-off-by: Johan Hovold <johan@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
69017618a6
commit
9401cc62b7
@@ -68,6 +68,16 @@ struct iuu_private {
|
|||||||
u32 clk;
|
u32 clk;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static int iuu_attach(struct usb_serial *serial)
|
||||||
|
{
|
||||||
|
unsigned char num_ports = serial->num_ports;
|
||||||
|
|
||||||
|
if (serial->num_bulk_in < num_ports || serial->num_bulk_out < num_ports)
|
||||||
|
return -ENODEV;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int iuu_port_probe(struct usb_serial_port *port)
|
static int iuu_port_probe(struct usb_serial_port *port)
|
||||||
{
|
{
|
||||||
struct iuu_private *priv;
|
struct iuu_private *priv;
|
||||||
@@ -1196,6 +1206,7 @@ static struct usb_serial_driver iuu_device = {
|
|||||||
.tiocmset = iuu_tiocmset,
|
.tiocmset = iuu_tiocmset,
|
||||||
.set_termios = iuu_set_termios,
|
.set_termios = iuu_set_termios,
|
||||||
.init_termios = iuu_init_termios,
|
.init_termios = iuu_init_termios,
|
||||||
|
.attach = iuu_attach,
|
||||||
.port_probe = iuu_port_probe,
|
.port_probe = iuu_port_probe,
|
||||||
.port_remove = iuu_port_remove,
|
.port_remove = iuu_port_remove,
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user