git: cacb5f3ea5d3 - stable/11 - xhci(4): Always add and evaluate the slot context.

From: Hans Petter Selasky <hselasky_at_FreeBSD.org>
Date: Wed, 04 May 2022 07:31:01 UTC
The branch stable/11 has been updated by hselasky:

URL: https://cgit.FreeBSD.org/src/commit/?id=cacb5f3ea5d39d9ee02e6f278993fb1b308ca9ba

commit cacb5f3ea5d39d9ee02e6f278993fb1b308ca9ba
Author:     Hans Petter Selasky <hselasky@FreeBSD.org>
AuthorDate: 2022-05-03 16:10:49 +0000
Commit:     Hans Petter Selasky <hselasky@FreeBSD.org>
CommitDate: 2022-05-04 07:30:12 +0000

    xhci(4): Always add and evaluate the slot context.
    
    Because the maximum number of endpoint contexts is stored there.
    
    Tested by:      ehaupt@
    PR:             262882
    Sponsored by:   NVIDIA Networking
    
    (cherry picked from commit 09dd1adfa4c9bb1b49f4ef5524a308732883e132)
---
 sys/dev/usb/controller/xhci.c | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)

diff --git a/sys/dev/usb/controller/xhci.c b/sys/dev/usb/controller/xhci.c
index 17fcc3ee09cf..4d7d9a199807 100644
--- a/sys/dev/usb/controller/xhci.c
+++ b/sys/dev/usb/controller/xhci.c
@@ -3951,7 +3951,11 @@ xhci_configure_reset_endpoint(struct usb_xfer *xfer)
 		}
 	}
 
-	xhci_configure_mask(udev, mask, 0);
+	/*
+	 * Always need to evaluate the slot context, because the maximum
+	 * number of endpoint contexts is stored there.
+	 */
+	xhci_configure_mask(udev, mask | 1U, 0);
 
 	if (!(sc->sc_hw.devs[index].ep_configured & mask)) {
 		err = xhci_cmd_configure_ep(sc, buf_inp.physaddr, 0, index);