Commit 17e01f21 authored by Mike Christie's avatar Mike Christie Committed by James Bottomley

[SCSI] add retries field to request for REQ_BLOCK_PC use

For tape we need to control the retries. This patch adds a retries
counter on the request for REQ_BLOCK_PC commands originating from
scsi_execute* to use. REQ_BLOCK_PC commands comming from the block
layer SG_IO path continue to use the retires set in the ULD init_command.
(scsi_execute* does not set the gendisk so we do not execute
the init_command in that path).
Signed-off-by: default avatarMike Christie <michaelc@cs.wisc.edu>
Signed-off-by: default avatarJames Bottomley <James.Bottomley@SteelEye.com>
parent 6e68af66
...@@ -259,6 +259,7 @@ int scsi_execute(struct scsi_device *sdev, const unsigned char *cmd, ...@@ -259,6 +259,7 @@ int scsi_execute(struct scsi_device *sdev, const unsigned char *cmd,
memcpy(req->cmd, cmd, req->cmd_len); memcpy(req->cmd, cmd, req->cmd_len);
req->sense = sense; req->sense = sense;
req->sense_len = 0; req->sense_len = 0;
req->retries = retries;
req->timeout = timeout; req->timeout = timeout;
req->flags |= flags | REQ_BLOCK_PC | REQ_SPECIAL | REQ_QUIET; req->flags |= flags | REQ_BLOCK_PC | REQ_SPECIAL | REQ_QUIET;
...@@ -472,6 +473,7 @@ int scsi_execute_async(struct scsi_device *sdev, const unsigned char *cmd, ...@@ -472,6 +473,7 @@ int scsi_execute_async(struct scsi_device *sdev, const unsigned char *cmd,
req->sense = sioc->sense; req->sense = sioc->sense;
req->sense_len = 0; req->sense_len = 0;
req->timeout = timeout; req->timeout = timeout;
req->retries = retries;
req->flags |= REQ_BLOCK_PC | REQ_QUIET; req->flags |= REQ_BLOCK_PC | REQ_QUIET;
req->end_io_data = sioc; req->end_io_data = sioc;
...@@ -1393,7 +1395,7 @@ static int scsi_prep_fn(struct request_queue *q, struct request *req) ...@@ -1393,7 +1395,7 @@ static int scsi_prep_fn(struct request_queue *q, struct request *req)
cmd->sc_data_direction = DMA_NONE; cmd->sc_data_direction = DMA_NONE;
cmd->transfersize = req->data_len; cmd->transfersize = req->data_len;
cmd->allowed = 3; cmd->allowed = req->retries;
cmd->timeout_per_command = req->timeout; cmd->timeout_per_command = req->timeout;
cmd->done = scsi_generic_done; cmd->done = scsi_generic_done;
} }
......
...@@ -184,6 +184,7 @@ struct request { ...@@ -184,6 +184,7 @@ struct request {
void *sense; void *sense;
unsigned int timeout; unsigned int timeout;
int retries;
/* /*
* For Power Management requests * For Power Management requests
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment