Commit 657add4e authored by James Smart's avatar James Smart Committed by Martin K. Petersen

scsi: lpfc: Fix poor use of hardware queues if fewer irq vectors

While fixing the resources per socket, realized the driver was not using
hardware queues (up to 1 per cpu) if there were fewer interrupt
vectors. The driver was only using the hardware queue assigned to the cpu
with the vector.

Rework the affinity map check to use the additional hardware queue elements
that had been allocated.  If the cpu count exceeds the hardware queue count
- share, but choose what is shared with by: hyperthread peer, core peer,
socket peer, or finally similar cpu in a different socket.
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 d9954a2d
...@@ -5115,7 +5115,8 @@ lpfc_cq_max_proc_limit_store(struct device *dev, struct device_attribute *attr, ...@@ -5115,7 +5115,8 @@ lpfc_cq_max_proc_limit_store(struct device *dev, struct device_attribute *attr,
/* set the values on the cq's */ /* set the values on the cq's */
for (i = 0; i < phba->cfg_irq_chann; i++) { for (i = 0; i < phba->cfg_irq_chann; i++) {
eq = phba->sli4_hba.hdwq[i].hba_eq; /* Get the EQ corresponding to the IRQ vector */
eq = phba->sli4_hba.hba_eq_hdl[i].eq;
if (!eq) if (!eq)
continue; continue;
......
This diff is collapsed.
...@@ -5548,6 +5548,7 @@ lpfc_sli4_arm_cqeq_intr(struct lpfc_hba *phba) ...@@ -5548,6 +5548,7 @@ lpfc_sli4_arm_cqeq_intr(struct lpfc_hba *phba)
int qidx; int qidx;
struct lpfc_sli4_hba *sli4_hba = &phba->sli4_hba; struct lpfc_sli4_hba *sli4_hba = &phba->sli4_hba;
struct lpfc_sli4_hdw_queue *qp; struct lpfc_sli4_hdw_queue *qp;
struct lpfc_queue *eq;
sli4_hba->sli4_write_cq_db(phba, sli4_hba->mbx_cq, 0, LPFC_QUEUE_REARM); sli4_hba->sli4_write_cq_db(phba, sli4_hba->mbx_cq, 0, LPFC_QUEUE_REARM);
sli4_hba->sli4_write_cq_db(phba, sli4_hba->els_cq, 0, LPFC_QUEUE_REARM); sli4_hba->sli4_write_cq_db(phba, sli4_hba->els_cq, 0, LPFC_QUEUE_REARM);
...@@ -5555,18 +5556,24 @@ lpfc_sli4_arm_cqeq_intr(struct lpfc_hba *phba) ...@@ -5555,18 +5556,24 @@ lpfc_sli4_arm_cqeq_intr(struct lpfc_hba *phba)
sli4_hba->sli4_write_cq_db(phba, sli4_hba->nvmels_cq, 0, sli4_hba->sli4_write_cq_db(phba, sli4_hba->nvmels_cq, 0,
LPFC_QUEUE_REARM); LPFC_QUEUE_REARM);
qp = sli4_hba->hdwq;
if (sli4_hba->hdwq) { if (sli4_hba->hdwq) {
/* Loop thru all Hardware Queues */
for (qidx = 0; qidx < phba->cfg_hdw_queue; qidx++) { for (qidx = 0; qidx < phba->cfg_hdw_queue; qidx++) {
sli4_hba->sli4_write_cq_db(phba, qp[qidx].fcp_cq, 0, qp = &sli4_hba->hdwq[qidx];
/* ARM the corresponding CQ */
sli4_hba->sli4_write_cq_db(phba, qp->fcp_cq, 0,
LPFC_QUEUE_REARM); LPFC_QUEUE_REARM);
sli4_hba->sli4_write_cq_db(phba, qp[qidx].nvme_cq, 0, sli4_hba->sli4_write_cq_db(phba, qp->nvme_cq, 0,
LPFC_QUEUE_REARM); LPFC_QUEUE_REARM);
} }
for (qidx = 0; qidx < phba->cfg_irq_chann; qidx++) /* Loop thru all IRQ vectors */
sli4_hba->sli4_write_eq_db(phba, qp[qidx].hba_eq, for (qidx = 0; qidx < phba->cfg_irq_chann; qidx++) {
0, LPFC_QUEUE_REARM); eq = sli4_hba->hba_eq_hdl[qidx].eq;
/* ARM the corresponding EQ */
sli4_hba->sli4_write_eq_db(phba, eq,
0, LPFC_QUEUE_REARM);
}
} }
if (phba->nvmet_support) { if (phba->nvmet_support) {
...@@ -7858,20 +7865,22 @@ lpfc_sli4_process_missed_mbox_completions(struct lpfc_hba *phba) ...@@ -7858,20 +7865,22 @@ lpfc_sli4_process_missed_mbox_completions(struct lpfc_hba *phba)
struct lpfc_sli4_hba *sli4_hba = &phba->sli4_hba; struct lpfc_sli4_hba *sli4_hba = &phba->sli4_hba;
uint32_t eqidx; uint32_t eqidx;
struct lpfc_queue *fpeq = NULL; struct lpfc_queue *fpeq = NULL;
struct lpfc_queue *eq;
bool mbox_pending; bool mbox_pending;
if (unlikely(!phba) || (phba->sli_rev != LPFC_SLI_REV4)) if (unlikely(!phba) || (phba->sli_rev != LPFC_SLI_REV4))
return false; return false;
/* Find the eq associated with the mcq */ /* Find the EQ associated with the mbox CQ */
if (sli4_hba->hdwq) {
if (sli4_hba->hdwq) for (eqidx = 0; eqidx < phba->cfg_irq_chann; eqidx++) {
for (eqidx = 0; eqidx < phba->cfg_irq_chann; eqidx++) eq = phba->sli4_hba.hba_eq_hdl[eqidx].eq;
if (sli4_hba->hdwq[eqidx].hba_eq->queue_id == if (eq->queue_id == sli4_hba->mbx_cq->assoc_qid) {
sli4_hba->mbx_cq->assoc_qid) { fpeq = eq;
fpeq = sli4_hba->hdwq[eqidx].hba_eq;
break; break;
} }
}
}
if (!fpeq) if (!fpeq)
return false; return false;
...@@ -14217,7 +14226,7 @@ lpfc_sli4_hba_intr_handler(int irq, void *dev_id) ...@@ -14217,7 +14226,7 @@ lpfc_sli4_hba_intr_handler(int irq, void *dev_id)
return IRQ_NONE; return IRQ_NONE;
/* Get to the EQ struct associated with this vector */ /* Get to the EQ struct associated with this vector */
fpeq = phba->sli4_hba.hdwq[hba_eqidx].hba_eq; fpeq = phba->sli4_hba.hba_eq_hdl[hba_eqidx].eq;
if (unlikely(!fpeq)) if (unlikely(!fpeq))
return IRQ_NONE; return IRQ_NONE;
...@@ -14502,7 +14511,7 @@ lpfc_modify_hba_eq_delay(struct lpfc_hba *phba, uint32_t startq, ...@@ -14502,7 +14511,7 @@ lpfc_modify_hba_eq_delay(struct lpfc_hba *phba, uint32_t startq,
/* set values by EQ_DELAY register if supported */ /* set values by EQ_DELAY register if supported */
if (phba->sli.sli_flag & LPFC_SLI_USE_EQDR) { if (phba->sli.sli_flag & LPFC_SLI_USE_EQDR) {
for (qidx = startq; qidx < phba->cfg_irq_chann; qidx++) { for (qidx = startq; qidx < phba->cfg_irq_chann; qidx++) {
eq = phba->sli4_hba.hdwq[qidx].hba_eq; eq = phba->sli4_hba.hba_eq_hdl[qidx].eq;
if (!eq) if (!eq)
continue; continue;
...@@ -14511,7 +14520,6 @@ lpfc_modify_hba_eq_delay(struct lpfc_hba *phba, uint32_t startq, ...@@ -14511,7 +14520,6 @@ lpfc_modify_hba_eq_delay(struct lpfc_hba *phba, uint32_t startq,
if (++cnt >= numq) if (++cnt >= numq)
break; break;
} }
return; return;
} }
...@@ -14539,7 +14547,7 @@ lpfc_modify_hba_eq_delay(struct lpfc_hba *phba, uint32_t startq, ...@@ -14539,7 +14547,7 @@ lpfc_modify_hba_eq_delay(struct lpfc_hba *phba, uint32_t startq,
dmult = LPFC_DMULT_MAX; dmult = LPFC_DMULT_MAX;
for (qidx = startq; qidx < phba->cfg_irq_chann; qidx++) { for (qidx = startq; qidx < phba->cfg_irq_chann; qidx++) {
eq = phba->sli4_hba.hdwq[qidx].hba_eq; eq = phba->sli4_hba.hba_eq_hdl[qidx].eq;
if (!eq) if (!eq)
continue; continue;
eq->q_mode = usdelay; eq->q_mode = usdelay;
......
...@@ -452,6 +452,7 @@ struct lpfc_hba_eq_hdl { ...@@ -452,6 +452,7 @@ struct lpfc_hba_eq_hdl {
uint32_t idx; uint32_t idx;
char handler_name[LPFC_SLI4_HANDLER_NAME_SZ]; char handler_name[LPFC_SLI4_HANDLER_NAME_SZ];
struct lpfc_hba *phba; struct lpfc_hba *phba;
struct lpfc_queue *eq;
}; };
/*BB Credit recovery value*/ /*BB Credit recovery value*/
...@@ -552,6 +553,7 @@ struct lpfc_vector_map_info { ...@@ -552,6 +553,7 @@ struct lpfc_vector_map_info {
uint16_t flag; uint16_t flag;
#define LPFC_CPU_MAP_HYPER 0x1 #define LPFC_CPU_MAP_HYPER 0x1
#define LPFC_CPU_MAP_UNASSIGN 0x2 #define LPFC_CPU_MAP_UNASSIGN 0x2
#define LPFC_CPU_FIRST_IRQ 0x4
}; };
#define LPFC_VECTOR_MAP_EMPTY 0xffff #define LPFC_VECTOR_MAP_EMPTY 0xffff
......
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