#define NLP_RNID_SND       0x00000400  /* sent RNID request for this entry */
 #define NLP_ELS_SND_MASK   0x000007e0  /* sent ELS request for this entry */
 #define NLP_NVMET_RECOV    0x00001000   /* NVMET auditing node for recovery. */
+#define NLP_FCP_PRLI_RJT   0x00002000   /* Rport does not support FCP PRLI. */
 #define NLP_DEFER_RM       0x00010000  /* Remove this ndlp if no longer used */
 #define NLP_DELAY_TMO      0x00020000  /* delay timeout is running for node */
 #define NLP_NPR_2B_DISC    0x00040000  /* node is included in num_disc_nodes */
 
 lpfc_issue_els_plogi(struct lpfc_vport *vport, uint32_t did, uint8_t retry)
 {
        struct lpfc_hba  *phba = vport->phba;
+       struct Scsi_Host *shost;
        struct serv_parm *sp;
        struct lpfc_nodelist *ndlp;
        struct lpfc_iocbq *elsiocb;
        if (!elsiocb)
                return 1;
 
+       shost = lpfc_shost_from_vport(vport);
+       spin_lock_irq(shost->host_lock);
+       ndlp->nlp_flag &= ~NLP_FCP_PRLI_RJT;
+       spin_unlock_irq(shost->host_lock);
+
        pcmd = (uint8_t *) (((struct lpfc_dmabuf *) elsiocb->context2)->virt);
 
        /* For PLOGI request, remainder of payload is service parameters */
                                goto out_retry;
                        }
                        break;
+               case LSRJT_CMD_UNSUPPORTED:
+                       /* lpfc nvmet returns this type of LS_RJT when it
+                        * receives an FCP PRLI because lpfc nvmet only
+                        * support NVME.  ELS request is terminated for FCP4
+                        * on this rport.
+                        */
+                       if (stat.un.b.lsRjtRsnCodeExp ==
+                           LSEXP_REQ_UNSUPPORTED && cmd == ELS_CMD_PRLI) {
+                               spin_lock_irq(shost->host_lock);
+                               ndlp->nlp_flag |= NLP_FCP_PRLI_RJT;
+                               spin_unlock_irq(shost->host_lock);
+                               retry = 0;
+                               goto out_retry;
+                       }
+                       break;
                }
                break;
 
                        rjt_exp = LSEXP_NOTHING_MORE;
                        break;
                }
+
+               /* NVMET accepts NVME PRLI only.  Reject FCP PRLI */
+               if (cmd == ELS_CMD_PRLI && phba->nvmet_support) {
+                       rjt_err = LSRJT_CMD_UNSUPPORTED;
+                       rjt_exp = LSEXP_REQ_UNSUPPORTED;
+                       break;
+               }
                lpfc_disc_state_machine(vport, ndlp, elsiocb, NLP_EVT_RCV_PRLI);
                break;
        case ELS_CMD_LIRR:
 
                        goto out;
                }
 
+               /* When the rport rejected the FCP PRLI as unsupported.
+                * This should only happen in Pt2Pt so an NVME PRLI
+                * should be outstanding still.
+                */
+               if (npr && ndlp->nlp_flag & NLP_FCP_PRLI_RJT) {
+                       ndlp->nlp_fc4_type &= ~NLP_FC4_FCP;
+                       goto out_err;
+               }
+
                /* The LS Req had some error.  Don't let this be a
                 * target.
                 */