diff options
Diffstat (limited to 'drivers/scsi/lpfc/lpfc_vport.c')
-rw-r--r-- | drivers/scsi/lpfc/lpfc_vport.c | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/drivers/scsi/lpfc/lpfc_vport.c b/drivers/scsi/lpfc/lpfc_vport.c index 1feb551a57bc..cff6ca67415c 100644 --- a/drivers/scsi/lpfc/lpfc_vport.c +++ b/drivers/scsi/lpfc/lpfc_vport.c | |||
@@ -692,13 +692,14 @@ lpfc_vport_delete(struct fc_vport *fc_vport) | |||
692 | /* Indicate free memory when release */ | 692 | /* Indicate free memory when release */ |
693 | NLP_SET_FREE_REQ(ndlp); | 693 | NLP_SET_FREE_REQ(ndlp); |
694 | } else { | 694 | } else { |
695 | if (!NLP_CHK_NODE_ACT(ndlp)) | 695 | if (!NLP_CHK_NODE_ACT(ndlp)) { |
696 | ndlp = lpfc_enable_node(vport, ndlp, | 696 | ndlp = lpfc_enable_node(vport, ndlp, |
697 | NLP_STE_UNUSED_NODE); | 697 | NLP_STE_UNUSED_NODE); |
698 | if (!ndlp) | 698 | if (!ndlp) |
699 | goto skip_logo; | 699 | goto skip_logo; |
700 | } | ||
700 | 701 | ||
701 | /* Remove ndlp from vport npld list */ | 702 | /* Remove ndlp from vport list */ |
702 | lpfc_dequeue_node(vport, ndlp); | 703 | lpfc_dequeue_node(vport, ndlp); |
703 | spin_lock_irq(&phba->ndlp_lock); | 704 | spin_lock_irq(&phba->ndlp_lock); |
704 | if (!NLP_CHK_FREE_REQ(ndlp)) | 705 | if (!NLP_CHK_FREE_REQ(ndlp)) |
@@ -711,8 +712,17 @@ lpfc_vport_delete(struct fc_vport *fc_vport) | |||
711 | } | 712 | } |
712 | spin_unlock_irq(&phba->ndlp_lock); | 713 | spin_unlock_irq(&phba->ndlp_lock); |
713 | } | 714 | } |
714 | if (!(vport->vpi_state & LPFC_VPI_REGISTERED)) | 715 | |
716 | /* | ||
717 | * If the vpi is not registered, then a valid FDISC doesn't | ||
718 | * exist and there is no need for a ELS LOGO. Just cleanup | ||
719 | * the ndlp. | ||
720 | */ | ||
721 | if (!(vport->vpi_state & LPFC_VPI_REGISTERED)) { | ||
722 | lpfc_nlp_put(ndlp); | ||
715 | goto skip_logo; | 723 | goto skip_logo; |
724 | } | ||
725 | |||
716 | vport->unreg_vpi_cmpl = VPORT_INVAL; | 726 | vport->unreg_vpi_cmpl = VPORT_INVAL; |
717 | timeout = msecs_to_jiffies(phba->fc_ratov * 2000); | 727 | timeout = msecs_to_jiffies(phba->fc_ratov * 2000); |
718 | if (!lpfc_issue_els_npiv_logo(vport, ndlp)) | 728 | if (!lpfc_issue_els_npiv_logo(vport, ndlp)) |