Lines Matching refs:vport

53 inline void lpfc_vport_set_state(struct lpfc_vport *vport,  in lpfc_vport_set_state()  argument
56 struct fc_vport *fc_vport = vport->fc_vport; in lpfc_vport_set_state()
76 vport->port_state = LPFC_VPORT_FAILED; in lpfc_vport_set_state()
79 vport->port_state = LPFC_VPORT_UNKNOWN; in lpfc_vport_set_state()
118 lpfc_vport_sparm(struct lpfc_hba *phba, struct lpfc_vport *vport) in lpfc_vport_sparm() argument
131 rc = lpfc_read_sparam(phba, pmb, vport->vpi); in lpfc_vport_sparm()
144 pmb->vport = vport; in lpfc_vport_sparm()
148 lpfc_printf_vlog(vport, KERN_ERR, LOG_TRACE_EVENT, in lpfc_vport_sparm()
157 lpfc_printf_vlog(vport, KERN_ERR, LOG_TRACE_EVENT, in lpfc_vport_sparm()
169 memcpy(&vport->fc_sparam, mp->virt, sizeof (struct serv_parm)); in lpfc_vport_sparm()
170 memcpy(&vport->fc_nodename, &vport->fc_sparam.nodeName, in lpfc_vport_sparm()
172 memcpy(&vport->fc_portname, &vport->fc_sparam.portName, in lpfc_vport_sparm()
207 struct lpfc_vport *vport; in lpfc_unique_wwpn() local
211 list_for_each_entry(vport, &phba->port_list, listentry) { in lpfc_unique_wwpn()
212 if (vport == new_vport) in lpfc_unique_wwpn()
215 if (memcmp(&vport->fc_sparam.portName, in lpfc_unique_wwpn()
241 static void lpfc_discovery_wait(struct lpfc_vport *vport) in lpfc_discovery_wait() argument
243 struct lpfc_hba *phba = vport->phba; in lpfc_discovery_wait()
260 if ((vport->num_disc_nodes > 0) || in lpfc_discovery_wait()
261 (vport->fc_flag & wait_flags) || in lpfc_discovery_wait()
262 ((vport->port_state > LPFC_VPORT_FAILED) && in lpfc_discovery_wait()
263 (vport->port_state < LPFC_VPORT_READY))) { in lpfc_discovery_wait()
264 lpfc_printf_vlog(vport, KERN_INFO, LOG_VPORT, in lpfc_discovery_wait()
269 vport->port_state, vport->fc_flag, in lpfc_discovery_wait()
270 vport->num_disc_nodes, in lpfc_discovery_wait()
275 lpfc_printf_vlog(vport, KERN_INFO, LOG_VPORT, in lpfc_discovery_wait()
279 vport->port_state, vport->fc_flag, in lpfc_discovery_wait()
287 lpfc_printf_vlog(vport, KERN_ERR, LOG_TRACE_EVENT, in lpfc_discovery_wait()
290 vport->port_state, vport->fc_flag, in lpfc_discovery_wait()
301 struct lpfc_vport *vport = NULL; in lpfc_vport_create() local
345 vport = lpfc_create_port(phba, instance, &fc_vport->dev); in lpfc_vport_create()
346 if (!vport) { in lpfc_vport_create()
354 vport->vpi = vpi; in lpfc_vport_create()
355 lpfc_debugfs_initialize(vport); in lpfc_vport_create()
357 if ((status = lpfc_vport_sparm(phba, vport))) { in lpfc_vport_create()
359 lpfc_printf_vlog(vport, KERN_ERR, LOG_TRACE_EVENT, in lpfc_vport_create()
363 lpfc_printf_vlog(vport, KERN_ERR, LOG_TRACE_EVENT, in lpfc_vport_create()
369 destroy_port(vport); in lpfc_vport_create()
373 u64_to_wwn(fc_vport->node_name, vport->fc_nodename.u.wwn); in lpfc_vport_create()
374 u64_to_wwn(fc_vport->port_name, vport->fc_portname.u.wwn); in lpfc_vport_create()
376 memcpy(&vport->fc_sparam.portName, vport->fc_portname.u.wwn, 8); in lpfc_vport_create()
377 memcpy(&vport->fc_sparam.nodeName, vport->fc_nodename.u.wwn, 8); in lpfc_vport_create()
379 if (!lpfc_valid_wwn_format(phba, &vport->fc_sparam.nodeName, "WWNN") || in lpfc_vport_create()
380 !lpfc_valid_wwn_format(phba, &vport->fc_sparam.portName, "WWPN")) { in lpfc_vport_create()
381 lpfc_printf_vlog(vport, KERN_ERR, LOG_TRACE_EVENT, in lpfc_vport_create()
385 destroy_port(vport); in lpfc_vport_create()
390 if (!lpfc_unique_wwpn(phba, vport)) { in lpfc_vport_create()
391 lpfc_printf_vlog(vport, KERN_ERR, LOG_TRACE_EVENT, in lpfc_vport_create()
395 destroy_port(vport); in lpfc_vport_create()
401 lpfc_alloc_sysfs_attr(vport); in lpfc_vport_create()
404 vport->cfg_lun_queue_depth = phba->pport->cfg_lun_queue_depth; in lpfc_vport_create()
407 vport->cfg_enable_fc4_type = LPFC_ENABLE_FCP; in lpfc_vport_create()
409 *(struct lpfc_vport **)fc_vport->dd_data = vport; in lpfc_vport_create()
410 vport->fc_vport = fc_vport; in lpfc_vport_create()
413 vport->load_flag |= FC_ALLOW_FDMI; in lpfc_vport_create()
417 vport->fdmi_hba_mask = phba->pport->fdmi_hba_mask; in lpfc_vport_create()
418 vport->fdmi_port_mask = phba->pport->fdmi_port_mask; in lpfc_vport_create()
427 rc = lpfc_sli4_init_vpi(vport); in lpfc_vport_create()
441 vport->fc_flag |= FC_VPORT_NEEDS_INIT_VPI; in lpfc_vport_create()
442 lpfc_vport_set_state(vport, FC_VPORT_LINKDOWN); in lpfc_vport_create()
450 lpfc_vport_set_state(vport, FC_VPORT_LINKDOWN); in lpfc_vport_create()
456 lpfc_vport_set_state(vport, FC_VPORT_DISABLED); in lpfc_vport_create()
468 lpfc_set_disctmo(vport); in lpfc_vport_create()
469 lpfc_initial_fdisc(vport); in lpfc_vport_create()
471 lpfc_vport_set_state(vport, FC_VPORT_NO_FABRIC_SUPP); in lpfc_vport_create()
472 lpfc_printf_vlog(vport, KERN_ERR, LOG_TRACE_EVENT, in lpfc_vport_create()
476 lpfc_vport_set_state(vport, FC_VPORT_FAILED); in lpfc_vport_create()
481 lpfc_printf_vlog(vport, KERN_ERR, LOG_VPORT, in lpfc_vport_create()
483 lpfc_host_attrib_init(lpfc_shost_from_vport(vport)); in lpfc_vport_create()
491 struct lpfc_vport *vport = *(struct lpfc_vport **)fc_vport->dd_data; in disable_vport() local
492 struct lpfc_hba *phba = vport->phba; in disable_vport()
495 struct Scsi_Host *shost = lpfc_shost_from_vport(vport); in disable_vport()
497 ndlp = lpfc_findnode_did(vport, Fabric_DID); in disable_vport()
499 vport->unreg_vpi_cmpl = VPORT_INVAL; in disable_vport()
501 if (!lpfc_issue_els_npiv_logo(vport, ndlp)) in disable_vport()
502 while (vport->unreg_vpi_cmpl == VPORT_INVAL && timeout) in disable_vport()
506 lpfc_sli_host_down(vport); in disable_vport()
511 list_for_each_entry_safe(ndlp, next_ndlp, &vport->fc_nodes, nlp_listp) { in disable_vport()
514 lpfc_disc_state_machine(vport, ndlp, NULL, in disable_vport()
517 lpfc_cleanup_rpis(vport, 1); in disable_vport()
519 lpfc_stop_vport_timers(vport); in disable_vport()
520 lpfc_unreg_all_rpis(vport); in disable_vport()
521 lpfc_unreg_default_rpis(vport); in disable_vport()
526 lpfc_mbx_unreg_vpi(vport); in disable_vport()
529 vport->fc_flag |= FC_VPORT_NEEDS_INIT_VPI; in disable_vport()
533 lpfc_vport_set_state(vport, FC_VPORT_DISABLED); in disable_vport()
534 lpfc_printf_vlog(vport, KERN_ERR, LOG_VPORT, in disable_vport()
542 struct lpfc_vport *vport = *(struct lpfc_vport **)fc_vport->dd_data; in enable_vport() local
543 struct lpfc_hba *phba = vport->phba; in enable_vport()
545 struct Scsi_Host *shost = lpfc_shost_from_vport(vport); in enable_vport()
549 lpfc_vport_set_state(vport, FC_VPORT_LINKDOWN); in enable_vport()
554 vport->load_flag |= FC_LOADING; in enable_vport()
555 if (vport->fc_flag & FC_VPORT_NEEDS_INIT_VPI) { in enable_vport()
557 lpfc_issue_init_vpi(vport); in enable_vport()
561 vport->fc_flag |= FC_VPORT_NEEDS_REG_VPI; in enable_vport()
570 lpfc_set_disctmo(vport); in enable_vport()
571 lpfc_initial_fdisc(vport); in enable_vport()
573 lpfc_vport_set_state(vport, FC_VPORT_NO_FABRIC_SUPP); in enable_vport()
574 lpfc_printf_vlog(vport, KERN_ERR, LOG_TRACE_EVENT, in enable_vport()
578 lpfc_vport_set_state(vport, FC_VPORT_FAILED); in enable_vport()
582 lpfc_printf_vlog(vport, KERN_ERR, LOG_VPORT, in enable_vport()
600 struct lpfc_vport *vport = *(struct lpfc_vport **)fc_vport->dd_data; in lpfc_vport_delete() local
601 struct Scsi_Host *shost = lpfc_shost_from_vport(vport); in lpfc_vport_delete()
602 struct lpfc_hba *phba = vport->phba; in lpfc_vport_delete()
605 if (vport->port_type == LPFC_PHYSICAL_PORT) { in lpfc_vport_delete()
606 lpfc_printf_vlog(vport, KERN_ERR, LOG_TRACE_EVENT, in lpfc_vport_delete()
613 if ((vport->vport_flag & STATIC_VPORT) && in lpfc_vport_delete()
615 lpfc_printf_vlog(vport, KERN_ERR, LOG_TRACE_EVENT, in lpfc_vport_delete()
622 vport->load_flag |= FC_UNLOADING; in lpfc_vport_delete()
632 vport->port_state > LPFC_VPORT_FAILED && in lpfc_vport_delete()
633 vport->port_state < LPFC_VPORT_READY) { in lpfc_vport_delete()
637 if (vport->port_state > LPFC_VPORT_FAILED && in lpfc_vport_delete()
638 vport->port_state < LPFC_VPORT_READY) in lpfc_vport_delete()
651 lpfc_free_sysfs_attr(vport); in lpfc_vport_delete()
652 lpfc_debugfs_terminate(vport); in lpfc_vport_delete()
659 ndlp = lpfc_findnode_did(vport, Fabric_DID); in lpfc_vport_delete()
666 if (vport->cfg_enable_da_id) { in lpfc_vport_delete()
669 if (!lpfc_ns_cmd(vport, SLI_CTNS_DA_ID, 0, 0)) in lpfc_vport_delete()
670 while (vport->ct_flags && timeout) in lpfc_vport_delete()
673 lpfc_printf_log(vport->phba, KERN_WARNING, in lpfc_vport_delete()
684 if (!(vport->vpi_state & LPFC_VPI_REGISTERED)) in lpfc_vport_delete()
688 ndlp = lpfc_findnode_did(vport, Fabric_DID); in lpfc_vport_delete()
691 vport->unreg_vpi_cmpl = VPORT_INVAL; in lpfc_vport_delete()
693 if (!lpfc_issue_els_npiv_logo(vport, ndlp)) in lpfc_vport_delete()
694 while (vport->unreg_vpi_cmpl == VPORT_INVAL && timeout) in lpfc_vport_delete()
699 lpfc_discovery_wait(vport); in lpfc_vport_delete()
703 lpfc_cleanup(vport); in lpfc_vport_delete()
706 lpfc_sli_host_down(vport); in lpfc_vport_delete()
707 lpfc_stop_vport_timers(vport); in lpfc_vport_delete()
710 lpfc_unreg_all_rpis(vport); in lpfc_vport_delete()
711 lpfc_unreg_default_rpis(vport); in lpfc_vport_delete()
716 if (!(vport->vpi_state & LPFC_VPI_REGISTERED) || in lpfc_vport_delete()
717 lpfc_mbx_unreg_vpi(vport)) in lpfc_vport_delete()
723 lpfc_free_vpi(phba, vport->vpi); in lpfc_vport_delete()
724 vport->work_port_events = 0; in lpfc_vport_delete()
726 list_del_init(&vport->listentry); in lpfc_vport_delete()
728 lpfc_printf_vlog(vport, KERN_ERR, LOG_VPORT, in lpfc_vport_delete()
781 lpfc_vport_reset_stat_data(struct lpfc_vport *vport) in lpfc_vport_reset_stat_data() argument
785 list_for_each_entry_safe(ndlp, next_ndlp, &vport->fc_nodes, nlp_listp) { in lpfc_vport_reset_stat_data()
801 lpfc_alloc_bucket(struct lpfc_vport *vport) in lpfc_alloc_bucket() argument
805 list_for_each_entry_safe(ndlp, next_ndlp, &vport->fc_nodes, nlp_listp) { in lpfc_alloc_bucket()
816 lpfc_printf_vlog(vport, KERN_ERR, in lpfc_alloc_bucket()
833 lpfc_free_bucket(struct lpfc_vport *vport) in lpfc_free_bucket() argument
837 list_for_each_entry_safe(ndlp, next_ndlp, &vport->fc_nodes, nlp_listp) { in lpfc_free_bucket()