]> git.karo-electronics.de Git - mv-sheeva.git/blobdiff - drivers/scsi/device_handler/scsi_dh.c
Merge tag 'v2.6.38' of git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6
[mv-sheeva.git] / drivers / scsi / device_handler / scsi_dh.c
index 6fae3d285ae79d5680f3d1e5d4cad02f5b47d3b6..b837c5b3c8f9daf70dfa9031d24ecb418330e4e6 100644 (file)
@@ -442,12 +442,19 @@ int scsi_dh_activate(struct request_queue *q, activate_complete fn, void *data)
        sdev = q->queuedata;
        if (sdev && sdev->scsi_dh_data)
                scsi_dh = sdev->scsi_dh_data->scsi_dh;
-       if (!scsi_dh || !get_device(&sdev->sdev_gendev))
+       if (!scsi_dh || !get_device(&sdev->sdev_gendev) ||
+           sdev->sdev_state == SDEV_CANCEL ||
+           sdev->sdev_state == SDEV_DEL)
                err = SCSI_DH_NOSYS;
+       if (sdev->sdev_state == SDEV_OFFLINE)
+               err = SCSI_DH_DEV_OFFLINED;
        spin_unlock_irqrestore(q->queue_lock, flags);
 
-       if (err)
+       if (err) {
+               if (fn)
+                       fn(data, err);
                return err;
+       }
 
        if (scsi_dh->activate)
                err = scsi_dh->activate(sdev, fn, data);