public inbox for linux-scsi@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH 1/1] fc class: fail fast bsg requests
@ 2009-11-05 17:18 michaelc
  2009-11-05 18:39 ` James Smart
  0 siblings, 1 reply; 4+ messages in thread
From: michaelc @ 2009-11-05 17:18 UTC (permalink / raw)
  To: linux-scsi; +Cc: Mike Christie, james.smart@emulex.com

From: Mike Christie <michaelc@cs.wisc.edu>

If the port state is blocked and the fast io fail tmo has
fired then this patch will fail bsg requests immediately.
This is needed if userspace is sending IOs to test the transport
like with fcping, so it will not have to wait for the dev loss tmo.
With this patch he bsg req fast io fail code behaves like the normal
and sg io/passthrough fast io fail.

Patch was made over scsi-rc-fixes. It is only compiled tested.
I found this while looking over the iscsi bsg patch.

Signed-off-by: Mike Christie <michaelc@cs.wisc.edu>
Cc: james.smart@emulex.com <james.smart@emulex.com>
---
 drivers/scsi/scsi_transport_fc.c |    5 +++--
 1 files changed, 3 insertions(+), 2 deletions(-)

diff --git a/drivers/scsi/scsi_transport_fc.c b/drivers/scsi/scsi_transport_fc.c
index c6f70da..1004684 100644
--- a/drivers/scsi/scsi_transport_fc.c
+++ b/drivers/scsi/scsi_transport_fc.c
@@ -3769,8 +3769,9 @@ fc_bsg_request_handler(struct request_queue *q, struct Scsi_Host *shost,
 		return;
 
 	while (!blk_queue_plugged(q)) {
-		if (rport && (rport->port_state == FC_PORTSTATE_BLOCKED))
-				break;
+		if (rport && (rport->port_state == FC_PORTSTATE_BLOCKED) &&
+		    !(rport->flags & FC_RPORT_FAST_FAIL_TIMEDOUT))
+			break;
 
 		req = blk_fetch_request(q);
 		if (!req)
-- 
1.6.0.6


^ permalink raw reply related	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2009-11-05 19:02 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-11-05 17:18 [PATCH 1/1] fc class: fail fast bsg requests michaelc
2009-11-05 18:39 ` James Smart
2009-11-05 18:55   ` Mike Christie
2009-11-05 19:02     ` James Smart

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox