* @drv: driver to bind a device to
  * @dev: device to try to bind to the driver
  *
- * This function returns -ENODEV if the device is not registered,
- * 1 if the device is bound successfully and 0 otherwise.
+ * This function returns -ENODEV if the device is not registered, -EBUSY if it
+ * already has a driver, and 1 if the device is bound successfully and 0
+ * otherwise.
  *
  * This function must be called with @dev lock held.  When called for a
  * USB interface, @dev->parent lock must be held as well.
 {
        int ret = 0;
 
-       if (!device_is_registered(dev))
+       if (dev->p->dead || !device_is_registered(dev))
                return -ENODEV;
+       if (dev->driver)
+               return -EBUSY;
 
        dev->can_match = true;
        pr_debug("bus: '%s': %s: matched device %s with driver %s\n",
  */
 int device_driver_attach(struct device_driver *drv, struct device *dev)
 {
-       int ret = 0;
+       int ret;
 
        __device_driver_lock(dev, dev->parent);
-
-       /*
-        * If device has been removed or someone has already successfully
-        * bound a driver before us just skip the driver probe call.
-        */
-       if (!dev->p->dead && !dev->driver)
-               ret = driver_probe_device(drv, dev);
-
+       ret = driver_probe_device(drv, dev);
        __device_driver_unlock(dev, dev->parent);
 
        return ret;
 {
        struct device *dev = _dev;
        struct device_driver *drv;
-       int ret = 0;
+       int ret;
 
        __device_driver_lock(dev, dev->parent);
-
        drv = dev->p->async_driver;
-
-       /*
-        * If device has been removed or someone has already successfully
-        * bound a driver before us just skip the driver probe call.
-        */
-       if (!dev->p->dead && !dev->driver)
-               ret = driver_probe_device(drv, dev);
-
+       ret = driver_probe_device(drv, dev);
        __device_driver_unlock(dev, dev->parent);
 
        dev_dbg(dev, "driver %s async attach completed: %d\n", drv->name, ret);