[SCSI] fc_transport: Check portstates before invoking target scan
When a target scan is initiated from sysfs, we should check the portstate prior to invoke scsi_scan_target(). Otherwise scsi_scan_target() might oops as the rport might already been removed from the scsi host and the traversal from the rport to the scsi_host in scsi_scan_target() will fail. Also the portstate already told us that communication with the target has failed, so it's quite pointless to try. Signed-off-by: Hannes Reinecke <hare@suse.de> Cc: James Smart <James.Smart@Emulex.Com> Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
This commit is contained in:
parent
1c13899154
commit
0d2fcd9f98
1 changed files with 3 additions and 0 deletions
|
@ -1943,6 +1943,9 @@ static int fc_user_scan(struct Scsi_Host *shost, uint channel,
|
|||
if (rport->scsi_target_id == -1)
|
||||
continue;
|
||||
|
||||
if (rport->port_state != FC_PORTSTATE_ONLINE)
|
||||
continue;
|
||||
|
||||
if ((channel == SCAN_WILD_CARD || channel == rport->channel) &&
|
||||
(id == SCAN_WILD_CARD || id == rport->scsi_target_id)) {
|
||||
scsi_scan_target(&rport->dev, rport->channel,
|
||||
|
|
Loading…
Reference in a new issue