linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 5.10 0/1] backport of 'xhci: Set HCD flag to defer primary roothub registration'
@ 2023-01-25 13:33 Adrian Zaharia
  2023-01-25 13:33 ` [PATCH 5.10 1/1] xhci: Set HCD flag to defer primary roothub registration Adrian Zaharia
  0 siblings, 1 reply; 3+ messages in thread
From: Adrian Zaharia @ 2023-01-25 13:33 UTC (permalink / raw)
  To: stable; +Cc: mathias.nyman, gregkh, linux-usb, linux-kernel

From: Adrian Zaharia <Adrian.Zaharia@windriver.com>

This patch enables the flag to defer registering primary roothub if xhci has two roothubs.
Link to upstream patch:
https://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb.git/commit/?id=b7a4f9b5d0e4b6dd937678c546c0b322dd1a4054

The support for deferring roothub registration was added in 5.10.121.
(See: a2532c441705 "usb: core: hcd: Add support for deferring roothub registration")


Kishon Vijay Abraham I (1):
  xhci: Set HCD flag to defer primary roothub registration

 drivers/usb/host/xhci.c | 2 ++
 1 file changed, 2 insertions(+)


base-commit: 179624a57b78c02de833370b7bdf0b0f4a27ca31
-- 
2.39.1


^ permalink raw reply	[flat|nested] 3+ messages in thread

* [PATCH 5.10 1/1] xhci: Set HCD flag to defer primary roothub registration
  2023-01-25 13:33 [PATCH 5.10 0/1] backport of 'xhci: Set HCD flag to defer primary roothub registration' Adrian Zaharia
@ 2023-01-25 13:33 ` Adrian Zaharia
  2023-01-27  7:25   ` Greg KH
  0 siblings, 1 reply; 3+ messages in thread
From: Adrian Zaharia @ 2023-01-25 13:33 UTC (permalink / raw)
  To: stable; +Cc: mathias.nyman, gregkh, linux-usb, linux-kernel

From: Kishon Vijay Abraham I <kishon@ti.com>

[ Upstream commit b7a4f9b5d0e4b6dd937678c546c0b322dd1a4054 ]

Set "HCD_FLAG_DEFER_RH_REGISTER" to hcd->flags in xhci_run() to defer
registering primary roothub in usb_add_hcd() if xhci has two roothubs.
This will make sure both primary roothub and secondary roothub will be
registered along with the second HCD.
This is required for cold plugged USB devices to be detected in certain
PCIe USB cards (like Inateck USB card connected to AM64 EVM or J7200 EVM).

This patch has been added and reverted earier as it triggered a race
in usb device enumeration.
That race is now fixed in 5.16-rc3, and in stable back to 5.4
commit 6cca13de26ee ("usb: hub: Fix locking issues with address0_mutex")
commit 6ae6dc22d2d1 ("usb: hub: Fix usb enumeration issue due to address0
race")

[minor rebase change, and commit message update -Mathias]

CC: stable@vger.kernel.org # 5.4+
Suggested-by: Mathias Nyman <mathias.nyman@linux.intel.com>
Tested-by: Chris Chiu <chris.chiu@canonical.com>
Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
Link: https://lore.kernel.org/r/20220510091630.16564-3-kishon@ti.com
Signed-off-by: Adrian Zaharia <Adrian.Zaharia@windriver.com>
---
 drivers/usb/host/xhci.c | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c
index 2967372a9988..473b0b64dd57 100644
--- a/drivers/usb/host/xhci.c
+++ b/drivers/usb/host/xhci.c
@@ -696,6 +696,8 @@ int xhci_run(struct usb_hcd *hcd)
 	xhci_dbg_trace(xhci, trace_xhci_dbg_init,
 			"Finished xhci_run for USB2 roothub");
 
+	set_bit(HCD_FLAG_DEFER_RH_REGISTER, &hcd->flags);
+
 	xhci_dbc_init(xhci);
 
 	xhci_debugfs_init(xhci);
-- 
2.39.1


^ permalink raw reply related	[flat|nested] 3+ messages in thread

* Re: [PATCH 5.10 1/1] xhci: Set HCD flag to defer primary roothub registration
  2023-01-25 13:33 ` [PATCH 5.10 1/1] xhci: Set HCD flag to defer primary roothub registration Adrian Zaharia
@ 2023-01-27  7:25   ` Greg KH
  0 siblings, 0 replies; 3+ messages in thread
From: Greg KH @ 2023-01-27  7:25 UTC (permalink / raw)
  To: Adrian Zaharia; +Cc: stable, mathias.nyman, linux-usb, linux-kernel

On Wed, Jan 25, 2023 at 03:33:59PM +0200, Adrian Zaharia wrote:
> From: Kishon Vijay Abraham I <kishon@ti.com>
> 
> [ Upstream commit b7a4f9b5d0e4b6dd937678c546c0b322dd1a4054 ]
> 
> Set "HCD_FLAG_DEFER_RH_REGISTER" to hcd->flags in xhci_run() to defer
> registering primary roothub in usb_add_hcd() if xhci has two roothubs.
> This will make sure both primary roothub and secondary roothub will be
> registered along with the second HCD.
> This is required for cold plugged USB devices to be detected in certain
> PCIe USB cards (like Inateck USB card connected to AM64 EVM or J7200 EVM).
> 
> This patch has been added and reverted earier as it triggered a race
> in usb device enumeration.
> That race is now fixed in 5.16-rc3, and in stable back to 5.4
> commit 6cca13de26ee ("usb: hub: Fix locking issues with address0_mutex")
> commit 6ae6dc22d2d1 ("usb: hub: Fix usb enumeration issue due to address0
> race")
> 
> [minor rebase change, and commit message update -Mathias]
> 
> CC: stable@vger.kernel.org # 5.4+
> Suggested-by: Mathias Nyman <mathias.nyman@linux.intel.com>
> Tested-by: Chris Chiu <chris.chiu@canonical.com>
> Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
> Link: https://lore.kernel.org/r/20220510091630.16564-3-kishon@ti.com
> Signed-off-by: Adrian Zaharia <Adrian.Zaharia@windriver.com>
> ---
>  drivers/usb/host/xhci.c | 2 ++
>  1 file changed, 2 insertions(+)

You dropped my original signed-off-by?  Odd...

Anyway, now queued up.

greg k-h

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2023-01-27  7:25 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-01-25 13:33 [PATCH 5.10 0/1] backport of 'xhci: Set HCD flag to defer primary roothub registration' Adrian Zaharia
2023-01-25 13:33 ` [PATCH 5.10 1/1] xhci: Set HCD flag to defer primary roothub registration Adrian Zaharia
2023-01-27  7:25   ` Greg KH

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).