diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-03-16 20:21:00 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-03-16 20:21:00 -0400 |
commit | f74b9444192c60603020c61d7915b72893137edc (patch) | |
tree | 8b1d16d373234038c2b045c9ceb3c33b93059e8a /include/linux | |
parent | 7a6362800cb7d1d618a697a650c7aaed3eb39320 (diff) | |
parent | 4ba8216cd90560bc402f52076f64d8546e8aefcb (diff) |
Merge branch 'config' of git://git.kernel.org/pub/scm/linux/kernel/git/arnd/bkl
* 'config' of git://git.kernel.org/pub/scm/linux/kernel/git/arnd/bkl:
BKL: That's all, folks
fs/locks.c: Remove stale FIXME left over from BKL conversion
ipx: remove the BKL
appletalk: remove the BKL
x25: remove the BKL
ufs: remove the BKL
hpfs: remove the BKL
drivers: remove extraneous includes of smp_lock.h
tracing: don't trace the BKL
adfs: remove the big kernel lock
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/hardirq.h | 9 | ||||
-rw-r--r-- | include/linux/smp_lock.h | 65 |
2 files changed, 1 insertions, 73 deletions
diff --git a/include/linux/hardirq.h b/include/linux/hardirq.h index 32f9fd6619b4..ba362171e8ae 100644 --- a/include/linux/hardirq.h +++ b/include/linux/hardirq.h | |||
@@ -93,13 +93,6 @@ | |||
93 | */ | 93 | */ |
94 | #define in_nmi() (preempt_count() & NMI_MASK) | 94 | #define in_nmi() (preempt_count() & NMI_MASK) |
95 | 95 | ||
96 | #if defined(CONFIG_PREEMPT) && defined(CONFIG_BKL) | ||
97 | # include <linux/sched.h> | ||
98 | # define PREEMPT_INATOMIC_BASE (current->lock_depth >= 0) | ||
99 | #else | ||
100 | # define PREEMPT_INATOMIC_BASE 0 | ||
101 | #endif | ||
102 | |||
103 | #if defined(CONFIG_PREEMPT) | 96 | #if defined(CONFIG_PREEMPT) |
104 | # define PREEMPT_CHECK_OFFSET 1 | 97 | # define PREEMPT_CHECK_OFFSET 1 |
105 | #else | 98 | #else |
@@ -113,7 +106,7 @@ | |||
113 | * used in the general case to determine whether sleeping is possible. | 106 | * used in the general case to determine whether sleeping is possible. |
114 | * Do not use in_atomic() in driver code. | 107 | * Do not use in_atomic() in driver code. |
115 | */ | 108 | */ |
116 | #define in_atomic() ((preempt_count() & ~PREEMPT_ACTIVE) != PREEMPT_INATOMIC_BASE) | 109 | #define in_atomic() ((preempt_count() & ~PREEMPT_ACTIVE) != 0) |
117 | 110 | ||
118 | /* | 111 | /* |
119 | * Check whether we were atomic before we did preempt_disable(): | 112 | * Check whether we were atomic before we did preempt_disable(): |
diff --git a/include/linux/smp_lock.h b/include/linux/smp_lock.h deleted file mode 100644 index 3a1988202731..000000000000 --- a/include/linux/smp_lock.h +++ /dev/null | |||
@@ -1,65 +0,0 @@ | |||
1 | #ifndef __LINUX_SMPLOCK_H | ||
2 | #define __LINUX_SMPLOCK_H | ||
3 | |||
4 | #ifdef CONFIG_LOCK_KERNEL | ||
5 | #include <linux/sched.h> | ||
6 | |||
7 | extern int __lockfunc __reacquire_kernel_lock(void); | ||
8 | extern void __lockfunc __release_kernel_lock(void); | ||
9 | |||
10 | /* | ||
11 | * Release/re-acquire global kernel lock for the scheduler | ||
12 | */ | ||
13 | #define release_kernel_lock(tsk) do { \ | ||
14 | if (unlikely((tsk)->lock_depth >= 0)) \ | ||
15 | __release_kernel_lock(); \ | ||
16 | } while (0) | ||
17 | |||
18 | static inline int reacquire_kernel_lock(struct task_struct *task) | ||
19 | { | ||
20 | if (unlikely(task->lock_depth >= 0)) | ||
21 | return __reacquire_kernel_lock(); | ||
22 | return 0; | ||
23 | } | ||
24 | |||
25 | extern void __lockfunc | ||
26 | _lock_kernel(const char *func, const char *file, int line) | ||
27 | __acquires(kernel_lock); | ||
28 | |||
29 | extern void __lockfunc | ||
30 | _unlock_kernel(const char *func, const char *file, int line) | ||
31 | __releases(kernel_lock); | ||
32 | |||
33 | #define lock_kernel() do { \ | ||
34 | _lock_kernel(__func__, __FILE__, __LINE__); \ | ||
35 | } while (0) | ||
36 | |||
37 | #define unlock_kernel() do { \ | ||
38 | _unlock_kernel(__func__, __FILE__, __LINE__); \ | ||
39 | } while (0) | ||
40 | |||
41 | /* | ||
42 | * Various legacy drivers don't really need the BKL in a specific | ||
43 | * function, but they *do* need to know that the BKL became available. | ||
44 | * This function just avoids wrapping a bunch of lock/unlock pairs | ||
45 | * around code which doesn't really need it. | ||
46 | */ | ||
47 | static inline void cycle_kernel_lock(void) | ||
48 | { | ||
49 | lock_kernel(); | ||
50 | unlock_kernel(); | ||
51 | } | ||
52 | |||
53 | #else | ||
54 | |||
55 | #ifdef CONFIG_BKL /* provoke build bug if not set */ | ||
56 | #define lock_kernel() | ||
57 | #define unlock_kernel() | ||
58 | #define cycle_kernel_lock() do { } while(0) | ||
59 | #endif /* CONFIG_BKL */ | ||
60 | |||
61 | #define release_kernel_lock(task) do { } while(0) | ||
62 | #define reacquire_kernel_lock(task) 0 | ||
63 | |||
64 | #endif /* CONFIG_LOCK_KERNEL */ | ||
65 | #endif /* __LINUX_SMPLOCK_H */ | ||