Commit e5854355 authored by Matthias Kaehlcke's avatar Matthias Kaehlcke Committed by Greg Kroah-Hartman

usb: misc: onboard_hub: Invert driver registration order

The onboard_hub 'driver' consists of two drivers, a platform
driver and a USB driver. Currently when the onboard hub driver
is initialized it first registers the platform driver, then the
USB driver. This results in a race condition when the 'attach'
work is executed, which is scheduled when the platform device
is probed. The purpose of fhe 'attach' work is to bind elegible
USB hub devices to the onboard_hub USB driver. This fails if
the work runs before the USB driver has been registered.

Register the USB driver first, then the platform driver. This
increases the chances that the onboard_hub USB devices are probed
before their corresponding platform device, which the USB driver
tries to locate in _probe(). The driver already handles this
situation and defers probing if the onboard hub platform device
doesn't exist yet.

Cc: stable@vger.kernel.org
Fixes: 8bc06364 ("usb: misc: Add onboard_usb_hub driver")
Link: https://lore.kernel.org/lkml/Y6W00vQm3jfLflUJ@hovoldconsulting.com/T/#m0d64295f017942fd988f7c53425db302d61952b4Reported-by: default avatarAlexander Stein <alexander.stein@ew.tq-group.com>
Signed-off-by: default avatarMatthias Kaehlcke <mka@chromium.org>
Tested-by: default avatarStefan Wahren <stefan.wahren@i2se.com>
Link: https://lore.kernel.org/r/20230110172954.v2.1.I75494ebee7027a50235ce4b1e930fa73a578fbe2@changeidSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent fac4b863
...@@ -433,13 +433,13 @@ static int __init onboard_hub_init(void) ...@@ -433,13 +433,13 @@ static int __init onboard_hub_init(void)
{ {
int ret; int ret;
ret = platform_driver_register(&onboard_hub_driver); ret = usb_register_device_driver(&onboard_hub_usbdev_driver, THIS_MODULE);
if (ret) if (ret)
return ret; return ret;
ret = usb_register_device_driver(&onboard_hub_usbdev_driver, THIS_MODULE); ret = platform_driver_register(&onboard_hub_driver);
if (ret) if (ret)
platform_driver_unregister(&onboard_hub_driver); usb_deregister_device_driver(&onboard_hub_usbdev_driver);
return ret; return ret;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment