[SCSI] libfc: clean up point-to-point discovery code.
authorJoe Eykholt <jeykholt@cisco.com>
Tue, 25 Aug 2009 21:02:49 +0000 (14:02 -0700)
committerJames Bottomley <James.Bottomley@suse.de>
Thu, 10 Sep 2009 17:07:53 +0000 (12:07 -0500)
The discovery code had a special-case for the point-to-point mode,
which used a bunch of code that wasn't really needed.

Now that rport_create adds the rport to the discovery list,
completely skip discovery for the point-to-point case.

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>
drivers/scsi/libfc/fc_disc.c
drivers/scsi/libfc/fc_lport.c

index a2410dc744414bd4a83f6445e28f693e1ca0a166..428421842f3ab2b261c6aaf7a54a564996908fad 100644 (file)
@@ -45,8 +45,6 @@
 
 static void fc_disc_gpn_ft_req(struct fc_disc *);
 static void fc_disc_gpn_ft_resp(struct fc_seq *, struct fc_frame *, void *);
-static int fc_disc_new_target(struct fc_disc *, struct fc_rport_priv *,
-                             struct fc_rport_identifiers *);
 static void fc_disc_done(struct fc_disc *, enum fc_disc_event);
 static void fc_disc_timeout(struct work_struct *);
 static void fc_disc_single(struct fc_disc *, struct fc_disc_port *);
@@ -240,14 +238,12 @@ static void fc_disc_restart(struct fc_disc *disc)
 /**
  * fc_disc_start() - Fibre Channel Target discovery
  * @lport: FC local port
- *
- * Returns non-zero if discovery cannot be started.
+ * @disc_callback: function to be called when discovery is complete
  */
 static void fc_disc_start(void (*disc_callback)(struct fc_lport *,
                                                enum fc_disc_event),
                          struct fc_lport *lport)
 {
-       struct fc_rport_priv *rdata;
        struct fc_disc *disc = &lport->disc;
 
        /*
@@ -256,87 +252,11 @@ static void fc_disc_start(void (*disc_callback)(struct fc_lport *,
         * and send the GPN_FT request.
         */
        mutex_lock(&disc->disc_mutex);
-
        disc->disc_callback = disc_callback;
-
-       /*
-        * If not ready, or already running discovery, just set request flag.
-        */
-       disc->requested = 1;
-
-       if (disc->pending) {
-               mutex_unlock(&disc->disc_mutex);
-               return;
-       }
-
-       /*
-        * Handle point-to-point mode as a simple discovery
-        * of the remote port. Yucky, yucky, yuck, yuck!
-        */
-       rdata = disc->lport->ptp_rp;
-       if (rdata) {
-               kref_get(&rdata->kref);
-               if (!fc_disc_new_target(disc, rdata, &rdata->ids)) {
-                       fc_disc_done(disc, DISC_EV_SUCCESS);
-               }
-               kref_put(&rdata->kref, rdata->local_port->tt.rport_destroy);
-       } else {
-               disc->disc_id = (disc->disc_id + 2) | 1;
-               fc_disc_gpn_ft_req(disc);       /* get ports by FC-4 type */
-       }
-
+       fc_disc_restart(disc);
        mutex_unlock(&disc->disc_mutex);
 }
 
-/**
- * fc_disc_new_target() - Handle new target found by discovery
- * @lport: FC local port
- * @rdata: The previous FC remote port priv (NULL if new remote port)
- * @ids: Identifiers for the new FC remote port
- *
- * Locking Note: This function expects that the disc_mutex is locked
- *              before it is called.
- */
-static int fc_disc_new_target(struct fc_disc *disc,
-                             struct fc_rport_priv *rdata,
-                             struct fc_rport_identifiers *ids)
-{
-       struct fc_lport *lport = disc->lport;
-       int error = 0;
-
-       if (rdata && ids->port_name) {
-               if (rdata->ids.port_name == -1) {
-                       /*
-                        * Set WWN and fall through to notify of create.
-                        */
-                       rdata->ids.port_name = ids->port_name;
-                       rdata->ids.node_name = ids->node_name;
-               } else if (rdata->ids.port_name != ids->port_name) {
-                       /*
-                        * This is a new port with the same FCID as
-                        * a previously-discovered port.  Presumably the old
-                        * port logged out and a new port logged in and was
-                        * assigned the same FCID.  This should be rare.
-                        * Delete the old one and fall thru to re-create.
-                        */
-                       lport->tt.rport_logoff(rdata);
-                       rdata = NULL;
-               }
-       }
-       if (((ids->port_name != -1) || (ids->port_id != -1)) &&
-           ids->port_id != fc_host_port_id(lport->host) &&
-           ids->port_name != lport->wwpn) {
-               if (!rdata) {
-                       rdata = lport->tt.rport_create(lport, ids);
-                       if (!rdata)
-                               error = -ENOMEM;
-               }
-               if (rdata)
-                       lport->tt.rport_login(rdata);
-       }
-       return error;
-}
-
 /**
  * fc_disc_done() - Discovery has been completed
  * @disc: FC discovery context
index f33e5732e3fc2f3c5f74a18c7c08da4abeac14e1..7000df5736913fb4c16e1a9619a0244fff716b2c 100644 (file)
@@ -708,7 +708,8 @@ static void fc_lport_enter_ready(struct fc_lport *lport)
 
        fc_lport_state_enter(lport, LPORT_ST_READY);
 
-       lport->tt.disc_start(fc_lport_disc_callback, lport);
+       if (!lport->ptp_rp)
+               lport->tt.disc_start(fc_lport_disc_callback, lport);
 }
 
 /**
@@ -794,8 +795,6 @@ static void fc_lport_recv_flogi_req(struct fc_seq *sp_in,
        fc_lport_ptp_setup(lport, remote_fid, remote_wwpn,
                           get_unaligned_be64(&flp->fl_wwnn));
 
-       lport->tt.disc_start(fc_lport_disc_callback, lport);
-
 out:
        sp = fr_seq(rx_fp);
        fc_frame_free(rx_fp);
@@ -1512,14 +1511,6 @@ static void fc_lport_flogi_resp(struct fc_seq *sp, struct fc_frame *fp,
                                fc_lport_enter_dns(lport);
                        }
                }
-
-               if (flp) {
-                       csp_flags = ntohs(flp->fl_csp.sp_features);
-                       if ((csp_flags & FC_SP_FT_FPORT) == 0) {
-                               lport->tt.disc_start(fc_lport_disc_callback,
-                                                    lport);
-                       }
-               }
        } else {
                FC_LPORT_DBG(lport, "Bad FLOGI response\n");
        }