* [PATCH v4 -next] usb: xhci: disable irq during initialization
@ 2022-06-16 8:09 Hongyu Xie
2022-06-16 8:12 ` Greg KH
0 siblings, 1 reply; 4+ messages in thread
From: Hongyu Xie @ 2022-06-16 8:09 UTC (permalink / raw)
To: mathias.nyman, gregkh
Cc: linux-usb, linux-kernel, 125707942, wangqi, xiongxin, Hongyu Xie,
kernel test robot
irq is disabled in xhci_quiesce(called by xhci_halt, with bit:2 cleared
in USBCMD register), but xhci_run(called by usb_add_hcd) re-enable it.
It's possible that you will receive thousands of interrupt requests
after initialization for 2.0 roothub. And you will get a lot of
warning like, "xHCI dying, ignoring interrupt. Shouldn't IRQs be
disabled?". This amount of interrupt requests will cause the entire
system to freeze.
This problem was first found on a device with ASM2142 host controller
on it.
Signed-off-by: Hongyu Xie <xiehongyu1@kylinos.cn>
Reported-by: kernel test robot <lkp@intel.com>
---
v4: add definition for flags
v3:
- enabling interrupt right before setting Run/Stop bit
- spin_lock_irqsave to prevent receiving irqs in the small window
according to Mathias's suggestion
v2: fix compile error
drivers/usb/host/xhci.c | 41 +++++++++++++++++++++++++++--------------
1 file changed, 27 insertions(+), 14 deletions(-)
diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c
index 9ac56e9ffc64..1344cc566338 100644
--- a/drivers/usb/host/xhci.c
+++ b/drivers/usb/host/xhci.c
@@ -611,15 +611,41 @@ static int xhci_init(struct usb_hcd *hcd)
static int xhci_run_finished(struct xhci_hcd *xhci)
{
+ unsigned long flags;
+ u32 temp;
+
+ /* Prevent receiving irqs in the small window between enabling interrupt
+ * and setting Run/Stop bit
+ */
+ spin_lock_irqsave(&xhci->lock, flags);
+
+ /* Enable interrupt right before setting Run/Stop bit according to spec
+ * 4.2
+ */
+ /* Set the HCD state before we enable the irqs */
+ temp = readl(&xhci->op_regs->command);
+ temp |= (CMD_EIE);
+ xhci_dbg_trace(xhci, trace_xhci_dbg_init,
+ "// Enable interrupts, cmd = 0x%x.", temp);
+ writel(temp, &xhci->op_regs->command);
+
+ temp = readl(&xhci->ir_set->irq_pending);
+ xhci_dbg_trace(xhci, trace_xhci_dbg_init,
+ "// %s %p by writing 0x%x %s",
+ "Enabling event ring interrupter",
+ "to irq_pending", xhci->ir_set,
+ (unsigned int) ER_IRQ_ENABLE(temp));
+ writel(ER_IRQ_ENABLE(temp), &xhci->ir_set->irq_pending);
if (xhci_start(xhci)) {
xhci_halt(xhci);
+ spin_unlock_irqrestore(&xhci->lock, flags);
return -ENODEV;
}
xhci->cmd_ring_state = CMD_RING_STATE_RUNNING;
if (xhci->quirks & XHCI_NEC_HOST)
xhci_ring_cmd_db(xhci);
-
+ spin_unlock_irqrestore(&xhci->lock, flags);
return 0;
}
@@ -668,19 +694,6 @@ int xhci_run(struct usb_hcd *hcd)
temp |= (xhci->imod_interval / 250) & ER_IRQ_INTERVAL_MASK;
writel(temp, &xhci->ir_set->irq_control);
- /* Set the HCD state before we enable the irqs */
- temp = readl(&xhci->op_regs->command);
- temp |= (CMD_EIE);
- xhci_dbg_trace(xhci, trace_xhci_dbg_init,
- "// Enable interrupts, cmd = 0x%x.", temp);
- writel(temp, &xhci->op_regs->command);
-
- temp = readl(&xhci->ir_set->irq_pending);
- xhci_dbg_trace(xhci, trace_xhci_dbg_init,
- "// Enabling event ring interrupter %p by writing 0x%x to irq_pending",
- xhci->ir_set, (unsigned int) ER_IRQ_ENABLE(temp));
- writel(ER_IRQ_ENABLE(temp), &xhci->ir_set->irq_pending);
-
if (xhci->quirks & XHCI_NEC_HOST) {
struct xhci_command *command;
--
2.25.1
^ permalink raw reply related [flat|nested] 4+ messages in thread* Re: [PATCH v4 -next] usb: xhci: disable irq during initialization
2022-06-16 8:09 [PATCH v4 -next] usb: xhci: disable irq during initialization Hongyu Xie
@ 2022-06-16 8:12 ` Greg KH
2022-06-16 8:24 ` 谢泓宇
0 siblings, 1 reply; 4+ messages in thread
From: Greg KH @ 2022-06-16 8:12 UTC (permalink / raw)
To: Hongyu Xie
Cc: mathias.nyman, linux-usb, linux-kernel, 125707942, wangqi,
xiongxin, Hongyu Xie, kernel test robot
On Thu, Jun 16, 2022 at 04:09:33PM +0800, Hongyu Xie wrote:
> irq is disabled in xhci_quiesce(called by xhci_halt, with bit:2 cleared
> in USBCMD register), but xhci_run(called by usb_add_hcd) re-enable it.
> It's possible that you will receive thousands of interrupt requests
> after initialization for 2.0 roothub. And you will get a lot of
> warning like, "xHCI dying, ignoring interrupt. Shouldn't IRQs be
> disabled?". This amount of interrupt requests will cause the entire
> system to freeze.
> This problem was first found on a device with ASM2142 host controller
> on it.
>
> Signed-off-by: Hongyu Xie <xiehongyu1@kylinos.cn>
> Reported-by: kernel test robot <lkp@intel.com>
the test robot did not find this original problem, it only found
problems with your original submission, which is different.
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH v4 -next] usb: xhci: disable irq during initialization
2022-06-16 8:12 ` Greg KH
@ 2022-06-16 8:24 ` 谢泓宇
2022-06-16 8:34 ` Greg KH
0 siblings, 1 reply; 4+ messages in thread
From: 谢泓宇 @ 2022-06-16 8:24 UTC (permalink / raw)
To: Greg KH, Hongyu Xie
Cc: mathias.nyman, linux-usb, linux-kernel, 125707942, wangqi,
xiongxin, kernel test robot
Hi greg,
On 2022/6/16 16:12, Greg KH wrote:
> On Thu, Jun 16, 2022 at 04:09:33PM +0800, Hongyu Xie wrote:
>> irq is disabled in xhci_quiesce(called by xhci_halt, with bit:2 cleared
>> in USBCMD register), but xhci_run(called by usb_add_hcd) re-enable it.
>> It's possible that you will receive thousands of interrupt requests
>> after initialization for 2.0 roothub. And you will get a lot of
>> warning like, "xHCI dying, ignoring interrupt. Shouldn't IRQs be
>> disabled?". This amount of interrupt requests will cause the entire
>> system to freeze.
>> This problem was first found on a device with ASM2142 host controller
>> on it.
>>
>> Signed-off-by: Hongyu Xie <xiehongyu1@kylinos.cn>
>> Reported-by: kernel test robot <lkp@intel.com>
>
> the test robot did not find this original problem, it only found
> problems with your original submission, which is different.
>
"Reported-by" shouldn't had been put here.
Quote from the last email test robot sent to me,
"If you fix the issue, kindly add following tag where applicable
Reported-by: kernel test robot <lkp@intel.com>"
Where should I put this? Or just ignore it?
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH v4 -next] usb: xhci: disable irq during initialization
2022-06-16 8:24 ` 谢泓宇
@ 2022-06-16 8:34 ` Greg KH
0 siblings, 0 replies; 4+ messages in thread
From: Greg KH @ 2022-06-16 8:34 UTC (permalink / raw)
To: 谢泓宇
Cc: Hongyu Xie, mathias.nyman, linux-usb, linux-kernel, 125707942,
wangqi, xiongxin, kernel test robot
On Thu, Jun 16, 2022 at 04:24:08PM +0800, 谢泓宇 wrote:
> Hi greg,
>
> On 2022/6/16 16:12, Greg KH wrote:
> > On Thu, Jun 16, 2022 at 04:09:33PM +0800, Hongyu Xie wrote:
> > > irq is disabled in xhci_quiesce(called by xhci_halt, with bit:2 cleared
> > > in USBCMD register), but xhci_run(called by usb_add_hcd) re-enable it.
> > > It's possible that you will receive thousands of interrupt requests
> > > after initialization for 2.0 roothub. And you will get a lot of
> > > warning like, "xHCI dying, ignoring interrupt. Shouldn't IRQs be
> > > disabled?". This amount of interrupt requests will cause the entire
> > > system to freeze.
> > > This problem was first found on a device with ASM2142 host controller
> > > on it.
> > >
> > > Signed-off-by: Hongyu Xie <xiehongyu1@kylinos.cn>
> > > Reported-by: kernel test robot <lkp@intel.com>
> >
> > the test robot did not find this original problem, it only found
> > problems with your original submission, which is different.
> >
> "Reported-by" shouldn't had been put here.
> Quote from the last email test robot sent to me,
> "If you fix the issue, kindly add following tag where applicable
> Reported-by: kernel test robot <lkp@intel.com>"
> Where should I put this? Or just ignore it?
>
Yes, you can ignore it but you properly referenced it in your changelog
area.
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2022-06-16 8:35 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-06-16 8:09 [PATCH v4 -next] usb: xhci: disable irq during initialization Hongyu Xie
2022-06-16 8:12 ` Greg KH
2022-06-16 8:24 ` 谢泓宇
2022-06-16 8:34 ` Greg KH
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox