[SCSI] lpfc 8.3.37: Fixed infinite loop in lpfc_sli4_fcf_rr_next_index_get.
Signed-off-by: James Smart <james.smart@emulex.com> Signed-off-by: James Bottomley <JBottomley@Parallels.com>
This commit is contained in:
parent
0a630c2788
commit
421c66228a
|
@ -15556,10 +15556,13 @@ lpfc_sli4_fcf_rr_next_index_get(struct lpfc_hba *phba)
|
||||||
{
|
{
|
||||||
uint16_t next_fcf_index;
|
uint16_t next_fcf_index;
|
||||||
|
|
||||||
|
initial_priority:
|
||||||
/* Search start from next bit of currently registered FCF index */
|
/* Search start from next bit of currently registered FCF index */
|
||||||
|
next_fcf_index = phba->fcf.current_rec.fcf_indx;
|
||||||
|
|
||||||
next_priority:
|
next_priority:
|
||||||
next_fcf_index = (phba->fcf.current_rec.fcf_indx + 1) %
|
/* Determine the next fcf index to check */
|
||||||
LPFC_SLI4_FCF_TBL_INDX_MAX;
|
next_fcf_index = (next_fcf_index + 1) % LPFC_SLI4_FCF_TBL_INDX_MAX;
|
||||||
next_fcf_index = find_next_bit(phba->fcf.fcf_rr_bmask,
|
next_fcf_index = find_next_bit(phba->fcf.fcf_rr_bmask,
|
||||||
LPFC_SLI4_FCF_TBL_INDX_MAX,
|
LPFC_SLI4_FCF_TBL_INDX_MAX,
|
||||||
next_fcf_index);
|
next_fcf_index);
|
||||||
|
@ -15586,7 +15589,7 @@ lpfc_sli4_fcf_rr_next_index_get(struct lpfc_hba *phba)
|
||||||
* at that level and continue the selection process.
|
* at that level and continue the selection process.
|
||||||
*/
|
*/
|
||||||
if (lpfc_check_next_fcf_pri_level(phba))
|
if (lpfc_check_next_fcf_pri_level(phba))
|
||||||
goto next_priority;
|
goto initial_priority;
|
||||||
lpfc_printf_log(phba, KERN_WARNING, LOG_FIP,
|
lpfc_printf_log(phba, KERN_WARNING, LOG_FIP,
|
||||||
"2844 No roundrobin failover FCF available\n");
|
"2844 No roundrobin failover FCF available\n");
|
||||||
if (next_fcf_index >= LPFC_SLI4_FCF_TBL_INDX_MAX)
|
if (next_fcf_index >= LPFC_SLI4_FCF_TBL_INDX_MAX)
|
||||||
|
|
Loading…
Reference in New Issue