lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <73d472ea-e660-474c-b319-b0e8758406c0@rowland.harvard.edu>
Date: Tue, 30 Dec 2025 11:42:35 -0500
From: Alan Stern <stern@...land.harvard.edu>
To: Diederik de Haas <diederik@...ow-tech.com>
Cc: Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
	Huacai Chen <chenhuacai@...ngson.cn>,
	Huacai Chen <chenhuacai@...nel.org>, linux-usb@...r.kernel.org,
	linux-kernel@...r.kernel.org, stable@...r.kernel.org,
	Shengwen Xiao <atzlinux@...a.com>,
	linux-rockchip@...ts.infradead.org
Subject: Re: [PATCH] USB: OHCI/UHCI: Add soft dependencies on ehci_hcd

On Tue, Dec 30, 2025 at 03:40:27PM +0100, Diederik de Haas wrote:
> On Tue Dec 30, 2025 at 9:15 AM CET, Greg Kroah-Hartman wrote:
> > On Tue, Dec 30, 2025 at 04:00:14PM +0800, Huacai Chen wrote:
> >> Commit 9beeee6584b9aa4f ("USB: EHCI: log a warning if ehci-hcd is not
> >> loaded first") said that ehci-hcd should be loaded before ohci-hcd and
> >> uhci-hcd. However, commit 05c92da0c52494ca ("usb: ohci/uhci - add soft
> >> dependencies on ehci_pci") only makes ohci-pci/uhci-pci depend on ehci-
> >> pci, which is not enough and we may still see the warnings in boot log.
> >> So fix it by also making ohci-hcd/uhci-hcd depend on ehci-hcd.
> >> 
> >> Cc: stable@...r.kernel.org
> >> Reported-by: Shengwen Xiao <atzlinux@...a.com>
> >> Signed-off-by: Huacai Chen <chenhuacai@...ngson.cn>
> >> ---
> >>  drivers/usb/host/ohci-hcd.c | 1 +
> >>  drivers/usb/host/uhci-hcd.c | 1 +
> >>  2 files changed, 2 insertions(+)
> >> 
> >> diff --git a/drivers/usb/host/ohci-hcd.c b/drivers/usb/host/ohci-hcd.c
> >> index 9c7f3008646e..549c965b7fbe 100644
> >> --- a/drivers/usb/host/ohci-hcd.c
> >> +++ b/drivers/usb/host/ohci-hcd.c
> >> @@ -1355,4 +1355,5 @@ static void __exit ohci_hcd_mod_exit(void)
> >>  	clear_bit(USB_OHCI_LOADED, &usb_hcds_loaded);
> >>  }
> >>  module_exit(ohci_hcd_mod_exit);
> >> +MODULE_SOFTDEP("pre: ehci_hcd");
> >
> > Ick, no, this way lies madness.  I hate the "softdep" stuff, it's
> > usually a sign that something is wrong elsewhere.
> >
> > And don't add this _just_ to fix a warning message in a boot log, if you
> > don't like that message, then build the module into your kernel, right?
> >
> > And I really should just go revert 05c92da0c524 ("usb: ohci/uhci - add
> > soft dependencies on ehci_pci") as well, that feels wrong too.
> 
> FWIW, I've been seeing this warning on several of my Rockchip based
> devices as well. I thought I had already mentioned that on some ML, but
> couldn't find it on lore.k.o ... turns out I reported it on my 'own' ML:
> https://lists.sr.ht/~diederik/pine64-discuss/%3CDD65LB64HB7K.15ZYRTB98X8G2@cknow.org%3E
> (and likely on #linux-rockchip IRC channel)
> 
> Most of it is just my research notes, but the last post also had this:
> 
> ```
> I checked the last 20 boots on my devices to see that warning (or not).
> Device				Number of times that warning showed up
> Rock64 (rk3328)			16x
> RockPro64 (rk3399)		11x
> Quartz64 Model A (rk3566)	 7x
> Quartz64 Model B (rk3566)	14x
> PineTab2 (rk3566)		17x
> NanoPi R5S (rk3568)		13x
> Rock 5B (rk3588)		12x
> ```
> 
> While I generally don't like seeing warning messages, it often also
> resulted in USB2 ports not working. Maybe even every time, but I only
> notice it when I actually tried to use one of the USB2 ports.
> 
> The first post mentioned what I 'assume' to be the problem:
> ```
> CONFIG_USB_XHCI_HCD=m
> CONFIG_USB_EHCI_HCD=m
> CONFIG_USB_OHCI_HCD=m
> ```
> 
> So I guess USB_EHCI_HCD doesn't work with '=m'.

Not true, it really does work with "=m".

And in fact, your systems should work even if the modules are loaded in 
the wrong order.  The issue is that doing so can cause a brief 
interruption in the existing USB connections when the ehci-pci module is 
loaded.

If your systems don't use PCI for these host controllers then I don't 
know how they would behave.  The issue is: How does the hardware route 
low-speed and full-speed USB connections to the different types of 
controller?

On PCI systems, when ehci-pci isn't loaded, the hardware routes all 
connections directly to the companion UHCI or OHCI controller.  When 
ehci-pci is loaded, the hardware routes connections to the EHCI 
controller, and when the driver sees that a connection isn't running at 
high speed (480 Mb/s), it tells the hardware to switch the connection 
over to the companion.

So if a low-speed (1.5 Mb/s) or full-speed (12 Mb/s) device is connected 
before ehci-pci loads, its connection will get routed to the companion 
controller.  Then when ehci-pci loads, the connection will be switched 
over to the EHCI controller, which will cause the existing connection to 
be dropped.  Then the connection will be routed back to the companion 
controller, but it will be perceived as a new connection, resulting in a 
brief interruption in service.  For many devices this won't matter, but 
for some it might.  The only way to avoid the problem is to load 
ehci-pci before uhci-pci and ohci-pci.

(A similar problem can occur with high-speed-capable devices.  When 
initially attached to the companion controller, they are forced to 
connect at full speed.  But when the connection is changed to the EHCI 
controller, they are able to run at high speed -- and again, the result 
is a new connection, causing service to be interrupted and then start up 
fresh but running much faster.)

Alan Stern

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ