USB: ti serial driver sleeps with spinlock held
you are submitting an URB with GFP_KERNEL holding a spinlock. In this case the spinlock can be dropped earlier. Signed-off-by: Oliver Neukum <oneukum@suse.de> Cc: Al Borchers <alborchers@steinerpoint.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
8cfbe7e60d
commit
944dc184f6
@@ -1555,15 +1555,17 @@ static int ti_restart_read(struct ti_port *tport, struct tty_struct *tty)
|
|||||||
spin_lock_irqsave(&tport->tp_lock, flags);
|
spin_lock_irqsave(&tport->tp_lock, flags);
|
||||||
|
|
||||||
if (tport->tp_read_urb_state == TI_READ_URB_STOPPED) {
|
if (tport->tp_read_urb_state == TI_READ_URB_STOPPED) {
|
||||||
|
tport->tp_read_urb_state = TI_READ_URB_RUNNING;
|
||||||
urb = tport->tp_port->read_urb;
|
urb = tport->tp_port->read_urb;
|
||||||
|
spin_unlock_irqrestore(&tport->tp_lock, flags);
|
||||||
urb->complete = ti_bulk_in_callback;
|
urb->complete = ti_bulk_in_callback;
|
||||||
urb->context = tport;
|
urb->context = tport;
|
||||||
urb->dev = tport->tp_port->serial->dev;
|
urb->dev = tport->tp_port->serial->dev;
|
||||||
status = usb_submit_urb(urb, GFP_KERNEL);
|
status = usb_submit_urb(urb, GFP_KERNEL);
|
||||||
|
} else {
|
||||||
|
tport->tp_read_urb_state = TI_READ_URB_RUNNING;
|
||||||
|
spin_unlock_irqrestore(&tport->tp_lock, flags);
|
||||||
}
|
}
|
||||||
tport->tp_read_urb_state = TI_READ_URB_RUNNING;
|
|
||||||
|
|
||||||
spin_unlock_irqrestore(&tport->tp_lock, flags);
|
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user