mirror of
https://github.com/torvalds/linux.git
synced 2026-03-08 03:24:45 +01:00
scsi: efct: Use IRQF_ONESHOT and default primary handler
There is no added value in efct_intr_msix() compared to
irq_default_primary_handler().
Using a threaded interrupt without a dedicated primary handler mandates
the IRQF_ONESHOT flag to mask the interrupt source while the threaded
handler is active. Otherwise the interrupt can fire again before the
threaded handler had a chance to run.
Use the default primary interrupt handler by specifying NULL and set
IRQF_ONESHOT so the interrupt source is masked until the secondary
handler is done.
Fixes: 4df84e8466 ("scsi: elx: efct: Driver initialization routines")
Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Signed-off-by: Thomas Gleixner <tglx@kernel.org>
Link: https://patch.msgid.link/20260128095540.863589-8-bigeasy@linutronix.de
This commit is contained in:
parent
28abed6569
commit
bd81f07e9a
1 changed files with 1 additions and 7 deletions
|
|
@ -415,12 +415,6 @@ efct_intr_thread(int irq, void *handle)
|
|||
return IRQ_HANDLED;
|
||||
}
|
||||
|
||||
static irqreturn_t
|
||||
efct_intr_msix(int irq, void *handle)
|
||||
{
|
||||
return IRQ_WAKE_THREAD;
|
||||
}
|
||||
|
||||
static int
|
||||
efct_setup_msix(struct efct *efct, u32 num_intrs)
|
||||
{
|
||||
|
|
@ -450,7 +444,7 @@ efct_setup_msix(struct efct *efct, u32 num_intrs)
|
|||
intr_ctx->index = i;
|
||||
|
||||
rc = request_threaded_irq(pci_irq_vector(efct->pci, i),
|
||||
efct_intr_msix, efct_intr_thread, 0,
|
||||
NULL, efct_intr_thread, IRQF_ONESHOT,
|
||||
EFCT_DRIVER_NAME, intr_ctx);
|
||||
if (rc) {
|
||||
dev_err(&efct->pci->dev,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue