[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20260127110422.306711-1-jiangdayu@xiaomi.com>
Date: Tue, 27 Jan 2026 19:04:22 +0800
From: jiangdayu <jiangdayu@...omi.com>
To: Mathias Nyman <mathias.nyman@...el.com>, Greg Kroah-Hartman
<gregkh@...uxfoundation.org>
CC: Longfang Liu <liulongfang@...wei.com>, <linux-usb@...r.kernel.org>,
<linux-kernel@...r.kernel.org>, yudongbin <yudongbin@...omi.com>, guhuinan
<guhuinan@...omi.com>, chenyu45 <chenyu45@...omi.com>, mahongwei3
<mahongwei3@...omi.com>, jiangdayu <jiangdayu@...omi.com>
Subject: [PATCH] usb: xhci: add xhci_halt() for HCE Handling
When the xHCI controller reports a Host Controller Error (HCE) status
in the interrupt handler, the driver currently only logs a warning and
continues execution. However, a Host Controller Error indicates a
critical hardware failure that requires the controller to be halted.
Add xhci_halt(xhci) call after the HCE warning to properly halt the
controller when this error condition is detected. This ensures the
controller is in a consistent state and prevents further operations
on a failed hardware. Additionally, if there are still unhandled
interrupts at this point, it may cause interrupt storm.
The change is made in xhci_irq() function where STS_HCE status is
checked, mirroring the existing error handling pattern used for
STS_FATAL errors.
Fixes: 2a25e66d676df ("xhci: print warning when HCE was set")
Signed-off-by: jiangdayu <jiangdayu@...omi.com>
---
drivers/usb/host/xhci-ring.c | 1 +
1 file changed, 1 insertion(+)
diff --git a/drivers/usb/host/xhci-ring.c b/drivers/usb/host/xhci-ring.c
index 9315ba18310d..1cbefee3c4ca 100644
--- a/drivers/usb/host/xhci-ring.c
+++ b/drivers/usb/host/xhci-ring.c
@@ -3195,6 +3195,7 @@ irqreturn_t xhci_irq(struct usb_hcd *hcd)
if (status & STS_HCE) {
xhci_warn(xhci, "WARNING: Host Controller Error\n");
+ xhci_halt(xhci);
goto out;
}
--
2.34.1
Powered by blists - more mailing lists