aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/scsi/device_handler/scsi_dh_rdac.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/drivers/scsi/device_handler/scsi_dh_rdac.c b/drivers/scsi/device_handler/scsi_dh_rdac.c
index ff07559c5fcd..3e16a33927cf 100644
--- a/drivers/scsi/device_handler/scsi_dh_rdac.c
+++ b/drivers/scsi/device_handler/scsi_dh_rdac.c
@@ -24,6 +24,7 @@
24#include <scsi/scsi_dh.h> 24#include <scsi/scsi_dh.h>
25 25
26#define RDAC_NAME "rdac" 26#define RDAC_NAME "rdac"
27#define RDAC_RETRY_COUNT 5
27 28
28/* 29/*
29 * LSI mode page stuff 30 * LSI mode page stuff
@@ -478,21 +479,27 @@ static int send_mode_select(struct scsi_device *sdev, struct rdac_dh_data *h)
478{ 479{
479 struct request *rq; 480 struct request *rq;
480 struct request_queue *q = sdev->request_queue; 481 struct request_queue *q = sdev->request_queue;
481 int err = SCSI_DH_RES_TEMP_UNAVAIL; 482 int err, retry_cnt = RDAC_RETRY_COUNT;
482 483
484retry:
485 err = SCSI_DH_RES_TEMP_UNAVAIL;
483 rq = rdac_failover_get(sdev, h); 486 rq = rdac_failover_get(sdev, h);
484 if (!rq) 487 if (!rq)
485 goto done; 488 goto done;
486 489
487 sdev_printk(KERN_INFO, sdev, "queueing MODE_SELECT command.\n"); 490 sdev_printk(KERN_INFO, sdev, "%s MODE_SELECT command.\n",
491 (retry_cnt == RDAC_RETRY_COUNT) ? "queueing" : "retrying");
488 492
489 err = blk_execute_rq(q, NULL, rq, 1); 493 err = blk_execute_rq(q, NULL, rq, 1);
490 if (err != SCSI_DH_OK) 494 blk_put_request(rq);
495 if (err != SCSI_DH_OK) {
491 err = mode_select_handle_sense(sdev, h->sense); 496 err = mode_select_handle_sense(sdev, h->sense);
497 if (err == SCSI_DH_RETRY && retry_cnt--)
498 goto retry;
499 }
492 if (err == SCSI_DH_OK) 500 if (err == SCSI_DH_OK)
493 h->state = RDAC_STATE_ACTIVE; 501 h->state = RDAC_STATE_ACTIVE;
494 502
495 blk_put_request(rq);
496done: 503done:
497 return err; 504 return err;
498} 505}