spinlock.h
来自「Linux Kernel 2.6.9 for OMAP1710」· C头文件 代码 · 共 120 行
H
120 行
/* * include/asm-sh/spinlock.h * * Copyright (C) 2002, 2003 Paul Mundt * * This file is subject to the terms and conditions of the GNU General Public * License. See the file "COPYING" in the main directory of this archive * for more details. */#ifndef __ASM_SH_SPINLOCK_H#define __ASM_SH_SPINLOCK_H#include <asm/atomic.h>/* * Your basic SMP spinlocks, allowing only a single CPU anywhere */typedef struct { volatile unsigned long lock;} spinlock_t;#define SPIN_LOCK_UNLOCKED (spinlock_t) { 0 }#define spin_lock_init(x) do { *(x) = SPIN_LOCK_UNLOCKED; } while(0)#define spin_is_locked(x) ((x)->lock != 0)#define spin_unlock_wait(x) do { barrier(); } while (spin_is_locked(x))#define _raw_spin_lock_flags(lock, flags) _raw_spin_lock(lock)/* * Simple spin lock operations. There are two variants, one clears IRQ's * on the local processor, one does not. * * We make no fairness assumptions. They have a cost. */static inline void _raw_spin_lock(spinlock_t *lock){ __asm__ __volatile__ ( "1:\n\t" "tas.b @%0\n\t" "bf/s 1b\n\t" "nop\n\t" : "=r" (lock->lock) : "r" (&lock->lock) : "t", "memory" );}static inline void _raw_spin_unlock(spinlock_t *lock){#ifdef CONFIG_DEBUG_SPINLOCK BUG_ON(!spin_is_locked(lock));#endif lock->lock = 0;}#define _raw_spin_trylock(x) (!test_and_set_bit(0, &(x)->lock))/* * Read-write spinlocks, allowing multiple readers but only one writer. * * NOTE! it is quite common to have readers in interrupts but no interrupt * writers. For those circumstances we can "mix" irq-safe locks - any writer * needs to get a irq-safe write-lock, but readers can get non-irqsafe * read-locks. */typedef struct { spinlock_t lock; atomic_t counter;} rwlock_t;#define RW_LOCK_BIAS 0x01000000#define RW_LOCK_UNLOCKED (rwlock_t) { { 0 }, { RW_LOCK_BIAS } }#define rwlock_init(x) do { *(x) = RW_LOCK_UNLOCKED; } while (0)#define rwlock_is_locked(x) (atomic_read(&(x)->counter) != RW_LOCK_BIAS)static inline void _raw_read_lock(rwlock_t *rw){ _raw_spin_lock(&rw->lock); atomic_inc(&rw->counter); _raw_spin_unlock(&rw->lock);}static inline void _raw_read_unlock(rwlock_t *rw){ _raw_spin_lock(&rw->lock); atomic_dec(&rw->counter); _raw_spin_unlock(&rw->lock);}static inline void _raw_write_lock(rwlock_t *rw){ _raw_spin_lock(&rw->lock); atomic_set(&rw->counter, -1);}static inline void _raw_write_unlock(rwlock_t *rw){ atomic_set(&rw->counter, 0); _raw_spin_unlock(&rw->lock);}static inline int _raw_write_trylock(rwlock_t *rw){ if (atomic_sub_and_test(RW_LOCK_BIAS, &rw->counter)) return 1; atomic_add(RW_LOCK_BIAS, &rw->counter); return 0;}#endif /* __ASM_SH_SPINLOCK_H */
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?