diff options
author | Joe Eykholt <jeykholt@cisco.com> | 2009-08-25 17:03:58 -0400 |
---|---|---|
committer | James Bottomley <James.Bottomley@suse.de> | 2009-09-10 13:08:03 -0400 |
commit | 2ab7e1ecb81ce35ed8e8df512e3fc6338a4c55bb (patch) | |
tree | cc4fea4717a66e7d1428505bb409146d37e52668 /drivers/scsi/libfc/fc_elsct.c | |
parent | 8abbe3a42324264c9d5cc4e7c3d265b5be6d82d6 (diff) |
[SCSI] libfc: send GPN_ID in reaction to single-port RSCNs.
When an RSCN indicates changes to individual remote ports,
don't blindly log them out and then back in. Instead, determine
whether they're still in the directory, by doing GPN_ID.
If that is successful, call login, which will send ADISC and reverify,
otherwise, call logoff. Perhaps we should just delete the rport,
not send LOGO, but it seems safer.
Also, fix a possible issue where if a mix of records in the RSCN
cause us to queue disc_ports for disc_single and then we decide
to do full rediscovery, we leak memory for those disc_ports queued.
So, go through the list of disc_ports even if doing full discovery.
Free the disc_ports in any case. If any of the disc_single() calls
return error, do a full discovery.
The ability to fill in GPN_ID requests was added to fc_ct_fill().
For this, it needs the FC_ID to be passed in as an arg.
The did parameter for fc_elsct_send() is used for that, since the
actual D_DID will always be 0xfffffc for all CT requests so far.
Signed-off-by: Joe Eykholt <jeykholt@cisco.com>
Signed-off-by: Robert Love <robert.w.love@intel.com>
Signed-off-by: James Bottomley <James.Bottomley@suse.de>
Diffstat (limited to 'drivers/scsi/libfc/fc_elsct.c')
-rw-r--r-- | drivers/scsi/libfc/fc_elsct.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/scsi/libfc/fc_elsct.c b/drivers/scsi/libfc/fc_elsct.c index d655924d46b6..5cfa68732e9d 100644 --- a/drivers/scsi/libfc/fc_elsct.c +++ b/drivers/scsi/libfc/fc_elsct.c | |||
@@ -49,7 +49,7 @@ static struct fc_seq *fc_elsct_send(struct fc_lport *lport, | |||
49 | rc = fc_els_fill(lport, did, fp, op, &r_ctl, &fh_type); | 49 | rc = fc_els_fill(lport, did, fp, op, &r_ctl, &fh_type); |
50 | else { | 50 | else { |
51 | /* CT requests */ | 51 | /* CT requests */ |
52 | rc = fc_ct_fill(lport, fp, op, &r_ctl, &fh_type); | 52 | rc = fc_ct_fill(lport, did, fp, op, &r_ctl, &fh_type); |
53 | did = FC_FID_DIR_SERV; | 53 | did = FC_FID_DIR_SERV; |
54 | } | 54 | } |
55 | 55 | ||