UPSTREAM: usb: dwc3: gadget: Fix null pointer exception
[ Upstream commit 26288448120b28af1dfd85a6fa6b6d55a16c7f2f ] In the endpoint interrupt functions dwc3_gadget_endpoint_transfer_in_progress() and dwc3_gadget_endpoint_trbs_complete() will dereference the endpoint descriptor. But it could be cleared in __dwc3_gadget_ep_disable() when accessory disconnected. So we need to check whether it is null or not before dereferencing it. Bug: 202829886 Bug: 204052921 Fixes: f09ddcfcb8c5 ("usb: dwc3: gadget: Prevent EP queuing while stopping transfers") Cc: stable <stable@vger.kernel.org> Reviewed-by: Jack Pham <quic_jackp@quicinc.com> Signed-off-by: Albert Wang <albertccwang@google.com> Link: https://lore.kernel.org/r/20211109092642.3507692-1-albertccwang@google.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Change-Id: I767f61f3c8840b7854a467ab6bf18c26c89757c2 Signed-off-by: Albert Wang <albertccwang@google.com>
This commit is contained in:
@@ -3264,6 +3264,9 @@ static bool dwc3_gadget_endpoint_trbs_complete(struct dwc3_ep *dep,
|
|||||||
struct dwc3 *dwc = dep->dwc;
|
struct dwc3 *dwc = dep->dwc;
|
||||||
bool no_started_trb = true;
|
bool no_started_trb = true;
|
||||||
|
|
||||||
|
if (!dep->endpoint.desc)
|
||||||
|
return no_started_trb;
|
||||||
|
|
||||||
dwc3_gadget_ep_cleanup_completed_requests(dep, event, status);
|
dwc3_gadget_ep_cleanup_completed_requests(dep, event, status);
|
||||||
|
|
||||||
if (dep->flags & DWC3_EP_END_TRANSFER_PENDING)
|
if (dep->flags & DWC3_EP_END_TRANSFER_PENDING)
|
||||||
@@ -3311,6 +3314,9 @@ static void dwc3_gadget_endpoint_transfer_in_progress(struct dwc3_ep *dep,
|
|||||||
{
|
{
|
||||||
int status = 0;
|
int status = 0;
|
||||||
|
|
||||||
|
if (!dep->endpoint.desc)
|
||||||
|
return;
|
||||||
|
|
||||||
if (usb_endpoint_xfer_isoc(dep->endpoint.desc))
|
if (usb_endpoint_xfer_isoc(dep->endpoint.desc))
|
||||||
dwc3_gadget_endpoint_frame_from_event(dep, event);
|
dwc3_gadget_endpoint_frame_from_event(dep, event);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user