[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <2026012708-liability-sincere-5ed4@gregkh>
Date: Tue, 27 Jan 2026 12:22:40 +0100
From: Greg Kroah-Hartman <gregkh@...uxfoundation.org>
To: jiangdayu <jiangdayu@...omi.com>
Cc: Mathias Nyman <mathias.nyman@...el.com>,
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>
Subject: Re: [PATCH] usb: xhci: add xhci_halt() for HCE Handling
On Tue, Jan 27, 2026 at 07:04:22PM +0800, jiangdayu wrote:
> 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>
We need a full name, not an email alias, sorry.
And this isn't really "fixing" that commit, there's nothing wrong with
it as-is. This is adding new functionality to the code.
> ---
> 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);
What is going to start things back up again? And as you are calling
this function, why is the warning message needed anymore? The
tracepoint information will give you that message now, right?
And is this just papering over a hardware bug? Should this really be
happening for any normal system?
thanks,
greg k-h
Powered by blists - more mailing lists