mirror of
https://github.com/torvalds/linux.git
synced 2024-11-10 22:21:40 +00:00
bed2213d01
Since commit e9c787e65c
("scsi: allocate scsi_cmnd structures as
part of struct request") struct request and struct scsi_cmnd are
adjacent. This means that there is now an alternative to reading
req->special to convert a pointer to a prepared request into a
SCSI command pointer, namely by using blk_mq_rq_to_pdu(). Make
this change where appropriate. Although this patch does not
change any functionality, it slightly improves performance and
slightly improves readability.
Signed-off-by: Bart Van Assche <bart.vanassche@sandisk.com>
Reviewed-by: Hannes Reinecke <hare@suse.com>
Reviewed-by: Johannes Thumshirn <jthumshirn@suse.de>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
47 lines
1014 B
C
47 lines
1014 B
C
#ifndef _SCSI_SCSI_TCQ_H
|
|
#define _SCSI_SCSI_TCQ_H
|
|
|
|
#include <linux/blkdev.h>
|
|
#include <scsi/scsi_cmnd.h>
|
|
#include <scsi/scsi_device.h>
|
|
#include <scsi/scsi_host.h>
|
|
|
|
#define SCSI_NO_TAG (-1) /* identify no tag in use */
|
|
|
|
|
|
#ifdef CONFIG_BLOCK
|
|
/**
|
|
* scsi_host_find_tag - find the tagged command by host
|
|
* @shost: pointer to scsi_host
|
|
* @tag: tag
|
|
*
|
|
* Note: for devices using multiple hardware queues tag must have been
|
|
* generated by blk_mq_unique_tag().
|
|
**/
|
|
static inline struct scsi_cmnd *scsi_host_find_tag(struct Scsi_Host *shost,
|
|
int tag)
|
|
{
|
|
struct request *req = NULL;
|
|
|
|
if (tag == SCSI_NO_TAG)
|
|
return NULL;
|
|
|
|
if (shost_use_blk_mq(shost)) {
|
|
u16 hwq = blk_mq_unique_tag_to_hwq(tag);
|
|
|
|
if (hwq < shost->tag_set.nr_hw_queues) {
|
|
req = blk_mq_tag_to_rq(shost->tag_set.tags[hwq],
|
|
blk_mq_unique_tag_to_tag(tag));
|
|
}
|
|
} else {
|
|
req = blk_map_queue_find_tag(shost->bqt, tag);
|
|
}
|
|
|
|
if (!req)
|
|
return NULL;
|
|
return blk_mq_rq_to_pdu(req);
|
|
}
|
|
|
|
#endif /* CONFIG_BLOCK */
|
|
#endif /* _SCSI_SCSI_TCQ_H */
|