Commit 7b813767 authored by Alexandru M Stan's avatar Alexandru M Stan Committed by Greg Kroah-Hartman

usb: dwc2: Fix NULL qh in dwc2_queue_transaction

When a usb device disconnects in a certain way, dwc2_queue_transaction
still gets called after dwc2_hcd_cleanup_channels.

dwc2_hcd_cleanup_channels does "channel->qh = NULL;" but
dwc2_queue_transaction still wants to dereference qh.
This adds a check for a null qh.
Acked-by: default avatarMinas Harutyunyan <hminas@synopsys.com>
Signed-off-by: default avatarAlexandru M Stan <amstan@chromium.org>
[dianders: rebased to mainline]
Signed-off-by: default avatarDouglas Anderson <dianders@chromium.org>
Signed-off-by: default avatarFelipe Balbi <felipe.balbi@linux.intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 6070636c
...@@ -2824,7 +2824,7 @@ static int dwc2_queue_transaction(struct dwc2_hsotg *hsotg, ...@@ -2824,7 +2824,7 @@ static int dwc2_queue_transaction(struct dwc2_hsotg *hsotg,
list_move_tail(&chan->split_order_list_entry, list_move_tail(&chan->split_order_list_entry,
&hsotg->split_order); &hsotg->split_order);
if (hsotg->params.host_dma) { if (hsotg->params.host_dma && chan->qh) {
if (hsotg->params.dma_desc_enable) { if (hsotg->params.dma_desc_enable) {
if (!chan->xfer_started || if (!chan->xfer_started ||
chan->ep_type == USB_ENDPOINT_XFER_ISOC) { chan->ep_type == USB_ENDPOINT_XFER_ISOC) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment