diff options
Diffstat (limited to 'drivers/usb/gadget/function/u_serial.c')
| -rw-r--r-- | drivers/usb/gadget/function/u_serial.c | 17 | 
1 files changed, 10 insertions, 7 deletions
| diff --git a/drivers/usb/gadget/function/u_serial.c b/drivers/usb/gadget/function/u_serial.c index 0a8c05b2746b..bc143a86c2dd 100644 --- a/drivers/usb/gadget/function/u_serial.c +++ b/drivers/usb/gadget/function/u_serial.c @@ -579,9 +579,12 @@ static int gs_start_io(struct gs_port *port)  		 * we didn't in gs_start_tx() */  		tty_wakeup(port->port.tty);  	} else { -		gs_free_requests(ep, head, &port->read_allocated); -		gs_free_requests(port->port_usb->in, &port->write_pool, -			&port->write_allocated); +		/* Free reqs only if we are still connected */ +		if (port->port_usb) { +			gs_free_requests(ep, head, &port->read_allocated); +			gs_free_requests(port->port_usb->in, &port->write_pool, +				&port->write_allocated); +		}  		status = -EIO;  	} @@ -1417,6 +1420,10 @@ void gserial_disconnect(struct gserial *gser)  	/* REVISIT as above: how best to track this? */  	port->port_line_coding = gser->port_line_coding; +	/* disable endpoints, aborting down any active I/O */ +	usb_ep_disable(gser->out); +	usb_ep_disable(gser->in); +  	port->port_usb = NULL;  	gser->ioport = NULL;  	if (port->port.count > 0) { @@ -1428,10 +1435,6 @@ void gserial_disconnect(struct gserial *gser)  	spin_unlock(&port->port_lock);  	spin_unlock_irqrestore(&serial_port_lock, flags); -	/* disable endpoints, aborting down any active I/O */ -	usb_ep_disable(gser->out); -	usb_ep_disable(gser->in); -  	/* finally, free any unused/unusable I/O buffers */  	spin_lock_irqsave(&port->port_lock, flags);  	if (port->port.count == 0) | 
