summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBastien Nocera <hadess@hadess.net>2020-08-18 13:04:43 +0200
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2020-09-03 11:29:49 +0200
commita18d5d456c009d69bd032fc96f4751d58e6ccc3a (patch)
treee7254d39526210aef6c53a5d8be7439104a0c869
parent0ca26ffe3c1f381f95a0c0bbb5e8241d8c7183cc (diff)
downloadlinux-stable-a18d5d456c009d69bd032fc96f4751d58e6ccc3a.tar.gz
linux-stable-a18d5d456c009d69bd032fc96f4751d58e6ccc3a.tar.bz2
linux-stable-a18d5d456c009d69bd032fc96f4751d58e6ccc3a.zip
USB: Also match device drivers using the ->match vfunc
commit adb6e6ac20eedcf1dce19dc75b224e63c0828ea1 upstream. We only ever used the ID table matching before, but we should also support open-coded match functions. Fixes: 88b7381a939de ("USB: Select better matching USB drivers when available") Signed-off-by: Bastien Nocera <hadess@hadess.net> Cc: stable <stable@vger.kernel.org> Acked-by: Alan Stern <stern@rowland.harvard.edu> Link: https://lore.kernel.org/r/20200818110445.509668-1-hadess@hadess.net Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r--drivers/usb/core/generic.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/usb/core/generic.c b/drivers/usb/core/generic.c
index 4626227a6dd2..cd08a47144bd 100644
--- a/drivers/usb/core/generic.c
+++ b/drivers/usb/core/generic.c
@@ -207,8 +207,9 @@ static int __check_usb_generic(struct device_driver *drv, void *data)
return 0;
if (!udrv->id_table)
return 0;
-
- return usb_device_match_id(udev, udrv->id_table) != NULL;
+ if (usb_device_match_id(udev, udrv->id_table) != NULL)
+ return 1;
+ return (udrv->match && udrv->match(udev));
}
static bool usb_generic_driver_match(struct usb_device *udev)