aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/scsi/libfc/fc_lport.c36
-rw-r--r--include/scsi/libfc.h2
2 files changed, 37 insertions, 1 deletions
diff --git a/drivers/scsi/libfc/fc_lport.c b/drivers/scsi/libfc/fc_lport.c
index 79c9e3ccd341..f7bff2cad4ee 100644
--- a/drivers/scsi/libfc/fc_lport.c
+++ b/drivers/scsi/libfc/fc_lport.c
@@ -755,6 +755,34 @@ static void fc_lport_set_port_id(struct fc_lport *lport, u32 port_id,
755} 755}
756 756
757/** 757/**
758 * fc_lport_set_port_id() - set the local port Port ID for point-to-multipoint
759 * @lport: The local port which will have its Port ID set.
760 * @port_id: The new port ID.
761 *
762 * Called by the lower-level driver when transport sets the local port_id.
763 * This is used in VN_port to VN_port mode for FCoE, and causes FLOGI and
764 * discovery to be skipped.
765 */
766void fc_lport_set_local_id(struct fc_lport *lport, u32 port_id)
767{
768 mutex_lock(&lport->lp_mutex);
769
770 fc_lport_set_port_id(lport, port_id, NULL);
771
772 switch (lport->state) {
773 case LPORT_ST_RESET:
774 case LPORT_ST_FLOGI:
775 if (port_id)
776 fc_lport_enter_ready(lport);
777 break;
778 default:
779 break;
780 }
781 mutex_unlock(&lport->lp_mutex);
782}
783EXPORT_SYMBOL(fc_lport_set_local_id);
784
785/**
758 * fc_lport_recv_flogi_req() - Receive a FLOGI request 786 * fc_lport_recv_flogi_req() - Receive a FLOGI request
759 * @sp_in: The sequence the FLOGI is on 787 * @sp_in: The sequence the FLOGI is on
760 * @rx_fp: The FLOGI frame 788 * @rx_fp: The FLOGI frame
@@ -954,7 +982,7 @@ static void fc_lport_reset_locked(struct fc_lport *lport)
954 lport->tt.exch_mgr_reset(lport, 0, 0); 982 lport->tt.exch_mgr_reset(lport, 0, 0);
955 fc_host_fabric_name(lport->host) = 0; 983 fc_host_fabric_name(lport->host) = 0;
956 984
957 if (lport->port_id) 985 if (lport->port_id && (!lport->point_to_multipoint || !lport->link_up))
958 fc_lport_set_port_id(lport, 0, NULL); 986 fc_lport_set_port_id(lport, 0, NULL);
959} 987}
960 988
@@ -1536,6 +1564,12 @@ void fc_lport_enter_flogi(struct fc_lport *lport)
1536 1564
1537 fc_lport_state_enter(lport, LPORT_ST_FLOGI); 1565 fc_lport_state_enter(lport, LPORT_ST_FLOGI);
1538 1566
1567 if (lport->point_to_multipoint) {
1568 if (lport->port_id)
1569 fc_lport_enter_ready(lport);
1570 return;
1571 }
1572
1539 fp = fc_frame_alloc(lport, sizeof(struct fc_els_flogi)); 1573 fp = fc_frame_alloc(lport, sizeof(struct fc_els_flogi));
1540 if (!fp) 1574 if (!fp)
1541 return fc_lport_error(lport, fp); 1575 return fc_lport_error(lport, fp);
diff --git a/include/scsi/libfc.h b/include/scsi/libfc.h
index 5f64e593cca8..bd0560509ce6 100644
--- a/include/scsi/libfc.h
+++ b/include/scsi/libfc.h
@@ -846,6 +846,7 @@ struct fc_lport {
846 u32 lro_enabled:1; 846 u32 lro_enabled:1;
847 u32 does_npiv:1; 847 u32 does_npiv:1;
848 u32 npiv_enabled:1; 848 u32 npiv_enabled:1;
849 u32 point_to_multipoint:1;
849 u32 mfs; 850 u32 mfs;
850 u8 max_retry_count; 851 u8 max_retry_count;
851 u8 max_rport_retry_count; 852 u8 max_rport_retry_count;
@@ -991,6 +992,7 @@ int fc_set_mfs(struct fc_lport *, u32 mfs);
991struct fc_lport *libfc_vport_create(struct fc_vport *, int privsize); 992struct fc_lport *libfc_vport_create(struct fc_vport *, int privsize);
992struct fc_lport *fc_vport_id_lookup(struct fc_lport *, u32 port_id); 993struct fc_lport *fc_vport_id_lookup(struct fc_lport *, u32 port_id);
993int fc_lport_bsg_request(struct fc_bsg_job *); 994int fc_lport_bsg_request(struct fc_bsg_job *);
995void fc_lport_set_local_id(struct fc_lport *, u32 port_id);
994 996
995/* 997/*
996 * REMOTE PORT LAYER 998 * REMOTE PORT LAYER