mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-13 16:56:53 +07:00
soc: fsl: qbman: avoid race in clearing QMan interrupt
By clearing all interrupt sources, not only those that already occurred, the existing code may acknowledge by mistake interrupts that occurred after the code checks for them. Signed-off-by: Madalin Bucur <madalin.bucur@nxp.com> Signed-off-by: Roy Pledge <roy.pledge@nxp.com> Signed-off-by: Li Yang <leoyang.li@nxp.com>
This commit is contained in:
parent
bfeffd1552
commit
89857a8a5c
@ -1143,18 +1143,19 @@ static void qm_mr_process_task(struct work_struct *work);
|
|||||||
static irqreturn_t portal_isr(int irq, void *ptr)
|
static irqreturn_t portal_isr(int irq, void *ptr)
|
||||||
{
|
{
|
||||||
struct qman_portal *p = ptr;
|
struct qman_portal *p = ptr;
|
||||||
|
|
||||||
u32 clear = QM_DQAVAIL_MASK | p->irq_sources;
|
|
||||||
u32 is = qm_in(&p->p, QM_REG_ISR) & p->irq_sources;
|
u32 is = qm_in(&p->p, QM_REG_ISR) & p->irq_sources;
|
||||||
|
u32 clear = 0;
|
||||||
|
|
||||||
if (unlikely(!is))
|
if (unlikely(!is))
|
||||||
return IRQ_NONE;
|
return IRQ_NONE;
|
||||||
|
|
||||||
/* DQRR-handling if it's interrupt-driven */
|
/* DQRR-handling if it's interrupt-driven */
|
||||||
if (is & QM_PIRQ_DQRI)
|
if (is & QM_PIRQ_DQRI) {
|
||||||
__poll_portal_fast(p, QMAN_POLL_LIMIT);
|
__poll_portal_fast(p, QMAN_POLL_LIMIT);
|
||||||
|
clear = QM_DQAVAIL_MASK | QM_PIRQ_DQRI;
|
||||||
|
}
|
||||||
/* Handling of anything else that's interrupt-driven */
|
/* Handling of anything else that's interrupt-driven */
|
||||||
clear |= __poll_portal_slow(p, is);
|
clear |= __poll_portal_slow(p, is) & QM_PIRQ_SLOW;
|
||||||
qm_out(&p->p, QM_REG_ISR, clear);
|
qm_out(&p->p, QM_REG_ISR, clear);
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user