Commit 12e896c7 authored by Justin Tee's avatar Justin Tee Committed by Martin K. Petersen

scsi: lpfc: Reject received PRLIs with only initiator fcn role for NPIV ports

Currently, NPIV ports send PRLI_ACC to all received unsolicited PRLI
requests.  For an NPIV port, there is no point to PRLI_ACC if the received
PRLI request has the initiator function bit set and the target function bit
unset.  Modify the lpfc_rcv_prli_support_check() routine to send a PRLI_RJT
in such cases.  NPIV ports are expected to send PRLI_ACC only if the Target
function bit is set.
Signed-off-by: default avatarJustin Tee <justin.tee@broadcom.com>
Link: https://lore.kernel.org/r/20231009161812.97232-4-justintee8345@gmail.comSigned-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent d472a766
...@@ -934,9 +934,12 @@ lpfc_rcv_prli_support_check(struct lpfc_vport *vport, ...@@ -934,9 +934,12 @@ lpfc_rcv_prli_support_check(struct lpfc_vport *vport,
struct ls_rjt stat; struct ls_rjt stat;
uint32_t *payload; uint32_t *payload;
uint32_t cmd; uint32_t cmd;
PRLI *npr;
payload = cmdiocb->cmd_dmabuf->virt; payload = cmdiocb->cmd_dmabuf->virt;
cmd = *payload; cmd = *payload;
npr = (PRLI *)((uint8_t *)payload + sizeof(uint32_t));
if (vport->phba->nvmet_support) { if (vport->phba->nvmet_support) {
/* Must be a NVME PRLI */ /* Must be a NVME PRLI */
if (cmd == ELS_CMD_PRLI) if (cmd == ELS_CMD_PRLI)
...@@ -945,14 +948,21 @@ lpfc_rcv_prli_support_check(struct lpfc_vport *vport, ...@@ -945,14 +948,21 @@ lpfc_rcv_prli_support_check(struct lpfc_vport *vport,
/* Initiator mode. */ /* Initiator mode. */
if (!vport->nvmei_support && (cmd == ELS_CMD_NVMEPRLI)) if (!vport->nvmei_support && (cmd == ELS_CMD_NVMEPRLI))
goto out; goto out;
/* NPIV ports will RJT initiator only functions */
if (vport->port_type == LPFC_NPIV_PORT &&
npr->initiatorFunc && !npr->targetFunc)
goto out;
} }
return 1; return 1;
out: out:
lpfc_printf_vlog(vport, KERN_WARNING, LOG_NVME_DISC, lpfc_printf_vlog(vport, KERN_WARNING, LOG_DISCOVERY,
"6115 Rcv PRLI (%x) check failed: ndlp rpi %d " "6115 Rcv PRLI (%x) check failed: ndlp rpi %d "
"state x%x flags x%x\n", "state x%x flags x%x port_type: x%x "
"npr->initfcn: x%x npr->tgtfcn: x%x\n",
cmd, ndlp->nlp_rpi, ndlp->nlp_state, cmd, ndlp->nlp_rpi, ndlp->nlp_state,
ndlp->nlp_flag); ndlp->nlp_flag, vport->port_type,
npr->initiatorFunc, npr->targetFunc);
memset(&stat, 0, sizeof(struct ls_rjt)); memset(&stat, 0, sizeof(struct ls_rjt));
stat.un.b.lsRjtRsnCode = LSRJT_CMD_UNSUPPORTED; stat.un.b.lsRjtRsnCode = LSRJT_CMD_UNSUPPORTED;
stat.un.b.lsRjtRsnCodeExp = LSEXP_REQ_UNSUPPORTED; stat.un.b.lsRjtRsnCodeExp = LSEXP_REQ_UNSUPPORTED;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment