lport->tt.lport_set_port_id(lport, port_id, fp);
 }
 
+/**
+ * fc_lport_set_port_id() - set the local port Port ID for point-to-multipoint
+ * @lport: The local port which will have its Port ID set.
+ * @port_id: The new port ID.
+ *
+ * Called by the lower-level driver when transport sets the local port_id.
+ * This is used in VN_port to VN_port mode for FCoE, and causes FLOGI and
+ * discovery to be skipped.
+ */
+void fc_lport_set_local_id(struct fc_lport *lport, u32 port_id)
+{
+       mutex_lock(&lport->lp_mutex);
+
+       fc_lport_set_port_id(lport, port_id, NULL);
+
+       switch (lport->state) {
+       case LPORT_ST_RESET:
+       case LPORT_ST_FLOGI:
+               if (port_id)
+                       fc_lport_enter_ready(lport);
+               break;
+       default:
+               break;
+       }
+       mutex_unlock(&lport->lp_mutex);
+}
+EXPORT_SYMBOL(fc_lport_set_local_id);
+
 /**
  * fc_lport_recv_flogi_req() - Receive a FLOGI request
  * @sp_in: The sequence the FLOGI is on
        lport->tt.exch_mgr_reset(lport, 0, 0);
        fc_host_fabric_name(lport->host) = 0;
 
-       if (lport->port_id)
+       if (lport->port_id && (!lport->point_to_multipoint || !lport->link_up))
                fc_lport_set_port_id(lport, 0, NULL);
 }
 
 
        fc_lport_state_enter(lport, LPORT_ST_FLOGI);
 
+       if (lport->point_to_multipoint) {
+               if (lport->port_id)
+                       fc_lport_enter_ready(lport);
+               return;
+       }
+
        fp = fc_frame_alloc(lport, sizeof(struct fc_els_flogi));
        if (!fp)
                return fc_lport_error(lport, fp);
 
        u32                            lro_enabled:1;
        u32                            does_npiv:1;
        u32                            npiv_enabled:1;
+       u32                            point_to_multipoint:1;
        u32                            mfs;
        u8                             max_retry_count;
        u8                             max_rport_retry_count;
 struct fc_lport *libfc_vport_create(struct fc_vport *, int privsize);
 struct fc_lport *fc_vport_id_lookup(struct fc_lport *, u32 port_id);
 int fc_lport_bsg_request(struct fc_bsg_job *);
+void fc_lport_set_local_id(struct fc_lport *, u32 port_id);
 
 /*
  * REMOTE PORT LAYER