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

usb: misc: onboard_usb_dev: Add match function

Add a match function for the onboard_usb_dev driver. Primary
matching is still done through the VID:PID pair, as usual for
USB devices. The new match function checks in addition whether
the device has a device tree node, which is a needed for using
the onboard_usb_dev driver.

Remove the check for a device tree node from _probe(), the new
match functions prevents devices without DT node from probing.
Signed-off-by: default avatarMatthias Kaehlcke <mka@chromium.org>
Tested-by: default avatarJameson Thies <jthies@google.com>
Reviewed-by: default avatarJameson Thies <jthies@google.com>
Link: https://lore.kernel.org/r/20240612180448.1.I805556c176c626872c15ce001f0e8198e1f95ae1@changeidSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent b38aa697
...@@ -454,16 +454,18 @@ static struct onboard_dev *_find_onboard_dev(struct device *dev) ...@@ -454,16 +454,18 @@ static struct onboard_dev *_find_onboard_dev(struct device *dev)
return onboard_dev; return onboard_dev;
} }
static bool onboard_dev_usbdev_match(struct usb_device *udev)
{
/* Onboard devices using this driver must have a device tree node */
return !!udev->dev.of_node;
}
static int onboard_dev_usbdev_probe(struct usb_device *udev) static int onboard_dev_usbdev_probe(struct usb_device *udev)
{ {
struct device *dev = &udev->dev; struct device *dev = &udev->dev;
struct onboard_dev *onboard_dev; struct onboard_dev *onboard_dev;
int err; int err;
/* ignore supported devices without device tree node */
if (!dev->of_node)
return -ENODEV;
onboard_dev = _find_onboard_dev(dev); onboard_dev = _find_onboard_dev(dev);
if (IS_ERR(onboard_dev)) if (IS_ERR(onboard_dev))
return PTR_ERR(onboard_dev); return PTR_ERR(onboard_dev);
...@@ -513,6 +515,7 @@ MODULE_DEVICE_TABLE(usb, onboard_dev_id_table); ...@@ -513,6 +515,7 @@ MODULE_DEVICE_TABLE(usb, onboard_dev_id_table);
static struct usb_device_driver onboard_dev_usbdev_driver = { static struct usb_device_driver onboard_dev_usbdev_driver = {
.name = "onboard-usb-dev", .name = "onboard-usb-dev",
.match = onboard_dev_usbdev_match,
.probe = onboard_dev_usbdev_probe, .probe = onboard_dev_usbdev_probe,
.disconnect = onboard_dev_usbdev_disconnect, .disconnect = onboard_dev_usbdev_disconnect,
.generic_subclass = 1, .generic_subclass = 1,
......
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