Commit b8e6ec86 authored by Linus Torvalds's avatar Linus Torvalds

Revert "[PATCH] Enforce "unsigned long flags;" when spinlocking"

This reverts commit ee3ce191, since it
broke on at least ARM, MIPS and PA-RISC due to complicated header file
dependencies.

Conflicts in include/linux/spinlock.h (due to the "nested" variety
fixes) fixed up by hand.

Cc: Alexey Dobriyan <adobriyan@gmail.com>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Kyle McMartin <kyle@parisc-linux.org>
Cc: Russell King <rmk+lkml@arm.linux.org.uk>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 137b529e
...@@ -11,12 +11,6 @@ ...@@ -11,12 +11,6 @@
#ifndef _LINUX_TRACE_IRQFLAGS_H #ifndef _LINUX_TRACE_IRQFLAGS_H
#define _LINUX_TRACE_IRQFLAGS_H #define _LINUX_TRACE_IRQFLAGS_H
#define BUILD_CHECK_IRQ_FLAGS(flags) \
do { \
BUILD_BUG_ON(sizeof(flags) != sizeof(unsigned long)); \
typecheck(unsigned long, flags); \
} while (0)
#ifdef CONFIG_TRACE_IRQFLAGS #ifdef CONFIG_TRACE_IRQFLAGS
extern void trace_hardirqs_on(void); extern void trace_hardirqs_on(void);
extern void trace_hardirqs_off(void); extern void trace_hardirqs_off(void);
...@@ -56,15 +50,10 @@ ...@@ -56,15 +50,10 @@
#define local_irq_disable() \ #define local_irq_disable() \
do { raw_local_irq_disable(); trace_hardirqs_off(); } while (0) do { raw_local_irq_disable(); trace_hardirqs_off(); } while (0)
#define local_irq_save(flags) \ #define local_irq_save(flags) \
do { \ do { raw_local_irq_save(flags); trace_hardirqs_off(); } while (0)
BUILD_CHECK_IRQ_FLAGS(flags); \
raw_local_irq_save(flags); \
trace_hardirqs_off(); \
} while (0)
#define local_irq_restore(flags) \ #define local_irq_restore(flags) \
do { \ do { \
BUILD_CHECK_IRQ_FLAGS(flags); \
if (raw_irqs_disabled_flags(flags)) { \ if (raw_irqs_disabled_flags(flags)) { \
raw_local_irq_restore(flags); \ raw_local_irq_restore(flags); \
trace_hardirqs_off(); \ trace_hardirqs_off(); \
...@@ -80,16 +69,8 @@ ...@@ -80,16 +69,8 @@
*/ */
# define raw_local_irq_disable() local_irq_disable() # define raw_local_irq_disable() local_irq_disable()
# define raw_local_irq_enable() local_irq_enable() # define raw_local_irq_enable() local_irq_enable()
# define raw_local_irq_save(flags) \ # define raw_local_irq_save(flags) local_irq_save(flags)
do { \ # define raw_local_irq_restore(flags) local_irq_restore(flags)
BUILD_CHECK_IRQ_FLAGS(flags); \
local_irq_save(flags); \
} while (0)
# define raw_local_irq_restore(flags) \
do { \
BUILD_CHECK_IRQ_FLAGS(flags); \
local_irq_restore(flags); \
} while (0)
#endif /* CONFIG_TRACE_IRQFLAGS_SUPPORT */ #endif /* CONFIG_TRACE_IRQFLAGS_SUPPORT */
#ifdef CONFIG_TRACE_IRQFLAGS_SUPPORT #ifdef CONFIG_TRACE_IRQFLAGS_SUPPORT
...@@ -99,11 +80,7 @@ ...@@ -99,11 +80,7 @@
raw_safe_halt(); \ raw_safe_halt(); \
} while (0) } while (0)
#define local_save_flags(flags) \ #define local_save_flags(flags) raw_local_save_flags(flags)
do { \
BUILD_CHECK_IRQ_FLAGS(flags); \
raw_local_save_flags(flags); \
} while (0)
#define irqs_disabled() \ #define irqs_disabled() \
({ \ ({ \
...@@ -113,11 +90,7 @@ ...@@ -113,11 +90,7 @@
raw_irqs_disabled_flags(flags); \ raw_irqs_disabled_flags(flags); \
}) })
#define irqs_disabled_flags(flags) \ #define irqs_disabled_flags(flags) raw_irqs_disabled_flags(flags)
({ \
BUILD_CHECK_IRQ_FLAGS(flags); \
raw_irqs_disabled_flags(flags); \
})
#endif /* CONFIG_X86 */ #endif /* CONFIG_X86 */
#endif #endif
...@@ -52,7 +52,6 @@ ...@@ -52,7 +52,6 @@
#include <linux/thread_info.h> #include <linux/thread_info.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/stringify.h> #include <linux/stringify.h>
#include <linux/irqflags.h>
#include <asm/system.h> #include <asm/system.h>
...@@ -184,52 +183,24 @@ do { \ ...@@ -184,52 +183,24 @@ do { \
#define read_lock(lock) _read_lock(lock) #define read_lock(lock) _read_lock(lock)
#if defined(CONFIG_SMP) || defined(CONFIG_DEBUG_SPINLOCK) #if defined(CONFIG_SMP) || defined(CONFIG_DEBUG_SPINLOCK)
#define spin_lock_irqsave(lock, flags) \
do { \ #define spin_lock_irqsave(lock, flags) flags = _spin_lock_irqsave(lock)
BUILD_CHECK_IRQ_FLAGS(flags); \ #define read_lock_irqsave(lock, flags) flags = _read_lock_irqsave(lock)
flags = _spin_lock_irqsave(lock); \ #define write_lock_irqsave(lock, flags) flags = _write_lock_irqsave(lock)
} while (0)
#define read_lock_irqsave(lock, flags) \
do { \
BUILD_CHECK_IRQ_FLAGS(flags); \
flags = _read_lock_irqsave(lock); \
} while (0)
#define write_lock_irqsave(lock, flags) \
do { \
BUILD_CHECK_IRQ_FLAGS(flags); \
flags = _write_lock_irqsave(lock); \
} while (0)
#ifdef CONFIG_DEBUG_LOCK_ALLOC #ifdef CONFIG_DEBUG_LOCK_ALLOC
#define spin_lock_irqsave_nested(lock, flags, subclass) \ #define spin_lock_irqsave_nested(lock, flags, subclass) \
do { \ flags = _spin_lock_irqsave_nested(lock, subclass)
BUILD_CHECK_IRQ_FLAGS(flags); \
flags = _spin_lock_irqsave_nested(lock, subclass); \
} while (0)
#else #else
#define spin_lock_irqsave_nested(lock, flags, subclass) \ #define spin_lock_irqsave_nested(lock, flags, subclass) \
do { \ flags = _spin_lock_irqsave(lock)
BUILD_CHECK_IRQ_FLAGS(flags); \
flags = _spin_lock_irqsave(lock); \
} while (0)
#endif #endif
#else #else
#define spin_lock_irqsave(lock, flags) \
do { \ #define spin_lock_irqsave(lock, flags) _spin_lock_irqsave(lock, flags)
BUILD_CHECK_IRQ_FLAGS(flags); \ #define read_lock_irqsave(lock, flags) _read_lock_irqsave(lock, flags)
_spin_lock_irqsave(lock, flags); \ #define write_lock_irqsave(lock, flags) _write_lock_irqsave(lock, flags)
} while (0)
#define read_lock_irqsave(lock, flags) \
do { \
BUILD_CHECK_IRQ_FLAGS(flags); \
_read_lock_irqsave(lock, flags); \
} while (0)
#define write_lock_irqsave(lock, flags) \
do { \
BUILD_CHECK_IRQ_FLAGS(flags); \
_write_lock_irqsave(lock, flags); \
} while (0)
#define spin_lock_irqsave_nested(lock, flags, subclass) \ #define spin_lock_irqsave_nested(lock, flags, subclass) \
spin_lock_irqsave(lock, flags) spin_lock_irqsave(lock, flags)
...@@ -268,24 +239,15 @@ do { \ ...@@ -268,24 +239,15 @@ do { \
#endif #endif
#define spin_unlock_irqrestore(lock, flags) \ #define spin_unlock_irqrestore(lock, flags) \
do { \ _spin_unlock_irqrestore(lock, flags)
BUILD_CHECK_IRQ_FLAGS(flags); \
_spin_unlock_irqrestore(lock, flags); \
} while (0)
#define spin_unlock_bh(lock) _spin_unlock_bh(lock) #define spin_unlock_bh(lock) _spin_unlock_bh(lock)
#define read_unlock_irqrestore(lock, flags) \ #define read_unlock_irqrestore(lock, flags) \
do { \ _read_unlock_irqrestore(lock, flags)
BUILD_CHECK_IRQ_FLAGS(flags); \
_read_unlock_irqrestore(lock, flags); \
} while (0)
#define read_unlock_bh(lock) _read_unlock_bh(lock) #define read_unlock_bh(lock) _read_unlock_bh(lock)
#define write_unlock_irqrestore(lock, flags) \ #define write_unlock_irqrestore(lock, flags) \
do { \ _write_unlock_irqrestore(lock, flags)
BUILD_CHECK_IRQ_FLAGS(flags); \
_write_unlock_irqrestore(lock, flags); \
} while (0)
#define write_unlock_bh(lock) _write_unlock_bh(lock) #define write_unlock_bh(lock) _write_unlock_bh(lock)
#define spin_trylock_bh(lock) __cond_lock(lock, _spin_trylock_bh(lock)) #define spin_trylock_bh(lock) __cond_lock(lock, _spin_trylock_bh(lock))
...@@ -299,7 +261,6 @@ do { \ ...@@ -299,7 +261,6 @@ do { \
#define spin_trylock_irqsave(lock, flags) \ #define spin_trylock_irqsave(lock, flags) \
({ \ ({ \
BUILD_CHECK_IRQ_FLAGS(flags); \
local_irq_save(flags); \ local_irq_save(flags); \
spin_trylock(lock) ? \ spin_trylock(lock) ? \
1 : ({ local_irq_restore(flags); 0; }); \ 1 : ({ local_irq_restore(flags); 0; }); \
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment