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

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

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

commit 11a732b280319e2babb5d575d14e89e12127d06a
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:28:46 +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 c2c111525e81..1d335fa6ee8d 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);