summaryrefslogtreecommitdiffstats
path: root/kernel/irq/manage.c
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2017-06-29 17:33:39 -0400
committerThomas Gleixner <tglx@linutronix.de>2017-07-04 06:46:16 -0400
commit2343877fbda701599653e63f8dcc318aa1bf15ee (patch)
treed7880af87c74ca66ecd49f2d933412894551db8a /kernel/irq/manage.c
parent46e48e257360f0845fe17089713cbad4db611e70 (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.c5
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