goto done;
        }
 
-       /* In these cases no commands are pending but the endpoint is stopped */
-       if (ep->ep_state & (EP_CLEARING_TT | EP_STALLED)) {
+       /* In this case no commands are pending but the endpoint is stopped */
+       if (ep->ep_state & EP_CLEARING_TT) {
                /* and cancelled TDs can be given back right away */
                xhci_dbg(xhci, "Invalidating TDs instantly on slot %d ep %d in state 0x%x\n",
                                urb->dev->slot_id, ep_index, ep->ep_state);
                return;
 
        ep = &vdev->eps[ep_index];
-
-       spin_lock_irqsave(&xhci->lock, flags);
-
        ep->ep_state &= ~EP_STALLED;
 
        /* Bail out if toggle is already being cleared by a endpoint reset */
+       spin_lock_irqsave(&xhci->lock, flags);
        if (ep->ep_state & EP_HARD_CLEAR_TOGGLE) {
                ep->ep_state &= ~EP_HARD_CLEAR_TOGGLE;
                spin_unlock_irqrestore(&xhci->lock, flags);