提交 67b46525 编写于 作者: S Steffen Maier 提交者: Martin K. Petersen

scsi: fc: start decoupling fc_block_scsi_eh from scsi_cmnd

Scsi_cmnd is an unsuitable argument for eh_device_reset_handler(),
eh_target_reset_handler(), and eh_host_reset_handler() which do not have
the scope of one single SCSI command.  These callbacks tend to use
fc_block_scsi_eh() requiring scsi_cmnd.  In order to start decoupling
above eh callbacks from scsi_cmnd, introduce a new variant of the
function called fc_block_rport() taking an fc_rport as argument.
Refactor the old fc_block_scsi_eh() to simply delegate to
fc_block_rport().
Signed-off-by: NSteffen Maier <maier@linux.vnet.ibm.com>
Reviewed-by: NHannes Reinecke <hare@suse.com>
Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
上级 49b3d5f6
...@@ -3276,8 +3276,8 @@ fc_scsi_scan_rport(struct work_struct *work) ...@@ -3276,8 +3276,8 @@ fc_scsi_scan_rport(struct work_struct *work)
} }
/** /**
* fc_block_scsi_eh - Block SCSI eh thread for blocked fc_rport * fc_block_rport() - Block SCSI eh thread for blocked fc_rport.
* @cmnd: SCSI command that scsi_eh is trying to recover * @rport: Remote port that scsi_eh is trying to recover.
* *
* This routine can be called from a FC LLD scsi_eh callback. It * This routine can be called from a FC LLD scsi_eh callback. It
* blocks the scsi_eh thread until the fc_rport leaves the * blocks the scsi_eh thread until the fc_rport leaves the
...@@ -3289,10 +3289,9 @@ fc_scsi_scan_rport(struct work_struct *work) ...@@ -3289,10 +3289,9 @@ fc_scsi_scan_rport(struct work_struct *work)
* FAST_IO_FAIL if the fast_io_fail_tmo fired, this should be * FAST_IO_FAIL if the fast_io_fail_tmo fired, this should be
* passed back to scsi_eh. * passed back to scsi_eh.
*/ */
int fc_block_scsi_eh(struct scsi_cmnd *cmnd) int fc_block_rport(struct fc_rport *rport)
{ {
struct Scsi_Host *shost = cmnd->device->host; struct Scsi_Host *shost = rport_to_shost(rport);
struct fc_rport *rport = starget_to_rport(scsi_target(cmnd->device));
unsigned long flags; unsigned long flags;
spin_lock_irqsave(shost->host_lock, flags); spin_lock_irqsave(shost->host_lock, flags);
...@@ -3309,6 +3308,28 @@ int fc_block_scsi_eh(struct scsi_cmnd *cmnd) ...@@ -3309,6 +3308,28 @@ int fc_block_scsi_eh(struct scsi_cmnd *cmnd)
return 0; return 0;
} }
EXPORT_SYMBOL(fc_block_rport);
/**
* fc_block_scsi_eh - Block SCSI eh thread for blocked fc_rport
* @cmnd: SCSI command that scsi_eh is trying to recover
*
* This routine can be called from a FC LLD scsi_eh callback. It
* blocks the scsi_eh thread until the fc_rport leaves the
* FC_PORTSTATE_BLOCKED, or the fast_io_fail_tmo fires. This is
* necessary to avoid the scsi_eh failing recovery actions for blocked
* rports which would lead to offlined SCSI devices.
*
* Returns: 0 if the fc_rport left the state FC_PORTSTATE_BLOCKED.
* FAST_IO_FAIL if the fast_io_fail_tmo fired, this should be
* passed back to scsi_eh.
*/
int fc_block_scsi_eh(struct scsi_cmnd *cmnd)
{
struct fc_rport *rport = starget_to_rport(scsi_target(cmnd->device));
return fc_block_rport(rport);
}
EXPORT_SYMBOL(fc_block_scsi_eh); EXPORT_SYMBOL(fc_block_scsi_eh);
/** /**
......
...@@ -804,6 +804,7 @@ void fc_host_post_vendor_event(struct Scsi_Host *shost, u32 event_number, ...@@ -804,6 +804,7 @@ void fc_host_post_vendor_event(struct Scsi_Host *shost, u32 event_number,
struct fc_vport *fc_vport_create(struct Scsi_Host *shost, int channel, struct fc_vport *fc_vport_create(struct Scsi_Host *shost, int channel,
struct fc_vport_identifiers *); struct fc_vport_identifiers *);
int fc_vport_terminate(struct fc_vport *vport); int fc_vport_terminate(struct fc_vport *vport);
int fc_block_rport(struct fc_rport *rport);
int fc_block_scsi_eh(struct scsi_cmnd *cmnd); int fc_block_scsi_eh(struct scsi_cmnd *cmnd);
enum blk_eh_timer_return fc_eh_timed_out(struct scsi_cmnd *scmd); enum blk_eh_timer_return fc_eh_timed_out(struct scsi_cmnd *scmd);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册