summaryrefslogtreecommitdiffstats
path: root/drivers/scsi/ibmvscsi
diff options
context:
space:
mode:
authorChristoph Hellwig <hch@lst.de>2014-11-03 08:09:02 -0500
committerChristoph Hellwig <hch@lst.de>2014-11-12 05:19:43 -0500
commit2ecb204d07ac8debe3893c362415919bc78bebd6 (patch)
treeeef99b324201b21de358dffdab8bfc0453358d5f /drivers/scsi/ibmvscsi
parente2eddf4d530df745019fded0fedfb78f6d3e33ca (diff)
scsi: always assign block layer tags if enabled
Allow a driver to ask for block layer tags by setting .use_blk_tags in the host template, in which case it will always see a valid value in request->tag, similar to the behavior when using blk-mq. This means even SCSI "untagged" commands will now have a tag, which is especially useful when using a host-wide tag map. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Mike Christie <michaelc@cs.wisc.edu> Reviewed-by: Martin K. Petersen <martin.petersen@oracle.com> Reviewed-by: Hannes Reinecke <hare@suse.de>
Diffstat (limited to 'drivers/scsi/ibmvscsi')
-rw-r--r--drivers/scsi/ibmvscsi/ibmvfc.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/drivers/scsi/ibmvscsi/ibmvfc.c b/drivers/scsi/ibmvscsi/ibmvfc.c
index a964f8c85833..4723d89df5ac 100644
--- a/drivers/scsi/ibmvscsi/ibmvfc.c
+++ b/drivers/scsi/ibmvscsi/ibmvfc.c
@@ -2888,11 +2888,11 @@ static int ibmvfc_slave_configure(struct scsi_device *sdev)
2888 if (sdev->type == TYPE_DISK) 2888 if (sdev->type == TYPE_DISK)
2889 sdev->allow_restart = 1; 2889 sdev->allow_restart = 1;
2890 2890
2891 if (sdev->tagged_supported) { 2891 if (sdev->tagged_supported)
2892 scsi_set_tag_type(sdev, MSG_SIMPLE_TAG); 2892 scsi_adjust_queue_depth(sdev, MSG_SIMPLE_TAG,
2893 scsi_activate_tcq(sdev, sdev->queue_depth); 2893 sdev->queue_depth);
2894 } else 2894 else
2895 scsi_deactivate_tcq(sdev, sdev->queue_depth); 2895 scsi_adjust_queue_depth(sdev, 0, sdev->queue_depth);
2896 spin_unlock_irqrestore(shost->host_lock, flags); 2896 spin_unlock_irqrestore(shost->host_lock, flags);
2897 return 0; 2897 return 0;
2898} 2898}
@@ -3108,6 +3108,7 @@ static struct scsi_host_template driver_template = {
3108 .max_sectors = IBMVFC_MAX_SECTORS, 3108 .max_sectors = IBMVFC_MAX_SECTORS,
3109 .use_clustering = ENABLE_CLUSTERING, 3109 .use_clustering = ENABLE_CLUSTERING,
3110 .shost_attrs = ibmvfc_attrs, 3110 .shost_attrs = ibmvfc_attrs,
3111 .use_blk_tags = 1,
3111}; 3112};
3112 3113
3113/** 3114/**