mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	[SCSI] zfcp: Block scsi_eh thread for rport state BLOCKED
In case the SCSI error recovery starts because of a SCSI command timeout, but then something else triggers the rport to be deleted, the SCSI error recovery will run to the end and set the SCSI device offline. To prevent this, call the FC transport function fc_block_scsi_eh which waits until the rport leaves the BLOCKED state. This guarantees that communication is possible if the rport is ONLINE, or the SCSI devices will be removed if the rport state switches to NOT_PRESENT. Reviewed-by: Swen Schillig <swen@vnet.ibm.com> Signed-off-by: Christof Schmitt <christof.schmitt@de.ibm.com> Signed-off-by: James Bottomley <James.Bottomley@suse.de>
This commit is contained in:
		
							parent
							
								
									4c571c659e
								
							
						
					
					
						commit
						af4de36d91
					
				| @ -209,6 +209,7 @@ static int zfcp_scsi_eh_abort_handler(struct scsi_cmnd *scpnt) | |||||||
| 			break; | 			break; | ||||||
| 
 | 
 | ||||||
| 		zfcp_erp_wait(adapter); | 		zfcp_erp_wait(adapter); | ||||||
|  | 		fc_block_scsi_eh(scpnt); | ||||||
| 		if (!(atomic_read(&adapter->status) & | 		if (!(atomic_read(&adapter->status) & | ||||||
| 		      ZFCP_STATUS_COMMON_RUNNING)) { | 		      ZFCP_STATUS_COMMON_RUNNING)) { | ||||||
| 			zfcp_dbf_scsi_abort("nres", adapter->dbf, scpnt, NULL, | 			zfcp_dbf_scsi_abort("nres", adapter->dbf, scpnt, NULL, | ||||||
| @ -248,6 +249,7 @@ static int zfcp_task_mgmt_function(struct scsi_cmnd *scpnt, u8 tm_flags) | |||||||
| 			break; | 			break; | ||||||
| 
 | 
 | ||||||
| 		zfcp_erp_wait(adapter); | 		zfcp_erp_wait(adapter); | ||||||
|  | 		fc_block_scsi_eh(scpnt); | ||||||
| 		if (!(atomic_read(&adapter->status) & | 		if (!(atomic_read(&adapter->status) & | ||||||
| 		      ZFCP_STATUS_COMMON_RUNNING)) { | 		      ZFCP_STATUS_COMMON_RUNNING)) { | ||||||
| 			zfcp_dbf_scsi_devreset("nres", tm_flags, unit, scpnt); | 			zfcp_dbf_scsi_devreset("nres", tm_flags, unit, scpnt); | ||||||
| @ -289,6 +291,7 @@ static int zfcp_scsi_eh_host_reset_handler(struct scsi_cmnd *scpnt) | |||||||
| 
 | 
 | ||||||
| 	zfcp_erp_adapter_reopen(adapter, 0, "schrh_1", scpnt); | 	zfcp_erp_adapter_reopen(adapter, 0, "schrh_1", scpnt); | ||||||
| 	zfcp_erp_wait(adapter); | 	zfcp_erp_wait(adapter); | ||||||
|  | 	fc_block_scsi_eh(scpnt); | ||||||
| 
 | 
 | ||||||
| 	return SUCCESS; | 	return SUCCESS; | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Christof Schmitt
						Christof Schmitt