[SCSI] fix up non-modular SCSI
authorJames Bottomley <James.Bottomley@steeleye.com>
Wed, 6 Sep 2006 14:00:29 +0000 (09:00 -0500)
committerJames Bottomley <jejb@mulgrave.il.steeleye.com>
Thu, 7 Sep 2006 15:37:22 +0000 (10:37 -0500)
The recent change to the way scsi_device_get()/put() work broke the
non modular build (we do a module_refcount on a NULL).  Fix this by
checking for non-null before checking module_refcount().

Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
drivers/scsi/scsi.c

index eedfd05..c35f5fc 100644 (file)
@@ -873,10 +873,12 @@ EXPORT_SYMBOL(scsi_device_get);
  */
 void scsi_device_put(struct scsi_device *sdev)
 {
+       struct module *module = sdev->host->hostt->module;
+
        /* The module refcount will be zero if scsi_device_get()
         * was called from a module removal routine */
-       if (likely(module_refcount(sdev->host->hostt->module) != 0))
-               module_put(sdev->host->hostt->module);
+       if (module && module_refcount(module) != 0)
+               module_put(module);
        put_device(&sdev->sdev_gendev);
 }
 EXPORT_SYMBOL(scsi_device_put);