Commit 07f50997 authored by James Smart's avatar James Smart Committed by Martin K. Petersen

scsi: lpfc: Fix null ptr oops updating lpfc_devloss_tmo via sysfs attribute

If an admin updates lpfc's devloss_tmo sysfs attribute, the kernel will
oops.

Coding of a loop allowed a new value (rport) to be set/checked for null
followed by an older value (remoteport) checked for null to allow progress
where the new value, even though null, will be referenced.

Rework the logic to validate and prevent any reference to the null ptr.
Signed-off-by: default avatarDick Kennedy <dick.kennedy@broadcom.com>
Signed-off-by: default avatarJames Smart <jsmart2021@gmail.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 6ede2ddd
...@@ -3682,8 +3682,8 @@ lpfc_update_rport_devloss_tmo(struct lpfc_vport *vport) ...@@ -3682,8 +3682,8 @@ lpfc_update_rport_devloss_tmo(struct lpfc_vport *vport)
if (rport) if (rport)
remoteport = rport->remoteport; remoteport = rport->remoteport;
spin_unlock(&vport->phba->hbalock); spin_unlock(&vport->phba->hbalock);
if (remoteport) if (rport && remoteport)
nvme_fc_set_remoteport_devloss(rport->remoteport, nvme_fc_set_remoteport_devloss(remoteport,
vport->cfg_devloss_tmo); vport->cfg_devloss_tmo);
#endif #endif
} }
......
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