]> git.baikalelectronics.ru Git - kernel.git/commit
genirq: Add IRQF_NO_AUTOEN for request_irq/nmi()
authorBarry Song <song.bao.hua@hisilicon.com>
Tue, 2 Mar 2021 22:49:15 +0000 (11:49 +1300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 17 May 2023 09:35:46 +0000 (11:35 +0200)
commitd652a14b93e6cee7cfd5d249fa43dfd0b0480bdb
treef63a7a0329c8998314a5992467ac94dba01a0b51
parent3edcc4180725e0a908075ba18a95a4739cb489ca
genirq: Add IRQF_NO_AUTOEN for request_irq/nmi()

[ Upstream commit 6f3fc8e9f6ed362dbe5eb07d94c56f2abc817399 ]

Many drivers don't want interrupts enabled automatically via request_irq().
So they are handling this issue by either way of the below two:

(1)
  irq_set_status_flags(irq, IRQ_NOAUTOEN);
  request_irq(dev, irq...);

(2)
  request_irq(dev, irq...);
  disable_irq(irq);

The code in the second way is silly and unsafe. In the small time gap
between request_irq() and disable_irq(), interrupts can still come.

The code in the first way is safe though it's subobtimal.

Add a new IRQF_NO_AUTOEN flag which can be handed in by drivers to
request_irq() and request_nmi(). It prevents the automatic enabling of the
requested interrupt/nmi in the same safe way as #1 above. With that the
various usage sites of #1 and #2 above can be simplified and corrected.

Signed-off-by: Barry Song <song.bao.hua@hisilicon.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Cc: dmitry.torokhov@gmail.com
Link: https://lore.kernel.org/r/20210302224916.13980-2-song.bao.hua@hisilicon.com
Stable-dep-of: 39db65a0a17b ("ASoC: es8316: Handle optional IRQ assignment")
Signed-off-by: Sasha Levin <sashal@kernel.org>
include/linux/interrupt.h
kernel/irq/manage.c