Commit b033cfbe authored by David Brownell's avatar David Brownell Committed by Greg Kroah-Hartman

[PATCH] found_match return value incorrect.

> I've seen several cases where 'usbtest' would look at the device
> and say "no thanks", but then the "right" driver wouldn't ever
> bind to the device.

This patch seems to fix it.  I think Linus' tree needs it,
or something like it.

(Since the probe routine returns zero on success, there
was confusion inside the driver model code where it assumed
that zero meant failure.)
parent 71660e15
...@@ -54,7 +54,7 @@ static void attach(struct device * dev) ...@@ -54,7 +54,7 @@ static void attach(struct device * dev)
*/ */
static int found_match(struct device * dev, struct device_driver * drv) static int found_match(struct device * dev, struct device_driver * drv)
{ {
int error = 0; int error;
if (!(error = probe(dev,get_driver(drv)))) { if (!(error = probe(dev,get_driver(drv)))) {
pr_debug("bound device '%s' to driver '%s'\n", pr_debug("bound device '%s' to driver '%s'\n",
...@@ -64,7 +64,7 @@ static int found_match(struct device * dev, struct device_driver * drv) ...@@ -64,7 +64,7 @@ static int found_match(struct device * dev, struct device_driver * drv)
put_driver(drv); put_driver(drv);
dev->driver = NULL; dev->driver = NULL;
} }
return error; return error == 0;
} }
/** /**
...@@ -75,7 +75,9 @@ static int found_match(struct device * dev, struct device_driver * drv) ...@@ -75,7 +75,9 @@ static int found_match(struct device * dev, struct device_driver * drv)
* This function is used as a callback to bus_for_each_drv. * This function is used as a callback to bus_for_each_drv.
* It calls the bus's match callback to check if the driver supports * It calls the bus's match callback to check if the driver supports
* the device. If so, it calls the found_match() function above to * the device. If so, it calls the found_match() function above to
* take care of all the details. * try taking care of all the details.
*
* Returns zero (to continue the scan) if the driver didn't attach.
*/ */
static int do_device_attach(struct device_driver * drv, void * data) static int do_device_attach(struct device_driver * drv, void * data)
{ {
......
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