spinlock: Add spin_lock_bh_nested()
Signed-off-by: Thomas Graf <tgraf@suug.ch> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
897362e446
commit
113948d841
|
@ -190,6 +190,8 @@ static inline void do_raw_spin_unlock(raw_spinlock_t *lock) __releases(lock)
|
||||||
#ifdef CONFIG_DEBUG_LOCK_ALLOC
|
#ifdef CONFIG_DEBUG_LOCK_ALLOC
|
||||||
# define raw_spin_lock_nested(lock, subclass) \
|
# define raw_spin_lock_nested(lock, subclass) \
|
||||||
_raw_spin_lock_nested(lock, subclass)
|
_raw_spin_lock_nested(lock, subclass)
|
||||||
|
# define raw_spin_lock_bh_nested(lock, subclass) \
|
||||||
|
_raw_spin_lock_bh_nested(lock, subclass)
|
||||||
|
|
||||||
# define raw_spin_lock_nest_lock(lock, nest_lock) \
|
# define raw_spin_lock_nest_lock(lock, nest_lock) \
|
||||||
do { \
|
do { \
|
||||||
|
@ -205,6 +207,7 @@ static inline void do_raw_spin_unlock(raw_spinlock_t *lock) __releases(lock)
|
||||||
# define raw_spin_lock_nested(lock, subclass) \
|
# define raw_spin_lock_nested(lock, subclass) \
|
||||||
_raw_spin_lock(((void)(subclass), (lock)))
|
_raw_spin_lock(((void)(subclass), (lock)))
|
||||||
# define raw_spin_lock_nest_lock(lock, nest_lock) _raw_spin_lock(lock)
|
# define raw_spin_lock_nest_lock(lock, nest_lock) _raw_spin_lock(lock)
|
||||||
|
# define raw_spin_lock_bh_nested(lock, subclass) _raw_spin_lock_bh(lock)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SMP) || defined(CONFIG_DEBUG_SPINLOCK)
|
#if defined(CONFIG_SMP) || defined(CONFIG_DEBUG_SPINLOCK)
|
||||||
|
@ -324,6 +327,11 @@ do { \
|
||||||
raw_spin_lock_nested(spinlock_check(lock), subclass); \
|
raw_spin_lock_nested(spinlock_check(lock), subclass); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
#define spin_lock_bh_nested(lock, subclass) \
|
||||||
|
do { \
|
||||||
|
raw_spin_lock_bh_nested(spinlock_check(lock), subclass);\
|
||||||
|
} while (0)
|
||||||
|
|
||||||
#define spin_lock_nest_lock(lock, nest_lock) \
|
#define spin_lock_nest_lock(lock, nest_lock) \
|
||||||
do { \
|
do { \
|
||||||
raw_spin_lock_nest_lock(spinlock_check(lock), nest_lock); \
|
raw_spin_lock_nest_lock(spinlock_check(lock), nest_lock); \
|
||||||
|
|
|
@ -22,6 +22,8 @@ int in_lock_functions(unsigned long addr);
|
||||||
void __lockfunc _raw_spin_lock(raw_spinlock_t *lock) __acquires(lock);
|
void __lockfunc _raw_spin_lock(raw_spinlock_t *lock) __acquires(lock);
|
||||||
void __lockfunc _raw_spin_lock_nested(raw_spinlock_t *lock, int subclass)
|
void __lockfunc _raw_spin_lock_nested(raw_spinlock_t *lock, int subclass)
|
||||||
__acquires(lock);
|
__acquires(lock);
|
||||||
|
void __lockfunc _raw_spin_lock_bh_nested(raw_spinlock_t *lock, int subclass)
|
||||||
|
__acquires(lock);
|
||||||
void __lockfunc
|
void __lockfunc
|
||||||
_raw_spin_lock_nest_lock(raw_spinlock_t *lock, struct lockdep_map *map)
|
_raw_spin_lock_nest_lock(raw_spinlock_t *lock, struct lockdep_map *map)
|
||||||
__acquires(lock);
|
__acquires(lock);
|
||||||
|
|
|
@ -57,6 +57,7 @@
|
||||||
|
|
||||||
#define _raw_spin_lock(lock) __LOCK(lock)
|
#define _raw_spin_lock(lock) __LOCK(lock)
|
||||||
#define _raw_spin_lock_nested(lock, subclass) __LOCK(lock)
|
#define _raw_spin_lock_nested(lock, subclass) __LOCK(lock)
|
||||||
|
#define _raw_spin_lock_bh_nested(lock, subclass) __LOCK(lock)
|
||||||
#define _raw_read_lock(lock) __LOCK(lock)
|
#define _raw_read_lock(lock) __LOCK(lock)
|
||||||
#define _raw_write_lock(lock) __LOCK(lock)
|
#define _raw_write_lock(lock) __LOCK(lock)
|
||||||
#define _raw_spin_lock_bh(lock) __LOCK_BH(lock)
|
#define _raw_spin_lock_bh(lock) __LOCK_BH(lock)
|
||||||
|
|
|
@ -363,6 +363,14 @@ void __lockfunc _raw_spin_lock_nested(raw_spinlock_t *lock, int subclass)
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(_raw_spin_lock_nested);
|
EXPORT_SYMBOL(_raw_spin_lock_nested);
|
||||||
|
|
||||||
|
void __lockfunc _raw_spin_lock_bh_nested(raw_spinlock_t *lock, int subclass)
|
||||||
|
{
|
||||||
|
__local_bh_disable_ip(_RET_IP_, SOFTIRQ_LOCK_OFFSET);
|
||||||
|
spin_acquire(&lock->dep_map, subclass, 0, _RET_IP_);
|
||||||
|
LOCK_CONTENDED(lock, do_raw_spin_trylock, do_raw_spin_lock);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(_raw_spin_lock_bh_nested);
|
||||||
|
|
||||||
unsigned long __lockfunc _raw_spin_lock_irqsave_nested(raw_spinlock_t *lock,
|
unsigned long __lockfunc _raw_spin_lock_irqsave_nested(raw_spinlock_t *lock,
|
||||||
int subclass)
|
int subclass)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue