[SCSI] add failure return to scsi_init_shared_tag_map()
authorJames Bottomley <James.Bottomley@steeleye.com>
Fri, 1 Sep 2006 13:28:48 +0000 (09:28 -0400)
committerJames Bottomley <jejb@mulgrave.il.steeleye.com>
Sat, 2 Sep 2006 18:57:28 +0000 (13:57 -0500)
And use it in the stex driver.

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

index 15fb99f224ee16b697722633c365faccf9ba5305..3cf3106a29b8e45fb6515817e5c9280cff07900d 100644 (file)
@@ -1108,9 +1108,8 @@ stex_probe(struct pci_dev *pdev, const struct pci_device_id *id)
        if (err)
                goto out_free_irq;
 
-       scsi_init_shared_tag_map(host, ST_CAN_QUEUE);
-       if (host->bqt == NULL) {
-               err = -ENOMEM;
+       err = scsi_init_shared_tag_map(host, ST_CAN_QUEUE);
+       if (err) {
                printk(KERN_ERR DRV_NAME "(%s): init shared queue failed\n",
                        pci_name(pdev));
                goto out_free_irq;
index 4eea254b1ce9e22a51433fbc58444f026f4a817c..d04d05adfa9b68ca1ccd08e231a81996a316c714 100644 (file)
@@ -138,9 +138,10 @@ static inline struct scsi_cmnd *scsi_find_tag(struct scsi_device *sdev, int tag)
  * @shost:     the host to share the tag map among all devices
  * @depth:     the total depth of the map
  */
-static inline void scsi_init_shared_tag_map(struct Scsi_Host *shost, int depth)
+static inline int scsi_init_shared_tag_map(struct Scsi_Host *shost, int depth)
 {
        shost->bqt = blk_init_tags(depth);
+       return shost->bqt ? 0 : -ENOMEM;
 }
 
 #endif /* _SCSI_SCSI_TCQ_H */