Skip to content

Commit 79b20be

Browse files
jsmart-ghmartinkpetersen
authored andcommitted
scsi: lpfc: Fix use-after-free in lpfc_unreg_rpi() routine
An error is detected with the following report when unloading the driver: "KASAN: use-after-free in lpfc_unreg_rpi+0x1b1b" The NLP_REG_LOGIN_SEND nlp_flag is set in lpfc_reg_fab_ctrl_node(), but the flag is not cleared upon completion of the login. This allows a second call to lpfc_unreg_rpi() to proceed with nlp_rpi set to LPFC_RPI_ALLOW_ERROR. This results in a use after free access when used as an rpi_ids array index. Fix by clearing the NLP_REG_LOGIN_SEND nlp_flag in lpfc_mbx_cmpl_fc_reg_login(). Link: https://lore.kernel.org/r/[email protected] Co-developed-by: Justin Tee <[email protected]> Signed-off-by: Justin Tee <[email protected]> Signed-off-by: James Smart <[email protected]> Signed-off-by: Martin K. Petersen <[email protected]>
1 parent 7a1dda9 commit 79b20be

File tree

1 file changed

+1
-0
lines changed

1 file changed

+1
-0
lines changed

drivers/scsi/lpfc/lpfc_hbadisc.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -4372,6 +4372,7 @@ lpfc_mbx_cmpl_fc_reg_login(struct lpfc_hba *phba, LPFC_MBOXQ_t *pmb)
43724372
ndlp->nlp_state);
43734373

43744374
ndlp->nlp_flag |= NLP_RPI_REGISTERED;
4375+
ndlp->nlp_flag &= ~NLP_REG_LOGIN_SEND;
43754376
ndlp->nlp_type |= NLP_FABRIC;
43764377
lpfc_nlp_set_state(vport, ndlp, NLP_STE_UNMAPPED_NODE);
43774378

0 commit comments

Comments
 (0)