[SCSI] libfc: do not fc_io_compl on fsp w/o any scsi_cmnd associated
Do not call fc_io_compl() on fsp w/o any scsi_cmnd, e.g., lun reset is built inside fc_fcp, not from a scsi command from queuecommnd from scsi-ml, so in in case target is buggy that is invalid flags in the FCP_RSP, as we have seen in some SAN Blaze target where all bits in flags are 0, we do not want to call io_compl on this fsp. [ Comment block added by Robert Love ] Signed-off-by: Yi Zou <yi.zou@intel.com> Signed-off-by: Robert Love <robert.w.love@intel.com> Signed-off-by: James Bottomley <James.Bottomley@suse.de>
This commit is contained in:
parent
9b90dc80ba
commit
d889b30a91
|
@ -973,7 +973,13 @@ static void fc_fcp_complete_locked(struct fc_fcp_pkt *fsp)
|
|||
}
|
||||
lport->tt.exch_done(seq);
|
||||
}
|
||||
fc_io_compl(fsp);
|
||||
/*
|
||||
* Some resets driven by SCSI are not I/Os and do not have
|
||||
* SCSI commands associated with the requests. We should not
|
||||
* call I/O completion if we do not have a SCSI command.
|
||||
*/
|
||||
if (fsp->cmd)
|
||||
fc_io_compl(fsp);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Reference in New Issue