Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

scsi: lpfc: nvmet: Avoid hang / use-after-free again when destroying targetport

We cannot wait on a completion object in the lpfc_nvme_targetport structure
in the _destroy_targetport() code path because the NVMe/fc transport will
free that structure immediately after the .targetport_delete() callback.
This results in a use-after-free, and a crash if slub_debug=FZPU is
enabled.

An earlier fix put put the completion on the stack, but commit 2a0fb340fcc8
("scsi: lpfc: Correct localport timeout duration error") subsequently
changed the code to reference the completion through a pointer in the
object rather than the local stack variable. Fix this by using the stack
variable directly.

Link: https://lore.kernel.org/r/20200729231011.13240-1-emilne@redhat.com
Fixes: 2a0fb340fcc8 ("scsi: lpfc: Correct localport timeout duration error")
Reviewed-by: James Smart <james.smart@broadcom.com>
Signed-off-by: Ewan D. Milne <emilne@redhat.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>

authored by

Ewan D. Milne and committed by
Martin K. Petersen
af6de8c6 8a8fb897

+1 -1
+1 -1
drivers/scsi/lpfc/lpfc_nvmet.c
··· 2110 2110 } 2111 2111 tgtp->tport_unreg_cmp = &tport_unreg_cmp; 2112 2112 nvmet_fc_unregister_targetport(phba->targetport); 2113 - if (!wait_for_completion_timeout(tgtp->tport_unreg_cmp, 2113 + if (!wait_for_completion_timeout(&tport_unreg_cmp, 2114 2114 msecs_to_jiffies(LPFC_NVMET_WAIT_TMO))) 2115 2115 lpfc_printf_log(phba, KERN_ERR, LOG_TRACE_EVENT, 2116 2116 "6179 Unreg targetport x%px timeout "