|
@@ -894,6 +894,9 @@ int __dwc3_gadget_ep_set_halt(struct dwc3_ep *dep, int value)
|
|
|
else
|
|
|
dep->flags |= DWC3_EP_STALL;
|
|
|
} else {
|
|
|
+ if (dep->flags & DWC3_EP_WEDGE)
|
|
|
+ return 0;
|
|
|
+
|
|
|
ret = dwc3_send_gadget_ep_cmd(dwc, dep->number,
|
|
|
DWC3_DEPCMD_CLEARSTALL, ¶ms);
|
|
|
if (ret)
|
|
@@ -903,6 +906,7 @@ int __dwc3_gadget_ep_set_halt(struct dwc3_ep *dep, int value)
|
|
|
else
|
|
|
dep->flags &= ~DWC3_EP_STALL;
|
|
|
}
|
|
|
+
|
|
|
return ret;
|
|
|
}
|
|
|
|
|
@@ -936,7 +940,7 @@ static int dwc3_gadget_ep_set_wedge(struct usb_ep *ep)
|
|
|
|
|
|
dep->flags |= DWC3_EP_WEDGE;
|
|
|
|
|
|
- return usb_ep_set_halt(ep);
|
|
|
+ return dwc3_gadget_ep_set_halt(ep, 1);
|
|
|
}
|
|
|
|
|
|
/* -------------------------------------------------------------------------- */
|