blob: 68d88f71f1a2049c2f8be89c47aab85978f21054 [file] [log] [blame]
Ingo Molnarfb1c8f92005-09-10 00:25:56 -07001#ifndef __LINUX_SPINLOCK_TYPES_H
2#define __LINUX_SPINLOCK_TYPES_H
3
4/*
5 * include/linux/spinlock_types.h - generic spinlock type definitions
6 * and initializers
7 *
8 * portions Copyright 2005, Red Hat, Inc., Ingo Molnar
9 * Released under the General Public License (GPL).
10 */
11
12#if defined(CONFIG_SMP)
13# include <asm/spinlock_types.h>
14#else
15# include <linux/spinlock_types_up.h>
16#endif
17
Peter Zijlstra21f8ca32007-07-19 01:48:53 -070018#include <linux/lockdep.h>
19
Ingo Molnarfb1c8f92005-09-10 00:25:56 -070020typedef struct {
21 raw_spinlock_t raw_lock;
Nick Piggin95c354f2008-01-30 13:31:20 +010022#ifdef CONFIG_GENERIC_LOCKBREAK
Ingo Molnarfb1c8f92005-09-10 00:25:56 -070023 unsigned int break_lock;
24#endif
25#ifdef CONFIG_DEBUG_SPINLOCK
26 unsigned int magic, owner_cpu;
27 void *owner;
28#endif
Ingo Molnar8a25d5d2006-07-03 00:24:54 -070029#ifdef CONFIG_DEBUG_LOCK_ALLOC
30 struct lockdep_map dep_map;
31#endif
Ingo Molnarfb1c8f92005-09-10 00:25:56 -070032} spinlock_t;
33
34#define SPINLOCK_MAGIC 0xdead4ead
35
36typedef struct {
37 raw_rwlock_t raw_lock;
Nick Piggin95c354f2008-01-30 13:31:20 +010038#ifdef CONFIG_GENERIC_LOCKBREAK
Ingo Molnarfb1c8f92005-09-10 00:25:56 -070039 unsigned int break_lock;
40#endif
41#ifdef CONFIG_DEBUG_SPINLOCK
42 unsigned int magic, owner_cpu;
43 void *owner;
44#endif
Ingo Molnar8a25d5d2006-07-03 00:24:54 -070045#ifdef CONFIG_DEBUG_LOCK_ALLOC
46 struct lockdep_map dep_map;
47#endif
Ingo Molnarfb1c8f92005-09-10 00:25:56 -070048} rwlock_t;
49
50#define RWLOCK_MAGIC 0xdeaf1eed
51
52#define SPINLOCK_OWNER_INIT ((void *)-1L)
53
Ingo Molnar8a25d5d2006-07-03 00:24:54 -070054#ifdef CONFIG_DEBUG_LOCK_ALLOC
55# define SPIN_DEP_MAP_INIT(lockname) .dep_map = { .name = #lockname }
56#else
57# define SPIN_DEP_MAP_INIT(lockname)
58#endif
59
60#ifdef CONFIG_DEBUG_LOCK_ALLOC
61# define RW_DEP_MAP_INIT(lockname) .dep_map = { .name = #lockname }
62#else
63# define RW_DEP_MAP_INIT(lockname)
64#endif
65
Ingo Molnarfb1c8f92005-09-10 00:25:56 -070066#ifdef CONFIG_DEBUG_SPINLOCK
Ingo Molnare4d91912006-07-03 00:24:34 -070067# define __SPIN_LOCK_UNLOCKED(lockname) \
Ingo Molnarfb1c8f92005-09-10 00:25:56 -070068 (spinlock_t) { .raw_lock = __RAW_SPIN_LOCK_UNLOCKED, \
69 .magic = SPINLOCK_MAGIC, \
70 .owner = SPINLOCK_OWNER_INIT, \
Ingo Molnar8a25d5d2006-07-03 00:24:54 -070071 .owner_cpu = -1, \
72 SPIN_DEP_MAP_INIT(lockname) }
Ingo Molnare4d91912006-07-03 00:24:34 -070073#define __RW_LOCK_UNLOCKED(lockname) \
Ingo Molnarfb1c8f92005-09-10 00:25:56 -070074 (rwlock_t) { .raw_lock = __RAW_RW_LOCK_UNLOCKED, \
75 .magic = RWLOCK_MAGIC, \
76 .owner = SPINLOCK_OWNER_INIT, \
Ingo Molnar8a25d5d2006-07-03 00:24:54 -070077 .owner_cpu = -1, \
78 RW_DEP_MAP_INIT(lockname) }
Ingo Molnarfb1c8f92005-09-10 00:25:56 -070079#else
Ingo Molnare4d91912006-07-03 00:24:34 -070080# define __SPIN_LOCK_UNLOCKED(lockname) \
Ingo Molnar8a25d5d2006-07-03 00:24:54 -070081 (spinlock_t) { .raw_lock = __RAW_SPIN_LOCK_UNLOCKED, \
82 SPIN_DEP_MAP_INIT(lockname) }
Ingo Molnare4d91912006-07-03 00:24:34 -070083#define __RW_LOCK_UNLOCKED(lockname) \
Ingo Molnar8a25d5d2006-07-03 00:24:54 -070084 (rwlock_t) { .raw_lock = __RAW_RW_LOCK_UNLOCKED, \
85 RW_DEP_MAP_INIT(lockname) }
Ingo Molnarfb1c8f92005-09-10 00:25:56 -070086#endif
87
Michael Ellermand1ab8242007-05-08 00:30:22 -070088/*
89 * SPIN_LOCK_UNLOCKED and RW_LOCK_UNLOCKED defeat lockdep state tracking and
90 * are hence deprecated.
91 * Please use DEFINE_SPINLOCK()/DEFINE_RWLOCK() or
92 * __SPIN_LOCK_UNLOCKED()/__RW_LOCK_UNLOCKED() as appropriate.
93 */
Ingo Molnare4d91912006-07-03 00:24:34 -070094#define SPIN_LOCK_UNLOCKED __SPIN_LOCK_UNLOCKED(old_style_spin_init)
95#define RW_LOCK_UNLOCKED __RW_LOCK_UNLOCKED(old_style_rw_init)
96
97#define DEFINE_SPINLOCK(x) spinlock_t x = __SPIN_LOCK_UNLOCKED(x)
98#define DEFINE_RWLOCK(x) rwlock_t x = __RW_LOCK_UNLOCKED(x)
Ingo Molnarfb1c8f92005-09-10 00:25:56 -070099
100#endif /* __LINUX_SPINLOCK_TYPES_H */