| Ingo Molnar | fb1c8f9 | 2005-09-10 00:25:56 -0700 | [diff] [blame] | 1 | #ifndef __LINUX_SPINLOCK_API_UP_H | 
|  | 2 | #define __LINUX_SPINLOCK_API_UP_H | 
|  | 3 |  | 
|  | 4 | #ifndef __LINUX_SPINLOCK_H | 
|  | 5 | # error "please don't include this file directly" | 
|  | 6 | #endif | 
|  | 7 |  | 
|  | 8 | /* | 
|  | 9 | * include/linux/spinlock_api_up.h | 
|  | 10 | * | 
|  | 11 | * spinlock API implementation on UP-nondebug (inlined implementation) | 
|  | 12 | * | 
|  | 13 | * portions Copyright 2005, Red Hat, Inc., Ingo Molnar | 
|  | 14 | * Released under the General Public License (GPL). | 
|  | 15 | */ | 
|  | 16 |  | 
|  | 17 | #define in_lock_functions(ADDR)		0 | 
|  | 18 |  | 
| Thomas Gleixner | c2f21ce | 2009-12-02 20:02:59 +0100 | [diff] [blame] | 19 | #define assert_raw_spin_locked(lock)	do { (void)(lock); } while (0) | 
| Ingo Molnar | fb1c8f9 | 2005-09-10 00:25:56 -0700 | [diff] [blame] | 20 |  | 
|  | 21 | /* | 
|  | 22 | * In the UP-nondebug case there's no real locking going on, so the | 
|  | 23 | * only thing we have to do is to keep the preempt counts and irq | 
| Joe Perches | fd3f898 | 2008-02-03 17:45:46 +0200 | [diff] [blame] | 24 | * flags straight, to suppress compiler warnings of unused lock | 
| Ingo Molnar | fb1c8f9 | 2005-09-10 00:25:56 -0700 | [diff] [blame] | 25 | * variables, and to add the proper checker annotations: | 
|  | 26 | */ | 
|  | 27 | #define __LOCK(lock) \ | 
|  | 28 | do { preempt_disable(); __acquire(lock); (void)(lock); } while (0) | 
|  | 29 |  | 
|  | 30 | #define __LOCK_BH(lock) \ | 
|  | 31 | do { local_bh_disable(); __LOCK(lock); } while (0) | 
|  | 32 |  | 
|  | 33 | #define __LOCK_IRQ(lock) \ | 
|  | 34 | do { local_irq_disable(); __LOCK(lock); } while (0) | 
|  | 35 |  | 
|  | 36 | #define __LOCK_IRQSAVE(lock, flags) \ | 
|  | 37 | do { local_irq_save(flags); __LOCK(lock); } while (0) | 
|  | 38 |  | 
|  | 39 | #define __UNLOCK(lock) \ | 
|  | 40 | do { preempt_enable(); __release(lock); (void)(lock); } while (0) | 
|  | 41 |  | 
|  | 42 | #define __UNLOCK_BH(lock) \ | 
| Thomas Gleixner | 9c1721a | 2009-12-03 21:52:18 +0100 | [diff] [blame] | 43 | do { preempt_enable_no_resched(); local_bh_enable(); \ | 
|  | 44 | __release(lock); (void)(lock); } while (0) | 
| Ingo Molnar | fb1c8f9 | 2005-09-10 00:25:56 -0700 | [diff] [blame] | 45 |  | 
|  | 46 | #define __UNLOCK_IRQ(lock) \ | 
|  | 47 | do { local_irq_enable(); __UNLOCK(lock); } while (0) | 
|  | 48 |  | 
|  | 49 | #define __UNLOCK_IRQRESTORE(lock, flags) \ | 
|  | 50 | do { local_irq_restore(flags); __UNLOCK(lock); } while (0) | 
|  | 51 |  | 
| Thomas Gleixner | 9c1721a | 2009-12-03 21:52:18 +0100 | [diff] [blame] | 52 | #define _raw_spin_lock(lock)			__LOCK(lock) | 
|  | 53 | #define _raw_spin_lock_nested(lock, subclass)	__LOCK(lock) | 
|  | 54 | #define _raw_read_lock(lock)			__LOCK(lock) | 
|  | 55 | #define _raw_write_lock(lock)			__LOCK(lock) | 
|  | 56 | #define _raw_spin_lock_bh(lock)			__LOCK_BH(lock) | 
|  | 57 | #define _raw_read_lock_bh(lock)			__LOCK_BH(lock) | 
|  | 58 | #define _raw_write_lock_bh(lock)		__LOCK_BH(lock) | 
|  | 59 | #define _raw_spin_lock_irq(lock)		__LOCK_IRQ(lock) | 
|  | 60 | #define _raw_read_lock_irq(lock)		__LOCK_IRQ(lock) | 
|  | 61 | #define _raw_write_lock_irq(lock)		__LOCK_IRQ(lock) | 
|  | 62 | #define _raw_spin_lock_irqsave(lock, flags)	__LOCK_IRQSAVE(lock, flags) | 
|  | 63 | #define _raw_read_lock_irqsave(lock, flags)	__LOCK_IRQSAVE(lock, flags) | 
|  | 64 | #define _raw_write_lock_irqsave(lock, flags)	__LOCK_IRQSAVE(lock, flags) | 
|  | 65 | #define _raw_spin_trylock(lock)			({ __LOCK(lock); 1; }) | 
|  | 66 | #define _raw_read_trylock(lock)			({ __LOCK(lock); 1; }) | 
|  | 67 | #define _raw_write_trylock(lock)			({ __LOCK(lock); 1; }) | 
|  | 68 | #define _raw_spin_trylock_bh(lock)		({ __LOCK_BH(lock); 1; }) | 
|  | 69 | #define _raw_spin_unlock(lock)			__UNLOCK(lock) | 
|  | 70 | #define _raw_read_unlock(lock)			__UNLOCK(lock) | 
|  | 71 | #define _raw_write_unlock(lock)			__UNLOCK(lock) | 
|  | 72 | #define _raw_spin_unlock_bh(lock)		__UNLOCK_BH(lock) | 
|  | 73 | #define _raw_write_unlock_bh(lock)		__UNLOCK_BH(lock) | 
|  | 74 | #define _raw_read_unlock_bh(lock)		__UNLOCK_BH(lock) | 
|  | 75 | #define _raw_spin_unlock_irq(lock)		__UNLOCK_IRQ(lock) | 
|  | 76 | #define _raw_read_unlock_irq(lock)		__UNLOCK_IRQ(lock) | 
|  | 77 | #define _raw_write_unlock_irq(lock)		__UNLOCK_IRQ(lock) | 
|  | 78 | #define _raw_spin_unlock_irqrestore(lock, flags) \ | 
|  | 79 | __UNLOCK_IRQRESTORE(lock, flags) | 
|  | 80 | #define _raw_read_unlock_irqrestore(lock, flags) \ | 
|  | 81 | __UNLOCK_IRQRESTORE(lock, flags) | 
|  | 82 | #define _raw_write_unlock_irqrestore(lock, flags) \ | 
|  | 83 | __UNLOCK_IRQRESTORE(lock, flags) | 
| Ingo Molnar | fb1c8f9 | 2005-09-10 00:25:56 -0700 | [diff] [blame] | 84 |  | 
|  | 85 | #endif /* __LINUX_SPINLOCK_API_UP_H */ |