|
@@ -830,7 +830,7 @@ static int sd_setup_write_same_cmnd(struct scsi_device *sdp, struct request *rq)
|
|
|
|
|
|
static int scsi_setup_flush_cmnd(struct scsi_device *sdp, struct request *rq)
|
|
|
{
|
|
|
- rq->timeout = SD_FLUSH_TIMEOUT;
|
|
|
+ rq->timeout *= SD_FLUSH_TIMEOUT_MULTIPLIER;
|
|
|
rq->retries = SD_MAX_RETRIES;
|
|
|
rq->cmd[0] = SYNCHRONIZE_CACHE;
|
|
|
rq->cmd_len = 10;
|
|
@@ -1434,6 +1434,8 @@ static int sd_sync_cache(struct scsi_disk *sdkp)
|
|
|
{
|
|
|
int retries, res;
|
|
|
struct scsi_device *sdp = sdkp->device;
|
|
|
+ const int timeout = sdp->request_queue->rq_timeout
|
|
|
+ * SD_FLUSH_TIMEOUT_MULTIPLIER;
|
|
|
struct scsi_sense_hdr sshdr;
|
|
|
|
|
|
if (!scsi_device_online(sdp))
|
|
@@ -1448,8 +1450,8 @@ static int sd_sync_cache(struct scsi_disk *sdkp)
|
|
|
* flush everything.
|
|
|
*/
|
|
|
res = scsi_execute_req_flags(sdp, cmd, DMA_NONE, NULL, 0,
|
|
|
- &sshdr, SD_FLUSH_TIMEOUT,
|
|
|
- SD_MAX_RETRIES, NULL, REQ_PM);
|
|
|
+ &sshdr, timeout, SD_MAX_RETRIES,
|
|
|
+ NULL, REQ_PM);
|
|
|
if (res == 0)
|
|
|
break;
|
|
|
}
|