aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorKrishna Gudipati <kgudipat@brocade.com>2010-03-03 20:44:02 -0500
committerJames Bottomley <James.Bottomley@suse.de>2010-03-04 05:47:02 -0500
commite67143243a1a6b47e1bdcda189ffac46d2a8744d (patch)
tree03a14641d29ec2d93eedcc921af7200c62f2e723 /drivers
parenta046bf0559018ba3d16c412fc4e1aa2be5f11f36 (diff)
[SCSI] bfa: Resume BFA operations after firmware mismatch is resolved.
bfad.c & bfad_drv.h: * Created a kernel thread from pci_probe that does the bfad start operations after BFA init done on a firmware mismatch. * The kernel thread on a fw mismatch waits for an event from IOC call back and is woken up from bfa_cb_init() on BFA init success. * In normal cases of no firmware mismatch this thread is terminated in pci_probe. bfa_fcs_lport.c, fabric.c, fcs_lport.h & vport.c: * Split the lport init to attach time and init time code, so that proper config attributes are set after firmware mismatch. bfa_iocfc.c: * Handle an IOC timer issue, where the IOC timer would expire before the init completion and send Init fail event to the driver, however IOC init continues and completes successfully at the later stage. The bfa and driver were not handling this kind of deferred init completion. Signed-off-by: Krishna Gudipati <kgudipat@brocade.com> Signed-off-by: James Bottomley <James.Bottomley@suse.de>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/scsi/bfa/bfa_fcs_lport.c30
-rw-r--r--drivers/scsi/bfa/bfa_iocfc.c6
-rw-r--r--drivers/scsi/bfa/bfad.c189
-rw-r--r--drivers/scsi/bfa/bfad_drv.h12
-rw-r--r--drivers/scsi/bfa/fabric.c4
-rw-r--r--drivers/scsi/bfa/fcs_lport.h7
-rw-r--r--drivers/scsi/bfa/vport.c3
7 files changed, 192 insertions, 59 deletions
diff --git a/drivers/scsi/bfa/bfa_fcs_lport.c b/drivers/scsi/bfa/bfa_fcs_lport.c
index c7ab257f10a7..3d62e456950b 100644
--- a/drivers/scsi/bfa/bfa_fcs_lport.c
+++ b/drivers/scsi/bfa/bfa_fcs_lport.c
@@ -873,36 +873,46 @@ bfa_fcs_port_is_online(struct bfa_fcs_port_s *port)
873} 873}
874 874
875/** 875/**
876 * Logical port initialization of base or virtual port. 876 * Attach time initialization of logical ports.
877 * Called by fabric for base port or by vport for virtual ports.
878 */ 877 */
879void 878void
880bfa_fcs_lport_init(struct bfa_fcs_port_s *lport, struct bfa_fcs_s *fcs, 879bfa_fcs_lport_attach(struct bfa_fcs_port_s *lport, struct bfa_fcs_s *fcs,
881 u16 vf_id, struct bfa_port_cfg_s *port_cfg, 880 uint16_t vf_id, struct bfa_fcs_vport_s *vport)
882 struct bfa_fcs_vport_s *vport)
883{ 881{
884 lport->fcs = fcs; 882 lport->fcs = fcs;
885 lport->fabric = bfa_fcs_vf_lookup(fcs, vf_id); 883 lport->fabric = bfa_fcs_vf_lookup(fcs, vf_id);
886 bfa_os_assign(lport->port_cfg, *port_cfg);
887 lport->vport = vport; 884 lport->vport = vport;
888 lport->lp_tag = (vport) ? bfa_lps_get_tag(vport->lps) : 885 lport->lp_tag = (vport) ? bfa_lps_get_tag(vport->lps) :
889 bfa_lps_get_tag(lport->fabric->lps); 886 bfa_lps_get_tag(lport->fabric->lps);
890 887
891 INIT_LIST_HEAD(&lport->rport_q); 888 INIT_LIST_HEAD(&lport->rport_q);
892 lport->num_rports = 0; 889 lport->num_rports = 0;
890}
891
892/**
893 * Logical port initialization of base or virtual port.
894 * Called by fabric for base port or by vport for virtual ports.
895 */
893 896
894 lport->bfad_port = 897void
895 bfa_fcb_port_new(fcs->bfad, lport, lport->port_cfg.roles, 898bfa_fcs_lport_init(struct bfa_fcs_port_s *lport,
899 struct bfa_port_cfg_s *port_cfg)
900{
901 struct bfa_fcs_vport_s *vport = lport->vport;
902
903 bfa_os_assign(lport->port_cfg, *port_cfg);
904
905 lport->bfad_port = bfa_fcb_port_new(lport->fcs->bfad, lport,
906 lport->port_cfg.roles,
896 lport->fabric->vf_drv, 907 lport->fabric->vf_drv,
897 vport ? vport->vport_drv : NULL); 908 vport ? vport->vport_drv : NULL);
909
898 bfa_fcs_port_aen_post(lport, BFA_LPORT_AEN_NEW); 910 bfa_fcs_port_aen_post(lport, BFA_LPORT_AEN_NEW);
899 911
900 bfa_sm_set_state(lport, bfa_fcs_port_sm_uninit); 912 bfa_sm_set_state(lport, bfa_fcs_port_sm_uninit);
901 bfa_sm_send_event(lport, BFA_FCS_PORT_SM_CREATE); 913 bfa_sm_send_event(lport, BFA_FCS_PORT_SM_CREATE);
902} 914}
903 915
904
905
906/** 916/**
907 * fcs_lport_api 917 * fcs_lport_api
908 */ 918 */
diff --git a/drivers/scsi/bfa/bfa_iocfc.c b/drivers/scsi/bfa/bfa_iocfc.c
index b5e7224bda4a..137591c984d7 100644
--- a/drivers/scsi/bfa/bfa_iocfc.c
+++ b/drivers/scsi/bfa/bfa_iocfc.c
@@ -336,8 +336,10 @@ bfa_iocfc_init_cb(void *bfa_arg, bfa_boolean_t complete)
336 bfa_cb_init(bfa->bfad, BFA_STATUS_OK); 336 bfa_cb_init(bfa->bfad, BFA_STATUS_OK);
337 else 337 else
338 bfa_cb_init(bfa->bfad, BFA_STATUS_FAILED); 338 bfa_cb_init(bfa->bfad, BFA_STATUS_FAILED);
339 } else 339 } else {
340 bfa->iocfc.action = BFA_IOCFC_ACT_NONE; 340 if (bfa->iocfc.cfgdone)
341 bfa->iocfc.action = BFA_IOCFC_ACT_NONE;
342 }
341} 343}
342 344
343static void 345static void
diff --git a/drivers/scsi/bfa/bfad.c b/drivers/scsi/bfa/bfad.c
index 965dfb575e5a..4ccaeaecd14c 100644
--- a/drivers/scsi/bfa/bfad.c
+++ b/drivers/scsi/bfa/bfad.c
@@ -20,6 +20,7 @@
20 */ 20 */
21 21
22#include <linux/module.h> 22#include <linux/module.h>
23#include <linux/kthread.h>
23#include "bfad_drv.h" 24#include "bfad_drv.h"
24#include "bfad_im.h" 25#include "bfad_im.h"
25#include "bfad_tm.h" 26#include "bfad_tm.h"
@@ -97,6 +98,8 @@ bfad_fc4_probe(struct bfad_s *bfad)
97 98
98 if (ipfc_enable) 99 if (ipfc_enable)
99 bfad_ipfc_probe(bfad); 100 bfad_ipfc_probe(bfad);
101
102 bfad->bfad_flags |= BFAD_FC4_PROBE_DONE;
100ext: 103ext:
101 return rc; 104 return rc;
102} 105}
@@ -108,6 +111,7 @@ bfad_fc4_probe_undo(struct bfad_s *bfad)
108 bfad_tm_probe_undo(bfad); 111 bfad_tm_probe_undo(bfad);
109 if (ipfc_enable) 112 if (ipfc_enable)
110 bfad_ipfc_probe_undo(bfad); 113 bfad_ipfc_probe_undo(bfad);
114 bfad->bfad_flags &= ~BFAD_FC4_PROBE_DONE;
111} 115}
112 116
113static void 117static void
@@ -175,9 +179,19 @@ bfa_cb_init(void *drv, bfa_status_t init_status)
175{ 179{
176 struct bfad_s *bfad = drv; 180 struct bfad_s *bfad = drv;
177 181
178 if (init_status == BFA_STATUS_OK) 182 if (init_status == BFA_STATUS_OK) {
179 bfad->bfad_flags |= BFAD_HAL_INIT_DONE; 183 bfad->bfad_flags |= BFAD_HAL_INIT_DONE;
180 184
185 /* If BFAD_HAL_INIT_FAIL flag is set:
186 * Wake up the kernel thread to start
187 * the bfad operations after HAL init done
188 */
189 if ((bfad->bfad_flags & BFAD_HAL_INIT_FAIL)) {
190 bfad->bfad_flags &= ~BFAD_HAL_INIT_FAIL;
191 wake_up_process(bfad->bfad_tsk);
192 }
193 }
194
181 complete(&bfad->comp); 195 complete(&bfad->comp);
182} 196}
183 197
@@ -749,7 +763,13 @@ bfad_drv_init(struct bfad_s *bfad)
749 bfa_fcs_trc_init(&bfad->bfa_fcs, bfad->trcmod); 763 bfa_fcs_trc_init(&bfad->bfa_fcs, bfad->trcmod);
750 bfa_fcs_aen_init(&bfad->bfa_fcs, bfad->aen); 764 bfa_fcs_aen_init(&bfad->bfa_fcs, bfad->aen);
751 bfa_fcs_attach(&bfad->bfa_fcs, &bfad->bfa, bfad, BFA_FALSE); 765 bfa_fcs_attach(&bfad->bfa_fcs, &bfad->bfa, bfad, BFA_FALSE);
752 bfa_fcs_init(&bfad->bfa_fcs); 766
767 /* Do FCS init only when HAL init is done */
768 if ((bfad->bfad_flags & BFAD_HAL_INIT_DONE)) {
769 bfa_fcs_init(&bfad->bfa_fcs);
770 bfad->bfad_flags |= BFAD_FCS_INIT_DONE;
771 }
772
753 bfa_fcs_driver_info_init(&bfad->bfa_fcs, &driver_info); 773 bfa_fcs_driver_info_init(&bfad->bfa_fcs, &driver_info);
754 bfa_fcs_set_fdmi_param(&bfad->bfa_fcs, fdmi_enable); 774 bfa_fcs_set_fdmi_param(&bfad->bfa_fcs, fdmi_enable);
755 spin_unlock_irqrestore(&bfad->bfad_lock, flags); 775 spin_unlock_irqrestore(&bfad->bfad_lock, flags);
@@ -767,12 +787,22 @@ out_hal_mem_alloc_failure:
767void 787void
768bfad_drv_uninit(struct bfad_s *bfad) 788bfad_drv_uninit(struct bfad_s *bfad)
769{ 789{
790 unsigned long flags;
791
792 spin_lock_irqsave(&bfad->bfad_lock, flags);
793 init_completion(&bfad->comp);
794 bfa_stop(&bfad->bfa);
795 spin_unlock_irqrestore(&bfad->bfad_lock, flags);
796 wait_for_completion(&bfad->comp);
797
770 del_timer_sync(&bfad->hal_tmo); 798 del_timer_sync(&bfad->hal_tmo);
771 bfa_isr_disable(&bfad->bfa); 799 bfa_isr_disable(&bfad->bfa);
772 bfa_detach(&bfad->bfa); 800 bfa_detach(&bfad->bfa);
773 bfad_remove_intr(bfad); 801 bfad_remove_intr(bfad);
774 bfa_assert(list_empty(&bfad->file_q)); 802 bfa_assert(list_empty(&bfad->file_q));
775 bfad_hal_mem_release(bfad); 803 bfad_hal_mem_release(bfad);
804
805 bfad->bfad_flags &= ~BFAD_DRV_INIT_DONE;
776} 806}
777 807
778void 808void
@@ -863,6 +893,86 @@ bfad_drv_log_level_set(struct bfad_s *bfad)
863 bfa_log_set_level_all(&bfad->log_data, log_level); 893 bfa_log_set_level_all(&bfad->log_data, log_level);
864} 894}
865 895
896bfa_status_t
897bfad_start_ops(struct bfad_s *bfad)
898{
899 int retval;
900
901 /* PPORT FCS config */
902 bfad_fcs_port_cfg(bfad);
903
904 retval = bfad_cfg_pport(bfad, BFA_PORT_ROLE_FCP_IM);
905 if (retval != BFA_STATUS_OK)
906 goto out_cfg_pport_failure;
907
908 /* BFAD level FC4 (IM/TM/IPFC) specific resource allocation */
909 retval = bfad_fc4_probe(bfad);
910 if (retval != BFA_STATUS_OK) {
911 printk(KERN_WARNING "bfad_fc4_probe failed\n");
912 goto out_fc4_probe_failure;
913 }
914
915 bfad_drv_start(bfad);
916
917 /*
918 * If bfa_linkup_delay is set to -1 default; try to retrive the
919 * value using the bfad_os_get_linkup_delay(); else use the
920 * passed in module param value as the bfa_linkup_delay.
921 */
922 if (bfa_linkup_delay < 0) {
923
924 bfa_linkup_delay = bfad_os_get_linkup_delay(bfad);
925 bfad_os_rport_online_wait(bfad);
926 bfa_linkup_delay = -1;
927
928 } else {
929 bfad_os_rport_online_wait(bfad);
930 }
931
932 bfa_log(bfad->logmod, BFA_LOG_LINUX_DEVICE_CLAIMED, bfad->pci_name);
933
934 return BFA_STATUS_OK;
935
936out_fc4_probe_failure:
937 bfad_fc4_probe_undo(bfad);
938 bfad_uncfg_pport(bfad);
939out_cfg_pport_failure:
940 return BFA_STATUS_FAILED;
941}
942
943int
944bfad_worker (void *ptr)
945{
946 struct bfad_s *bfad;
947 unsigned long flags;
948
949 bfad = (struct bfad_s *)ptr;
950
951 while (!kthread_should_stop()) {
952
953 /* Check if the FCS init is done from bfad_drv_init;
954 * if not done do FCS init and set the flag.
955 */
956 if (!(bfad->bfad_flags & BFAD_FCS_INIT_DONE)) {
957 spin_lock_irqsave(&bfad->bfad_lock, flags);
958 bfa_fcs_init(&bfad->bfa_fcs);
959 bfad->bfad_flags |= BFAD_FCS_INIT_DONE;
960 spin_unlock_irqrestore(&bfad->bfad_lock, flags);
961 }
962
963 /* Start the bfad operations after HAL init done */
964 bfad_start_ops(bfad);
965
966 spin_lock_irqsave(&bfad->bfad_lock, flags);
967 bfad->bfad_tsk = NULL;
968 spin_unlock_irqrestore(&bfad->bfad_lock, flags);
969
970 break;
971 }
972
973 return 0;
974}
975
866 /* 976 /*
867 * PCI_entry PCI driver entries * { 977 * PCI_entry PCI driver entries * {
868 */ 978 */
@@ -937,57 +1047,39 @@ bfad_pci_probe(struct pci_dev *pdev, const struct pci_device_id *pid)
937 bfad->ref_count = 0; 1047 bfad->ref_count = 0;
938 bfad->pport.bfad = bfad; 1048 bfad->pport.bfad = bfad;
939 1049
1050 bfad->bfad_tsk = kthread_create(bfad_worker, (void *) bfad, "%s",
1051 "bfad_worker");
1052 if (IS_ERR(bfad->bfad_tsk)) {
1053 printk(KERN_INFO "bfad[%d]: Kernel thread"
1054 " creation failed!\n",
1055 bfad->inst_no);
1056 goto out_kthread_create_failure;
1057 }
1058
940 retval = bfad_drv_init(bfad); 1059 retval = bfad_drv_init(bfad);
941 if (retval != BFA_STATUS_OK) 1060 if (retval != BFA_STATUS_OK)
942 goto out_drv_init_failure; 1061 goto out_drv_init_failure;
943 if (!(bfad->bfad_flags & BFAD_HAL_INIT_DONE)) { 1062 if (!(bfad->bfad_flags & BFAD_HAL_INIT_DONE)) {
1063 bfad->bfad_flags |= BFAD_HAL_INIT_FAIL;
944 printk(KERN_WARNING "bfad%d: hal init failed\n", bfad->inst_no); 1064 printk(KERN_WARNING "bfad%d: hal init failed\n", bfad->inst_no);
945 goto ok; 1065 goto ok;
946 } 1066 }
947 1067
948 /* 1068 retval = bfad_start_ops(bfad);
949 * PPORT FCS config
950 */
951 bfad_fcs_port_cfg(bfad);
952
953 retval = bfad_cfg_pport(bfad, BFA_PORT_ROLE_FCP_IM);
954 if (retval != BFA_STATUS_OK) 1069 if (retval != BFA_STATUS_OK)
955 goto out_cfg_pport_failure; 1070 goto out_start_ops_failure;
956 1071
957 /* 1072 kthread_stop(bfad->bfad_tsk);
958 * BFAD level FC4 (IM/TM/IPFC) specific resource allocation 1073 bfad->bfad_tsk = NULL;
959 */
960 retval = bfad_fc4_probe(bfad);
961 if (retval != BFA_STATUS_OK) {
962 printk(KERN_WARNING "bfad_fc4_probe failed\n");
963 goto out_fc4_probe_failure;
964 }
965
966 bfad_drv_start(bfad);
967 1074
968 /*
969 * If bfa_linkup_delay is set to -1 default; try to retrive the
970 * value using the bfad_os_get_linkup_delay(); else use the
971 * passed in module param value as the bfa_linkup_delay.
972 */
973 if (bfa_linkup_delay < 0) {
974 bfa_linkup_delay = bfad_os_get_linkup_delay(bfad);
975 bfad_os_rport_online_wait(bfad);
976 bfa_linkup_delay = -1;
977 } else {
978 bfad_os_rport_online_wait(bfad);
979 }
980
981 bfa_log(bfad->logmod, BFA_LOG_LINUX_DEVICE_CLAIMED, bfad->pci_name);
982ok: 1075ok:
983 return 0; 1076 return 0;
984 1077
985out_fc4_probe_failure: 1078out_start_ops_failure:
986 bfad_fc4_probe_undo(bfad);
987 bfad_uncfg_pport(bfad);
988out_cfg_pport_failure:
989 bfad_drv_uninit(bfad); 1079 bfad_drv_uninit(bfad);
990out_drv_init_failure: 1080out_drv_init_failure:
1081 kthread_stop(bfad->bfad_tsk);
1082out_kthread_create_failure:
991 mutex_lock(&bfad_mutex); 1083 mutex_lock(&bfad_mutex);
992 bfad_inst--; 1084 bfad_inst--;
993 list_del(&bfad->list_entry); 1085 list_del(&bfad->list_entry);
@@ -1012,6 +1104,11 @@ bfad_pci_remove(struct pci_dev *pdev)
1012 1104
1013 bfa_trc(bfad, bfad->inst_no); 1105 bfa_trc(bfad, bfad->inst_no);
1014 1106
1107 spin_lock_irqsave(&bfad->bfad_lock, flags);
1108 if (bfad->bfad_tsk != NULL)
1109 kthread_stop(bfad->bfad_tsk);
1110 spin_unlock_irqrestore(&bfad->bfad_lock, flags);
1111
1015 if ((bfad->bfad_flags & BFAD_DRV_INIT_DONE) 1112 if ((bfad->bfad_flags & BFAD_DRV_INIT_DONE)
1016 && !(bfad->bfad_flags & BFAD_HAL_INIT_DONE)) { 1113 && !(bfad->bfad_flags & BFAD_HAL_INIT_DONE)) {
1017 1114
@@ -1028,13 +1125,25 @@ bfad_pci_remove(struct pci_dev *pdev)
1028 goto remove_sysfs; 1125 goto remove_sysfs;
1029 } 1126 }
1030 1127
1031 if (bfad->bfad_flags & BFAD_HAL_START_DONE) 1128 if (bfad->bfad_flags & BFAD_HAL_START_DONE) {
1032 bfad_drv_stop(bfad); 1129 bfad_drv_stop(bfad);
1130 } else if (bfad->bfad_flags & BFAD_DRV_INIT_DONE) {
1131 /* Invoking bfa_stop() before bfa_detach
1132 * when HAL and DRV init are success
1133 * but HAL start did not occur.
1134 */
1135 spin_lock_irqsave(&bfad->bfad_lock, flags);
1136 init_completion(&bfad->comp);
1137 bfa_stop(&bfad->bfa);
1138 spin_unlock_irqrestore(&bfad->bfad_lock, flags);
1139 wait_for_completion(&bfad->comp);
1140 }
1033 1141
1034 bfad_remove_intr(bfad); 1142 bfad_remove_intr(bfad);
1035
1036 del_timer_sync(&bfad->hal_tmo); 1143 del_timer_sync(&bfad->hal_tmo);
1037 bfad_fc4_probe_undo(bfad); 1144
1145 if (bfad->bfad_flags & BFAD_FC4_PROBE_DONE)
1146 bfad_fc4_probe_undo(bfad);
1038 1147
1039 if (bfad->bfad_flags & BFAD_CFG_PPORT_DONE) 1148 if (bfad->bfad_flags & BFAD_CFG_PPORT_DONE)
1040 bfad_uncfg_pport(bfad); 1149 bfad_uncfg_pport(bfad);
diff --git a/drivers/scsi/bfa/bfad_drv.h b/drivers/scsi/bfa/bfad_drv.h
index 172c81e25c1c..9fa801a50250 100644
--- a/drivers/scsi/bfa/bfad_drv.h
+++ b/drivers/scsi/bfa/bfad_drv.h
@@ -62,7 +62,9 @@
62#define BFAD_HAL_START_DONE 0x00000010 62#define BFAD_HAL_START_DONE 0x00000010
63#define BFAD_PORT_ONLINE 0x00000020 63#define BFAD_PORT_ONLINE 0x00000020
64#define BFAD_RPORT_ONLINE 0x00000040 64#define BFAD_RPORT_ONLINE 0x00000040
65 65#define BFAD_FCS_INIT_DONE 0x00000080
66#define BFAD_HAL_INIT_FAIL 0x00000100
67#define BFAD_FC4_PROBE_DONE 0x00000200
66#define BFAD_PORT_DELETE 0x00000001 68#define BFAD_PORT_DELETE 0x00000001
67 69
68/* 70/*
@@ -168,6 +170,7 @@ struct bfad_s {
168 u32 inst_no; /* BFAD instance number */ 170 u32 inst_no; /* BFAD instance number */
169 u32 bfad_flags; 171 u32 bfad_flags;
170 spinlock_t bfad_lock; 172 spinlock_t bfad_lock;
173 struct task_struct *bfad_tsk;
171 struct bfad_cfg_param_s cfg_data; 174 struct bfad_cfg_param_s cfg_data;
172 struct bfad_msix_s msix_tab[MAX_MSIX_ENTRY]; 175 struct bfad_msix_s msix_tab[MAX_MSIX_ENTRY];
173 int nvec; 176 int nvec;
@@ -258,6 +261,7 @@ bfa_status_t bfad_vf_create(struct bfad_s *bfad, u16 vf_id,
258 struct bfa_port_cfg_s *port_cfg); 261 struct bfa_port_cfg_s *port_cfg);
259bfa_status_t bfad_cfg_pport(struct bfad_s *bfad, enum bfa_port_role role); 262bfa_status_t bfad_cfg_pport(struct bfad_s *bfad, enum bfa_port_role role);
260bfa_status_t bfad_drv_init(struct bfad_s *bfad); 263bfa_status_t bfad_drv_init(struct bfad_s *bfad);
264bfa_status_t bfad_start_ops(struct bfad_s *bfad);
261void bfad_drv_start(struct bfad_s *bfad); 265void bfad_drv_start(struct bfad_s *bfad);
262void bfad_uncfg_pport(struct bfad_s *bfad); 266void bfad_uncfg_pport(struct bfad_s *bfad);
263void bfad_drv_stop(struct bfad_s *bfad); 267void bfad_drv_stop(struct bfad_s *bfad);
@@ -280,6 +284,12 @@ void bfad_drv_log_level_set(struct bfad_s *bfad);
280bfa_status_t bfad_fc4_module_init(void); 284bfa_status_t bfad_fc4_module_init(void);
281void bfad_fc4_module_exit(void); 285void bfad_fc4_module_exit(void);
282 286
287bfa_status_t bfad_os_kthread_create(struct bfad_s *bfad);
288void bfad_os_kthread_stop(struct bfad_s *bfad);
289void bfad_os_kthread_wakeup(struct bfad_s *bfad);
290int bfad_os_kthread_should_stop(void);
291int bfad_worker (void *ptr);
292
283void bfad_pci_remove(struct pci_dev *pdev); 293void bfad_pci_remove(struct pci_dev *pdev);
284int bfad_pci_probe(struct pci_dev *pdev, const struct pci_device_id *pid); 294int bfad_pci_probe(struct pci_dev *pdev, const struct pci_device_id *pid);
285void bfad_os_rport_online_wait(struct bfad_s *bfad); 295void bfad_os_rport_online_wait(struct bfad_s *bfad);
diff --git a/drivers/scsi/bfa/fabric.c b/drivers/scsi/bfa/fabric.c
index e22989886646..20a686a420a2 100644
--- a/drivers/scsi/bfa/fabric.c
+++ b/drivers/scsi/bfa/fabric.c
@@ -136,8 +136,7 @@ bfa_fcs_fabric_sm_uninit(struct bfa_fcs_fabric_s *fabric,
136 case BFA_FCS_FABRIC_SM_CREATE: 136 case BFA_FCS_FABRIC_SM_CREATE:
137 bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_created); 137 bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_created);
138 bfa_fcs_fabric_init(fabric); 138 bfa_fcs_fabric_init(fabric);
139 bfa_fcs_lport_init(&fabric->bport, fabric->fcs, FC_VF_ID_NULL, 139 bfa_fcs_lport_init(&fabric->bport, &fabric->bport.port_cfg);
140 &fabric->bport.port_cfg, NULL);
141 break; 140 break;
142 141
143 case BFA_FCS_FABRIC_SM_LINK_UP: 142 case BFA_FCS_FABRIC_SM_LINK_UP:
@@ -841,6 +840,7 @@ bfa_fcs_fabric_attach(struct bfa_fcs_s *fcs)
841 bfa_wc_up(&fabric->wc); /* For the base port */ 840 bfa_wc_up(&fabric->wc); /* For the base port */
842 841
843 bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_uninit); 842 bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_uninit);
843 bfa_fcs_lport_attach(&fabric->bport, fabric->fcs, FC_VF_ID_NULL, NULL);
844} 844}
845 845
846void 846void
diff --git a/drivers/scsi/bfa/fcs_lport.h b/drivers/scsi/bfa/fcs_lport.h
index ae744ba35671..a6508c8ab184 100644
--- a/drivers/scsi/bfa/fcs_lport.h
+++ b/drivers/scsi/bfa/fcs_lport.h
@@ -84,9 +84,10 @@ void bfa_fcs_port_uf_recv(struct bfa_fcs_port_s *lport, struct fchs_s *fchs,
84 * Following routines will be called by Fabric to indicate port 84 * Following routines will be called by Fabric to indicate port
85 * online/offline to vport. 85 * online/offline to vport.
86 */ 86 */
87void bfa_fcs_lport_init(struct bfa_fcs_port_s *lport, struct bfa_fcs_s *fcs, 87void bfa_fcs_lport_attach(struct bfa_fcs_port_s *lport, struct bfa_fcs_s *fcs,
88 u16 vf_id, struct bfa_port_cfg_s *port_cfg, 88 uint16_t vf_id, struct bfa_fcs_vport_s *vport);
89 struct bfa_fcs_vport_s *vport); 89void bfa_fcs_lport_init(struct bfa_fcs_port_s *lport,
90 struct bfa_port_cfg_s *port_cfg);
90void bfa_fcs_port_online(struct bfa_fcs_port_s *port); 91void bfa_fcs_port_online(struct bfa_fcs_port_s *port);
91void bfa_fcs_port_offline(struct bfa_fcs_port_s *port); 92void bfa_fcs_port_offline(struct bfa_fcs_port_s *port);
92void bfa_fcs_port_delete(struct bfa_fcs_port_s *port); 93void bfa_fcs_port_delete(struct bfa_fcs_port_s *port);
diff --git a/drivers/scsi/bfa/vport.c b/drivers/scsi/bfa/vport.c
index 3dce9e1c947d..13f737139379 100644
--- a/drivers/scsi/bfa/vport.c
+++ b/drivers/scsi/bfa/vport.c
@@ -662,7 +662,8 @@ bfa_fcs_vport_create(struct bfa_fcs_vport_s *vport, struct bfa_fcs_s *fcs,
662 vport->vport_drv = vport_drv; 662 vport->vport_drv = vport_drv;
663 bfa_sm_set_state(vport, bfa_fcs_vport_sm_uninit); 663 bfa_sm_set_state(vport, bfa_fcs_vport_sm_uninit);
664 664
665 bfa_fcs_lport_init(&vport->lport, fcs, vf_id, vport_cfg, vport); 665 bfa_fcs_lport_attach(&vport->lport, fcs, vf_id, vport);
666 bfa_fcs_lport_init(&vport->lport, vport_cfg);
666 667
667 bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_CREATE); 668 bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_CREATE);
668 669