2012-07-22 22:17:50 +00:00
|
|
|
From f0213bc69b3cf36e06957f512e389a115b187625 Mon Sep 17 00:00:00 2001
|
2011-11-20 00:01:55 +00:00
|
|
|
From: Thomas Gleixner <tglx@linutronix.de>
|
|
|
|
Date: Tue, 21 Jul 2009 22:34:14 +0200
|
2012-07-22 22:17:50 +00:00
|
|
|
Subject: [PATCH 079/282] rt: local_irq_* variants depending on RT/!RT
|
2011-11-20 00:01:55 +00:00
|
|
|
|
|
|
|
Add local_irq_*_(no)rt variant which are mainly used to break
|
|
|
|
interrupt disabled sections on PREEMPT_RT or to explicitely disable
|
|
|
|
interrupts on PREEMPT_RT.
|
|
|
|
|
|
|
|
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
|
|
|
|
---
|
|
|
|
include/linux/interrupt.h | 2 +-
|
|
|
|
include/linux/irqflags.h | 19 +++++++++++++++++++
|
|
|
|
2 files changed, 20 insertions(+), 1 deletion(-)
|
|
|
|
|
2012-05-12 14:20:55 +00:00
|
|
|
diff --git a/include/linux/interrupt.h b/include/linux/interrupt.h
|
|
|
|
index 21b94de..ddd6b2a 100644
|
|
|
|
--- a/include/linux/interrupt.h
|
|
|
|
+++ b/include/linux/interrupt.h
|
|
|
|
@@ -219,7 +219,7 @@ extern void devm_free_irq(struct device *dev, unsigned int irq, void *dev_id);
|
2011-11-20 00:01:55 +00:00
|
|
|
#ifdef CONFIG_LOCKDEP
|
|
|
|
# define local_irq_enable_in_hardirq() do { } while (0)
|
|
|
|
#else
|
|
|
|
-# define local_irq_enable_in_hardirq() local_irq_enable()
|
|
|
|
+# define local_irq_enable_in_hardirq() local_irq_enable_nort()
|
|
|
|
#endif
|
|
|
|
|
|
|
|
extern void disable_irq_nosync(unsigned int irq);
|
2012-05-12 14:20:55 +00:00
|
|
|
diff --git a/include/linux/irqflags.h b/include/linux/irqflags.h
|
|
|
|
index d176d65..37b13c4 100644
|
|
|
|
--- a/include/linux/irqflags.h
|
|
|
|
+++ b/include/linux/irqflags.h
|
2011-11-20 00:01:55 +00:00
|
|
|
@@ -147,4 +147,23 @@
|
|
|
|
|
|
|
|
#endif /* CONFIG_TRACE_IRQFLAGS_SUPPORT */
|
|
|
|
|
|
|
|
+/*
|
|
|
|
+ * local_irq* variants depending on RT/!RT
|
|
|
|
+ */
|
|
|
|
+#ifdef CONFIG_PREEMPT_RT_FULL
|
|
|
|
+# define local_irq_disable_nort() do { } while (0)
|
|
|
|
+# define local_irq_enable_nort() do { } while (0)
|
|
|
|
+# define local_irq_save_nort(flags) do { local_save_flags(flags); } while (0)
|
|
|
|
+# define local_irq_restore_nort(flags) do { (void)(flags); } while (0)
|
|
|
|
+# define local_irq_disable_rt() local_irq_disable()
|
|
|
|
+# define local_irq_enable_rt() local_irq_enable()
|
|
|
|
+#else
|
|
|
|
+# define local_irq_disable_nort() local_irq_disable()
|
|
|
|
+# define local_irq_enable_nort() local_irq_enable()
|
|
|
|
+# define local_irq_save_nort(flags) local_irq_save(flags)
|
|
|
|
+# define local_irq_restore_nort(flags) local_irq_restore(flags)
|
|
|
|
+# define local_irq_disable_rt() do { } while (0)
|
|
|
|
+# define local_irq_enable_rt() do { } while (0)
|
|
|
|
+#endif
|
|
|
|
+
|
|
|
|
#endif
|
2012-05-12 14:20:55 +00:00
|
|
|
--
|
|
|
|
1.7.10
|
|
|
|
|