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

scsi: lpfc: Refactor cpu affinity assignment paths

During initialization, a lot of the same logic is used on MSI-X vector CPU
affinity assignment.

Create a lpfc_next_present_cpu() helper routine, and apply its usage for
refactoring purposes.
Signed-off-by: default avatarJustin Tee <justin.tee@broadcom.com>
Link: https://lore.kernel.org/r/20230712180522.112722-10-justintee8345@gmail.comSigned-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 089ea22e
...@@ -1709,6 +1709,25 @@ lpfc_next_online_cpu(const struct cpumask *mask, unsigned int start) ...@@ -1709,6 +1709,25 @@ lpfc_next_online_cpu(const struct cpumask *mask, unsigned int start)
return cpu_it; return cpu_it;
} }
/**
* lpfc_next_present_cpu - Finds next present CPU after n
* @n: the cpu prior to search
*
* Note: If no next present cpu, then fallback to first present cpu.
*
**/
static inline unsigned int lpfc_next_present_cpu(int n)
{
unsigned int cpu;
cpu = cpumask_next(n, cpu_present_mask);
if (cpu >= nr_cpu_ids)
cpu = cpumask_first(cpu_present_mask);
return cpu;
}
/** /**
* lpfc_sli4_mod_hba_eq_delay - update EQ delay * lpfc_sli4_mod_hba_eq_delay - update EQ delay
* @phba: Pointer to HBA context object. * @phba: Pointer to HBA context object.
......
...@@ -12512,10 +12512,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors) ...@@ -12512,10 +12512,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors)
(new_cpup->eq != LPFC_VECTOR_MAP_EMPTY) && (new_cpup->eq != LPFC_VECTOR_MAP_EMPTY) &&
(new_cpup->phys_id == cpup->phys_id)) (new_cpup->phys_id == cpup->phys_id))
goto found_same; goto found_same;
new_cpu = cpumask_next( new_cpu = lpfc_next_present_cpu(new_cpu);
new_cpu, cpu_present_mask);
if (new_cpu >= nr_cpu_ids)
new_cpu = first_cpu;
} }
/* At this point, we leave the CPU as unassigned */ /* At this point, we leave the CPU as unassigned */
continue; continue;
...@@ -12527,9 +12524,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors) ...@@ -12527,9 +12524,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors)
* chance of having multiple unassigned CPU entries * chance of having multiple unassigned CPU entries
* selecting the same IRQ. * selecting the same IRQ.
*/ */
start_cpu = cpumask_next(new_cpu, cpu_present_mask); start_cpu = lpfc_next_present_cpu(new_cpu);
if (start_cpu >= nr_cpu_ids)
start_cpu = first_cpu;
lpfc_printf_log(phba, KERN_INFO, LOG_INIT, lpfc_printf_log(phba, KERN_INFO, LOG_INIT,
"3337 Set Affinity: CPU %d " "3337 Set Affinity: CPU %d "
...@@ -12562,10 +12557,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors) ...@@ -12562,10 +12557,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors)
if (!(new_cpup->flag & LPFC_CPU_MAP_UNASSIGN) && if (!(new_cpup->flag & LPFC_CPU_MAP_UNASSIGN) &&
(new_cpup->eq != LPFC_VECTOR_MAP_EMPTY)) (new_cpup->eq != LPFC_VECTOR_MAP_EMPTY))
goto found_any; goto found_any;
new_cpu = cpumask_next( new_cpu = lpfc_next_present_cpu(new_cpu);
new_cpu, cpu_present_mask);
if (new_cpu >= nr_cpu_ids)
new_cpu = first_cpu;
} }
/* We should never leave an entry unassigned */ /* We should never leave an entry unassigned */
lpfc_printf_log(phba, KERN_ERR, LOG_INIT, lpfc_printf_log(phba, KERN_ERR, LOG_INIT,
...@@ -12581,9 +12573,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors) ...@@ -12581,9 +12573,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors)
* chance of having multiple unassigned CPU entries * chance of having multiple unassigned CPU entries
* selecting the same IRQ. * selecting the same IRQ.
*/ */
start_cpu = cpumask_next(new_cpu, cpu_present_mask); start_cpu = lpfc_next_present_cpu(new_cpu);
if (start_cpu >= nr_cpu_ids)
start_cpu = first_cpu;
lpfc_printf_log(phba, KERN_INFO, LOG_INIT, lpfc_printf_log(phba, KERN_INFO, LOG_INIT,
"3338 Set Affinity: CPU %d " "3338 Set Affinity: CPU %d "
...@@ -12654,9 +12644,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors) ...@@ -12654,9 +12644,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors)
new_cpup->core_id == cpup->core_id) { new_cpup->core_id == cpup->core_id) {
goto found_hdwq; goto found_hdwq;
} }
new_cpu = cpumask_next(new_cpu, cpu_present_mask); new_cpu = lpfc_next_present_cpu(new_cpu);
if (new_cpu >= nr_cpu_ids)
new_cpu = first_cpu;
} }
/* If we can't match both phys_id and core_id, /* If we can't match both phys_id and core_id,
...@@ -12668,10 +12656,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors) ...@@ -12668,10 +12656,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors)
if (new_cpup->hdwq != LPFC_VECTOR_MAP_EMPTY && if (new_cpup->hdwq != LPFC_VECTOR_MAP_EMPTY &&
new_cpup->phys_id == cpup->phys_id) new_cpup->phys_id == cpup->phys_id)
goto found_hdwq; goto found_hdwq;
new_cpu = lpfc_next_present_cpu(new_cpu);
new_cpu = cpumask_next(new_cpu, cpu_present_mask);
if (new_cpu >= nr_cpu_ids)
new_cpu = first_cpu;
} }
/* Otherwise just round robin on cfg_hdw_queue */ /* Otherwise just round robin on cfg_hdw_queue */
...@@ -12680,9 +12665,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors) ...@@ -12680,9 +12665,7 @@ lpfc_cpu_affinity_check(struct lpfc_hba *phba, int vectors)
goto logit; goto logit;
found_hdwq: found_hdwq:
/* We found an available entry, copy the IRQ info */ /* We found an available entry, copy the IRQ info */
start_cpu = cpumask_next(new_cpu, cpu_present_mask); start_cpu = lpfc_next_present_cpu(new_cpu);
if (start_cpu >= nr_cpu_ids)
start_cpu = first_cpu;
cpup->hdwq = new_cpup->hdwq; cpup->hdwq = new_cpup->hdwq;
logit: logit:
lpfc_printf_log(phba, KERN_INFO, LOG_INIT, lpfc_printf_log(phba, KERN_INFO, LOG_INIT,
......
...@@ -1620,10 +1620,7 @@ lpfc_nvmet_setup_io_context(struct lpfc_hba *phba) ...@@ -1620,10 +1620,7 @@ lpfc_nvmet_setup_io_context(struct lpfc_hba *phba)
cpu = cpumask_first(cpu_present_mask); cpu = cpumask_first(cpu_present_mask);
continue; continue;
} }
cpu = cpumask_next(cpu, cpu_present_mask); cpu = lpfc_next_present_cpu(cpu);
if (cpu == nr_cpu_ids)
cpu = cpumask_first(cpu_present_mask);
} }
for_each_present_cpu(i) { for_each_present_cpu(i) {
......
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