diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2017-06-29 17:33:39 -0400 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2017-07-04 06:46:16 -0400 |
commit | 2343877fbda701599653e63f8dcc318aa1bf15ee (patch) | |
tree | d7880af87c74ca66ecd49f2d933412894551db8a /kernel/irq/manage.c | |
parent | 46e48e257360f0845fe17089713cbad4db611e70 (diff) |
genirq/timings: Move free timings out of spinlocked region
No point to do memory management from a interrupt disabled spin locked
region.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Reviewed-by: Marc Zyngier <marc.zyngier@arm.com>
Cc: Daniel Lezcano <daniel.lezcano@linaro.org>
Cc: Heiko Stuebner <heiko@sntech.de>
Cc: Julia Cartwright <julia@ni.com>
Cc: Linus Walleij <linus.walleij@linaro.org>
Cc: Brian Norris <briannorris@chromium.org>
Cc: Doug Anderson <dianders@chromium.org>
Cc: linux-rockchip@lists.infradead.org
Cc: John Keeping <john@metanate.com>
Cc: linux-gpio@vger.kernel.org
Link: http://lkml.kernel.org/r/20170629214344.196130646@linutronix.de
Diffstat (limited to 'kernel/irq/manage.c')
-rw-r--r-- | kernel/irq/manage.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/kernel/irq/manage.c b/kernel/irq/manage.c index 3e693430bfe1..91e1f2390752 100644 --- a/kernel/irq/manage.c +++ b/kernel/irq/manage.c | |||
@@ -1489,7 +1489,6 @@ static struct irqaction *__free_irq(unsigned int irq, void *dev_id) | |||
1489 | if (!desc->action) { | 1489 | if (!desc->action) { |
1490 | irq_settings_clr_disable_unlazy(desc); | 1490 | irq_settings_clr_disable_unlazy(desc); |
1491 | irq_shutdown(desc); | 1491 | irq_shutdown(desc); |
1492 | irq_remove_timings(desc); | ||
1493 | } | 1492 | } |
1494 | 1493 | ||
1495 | #ifdef CONFIG_SMP | 1494 | #ifdef CONFIG_SMP |
@@ -1531,8 +1530,10 @@ static struct irqaction *__free_irq(unsigned int irq, void *dev_id) | |||
1531 | } | 1530 | } |
1532 | } | 1531 | } |
1533 | 1532 | ||
1534 | if (!desc->action) | 1533 | if (!desc->action) { |
1535 | irq_release_resources(desc); | 1534 | irq_release_resources(desc); |
1535 | irq_remove_timings(desc); | ||
1536 | } | ||
1536 | 1537 | ||
1537 | mutex_unlock(&desc->request_mutex); | 1538 | mutex_unlock(&desc->request_mutex); |
1538 | 1539 | ||