diff options
author | Nick Piggin <npiggin@suse.de> | 2008-01-30 07:31:20 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-01-30 07:31:20 -0500 |
commit | 95c354fe9f7d6decc08a92aa26eb233ecc2155bf (patch) | |
tree | ec9267032ea875e84216cfb20acb2cfc7c62149f /arch | |
parent | a95d67f87e1a5f1b4429be3ba3bf7b4051657908 (diff) |
spinlock: lockbreak cleanup
The break_lock data structure and code for spinlocks is quite nasty.
Not only does it double the size of a spinlock but it changes locking to
a potentially less optimal trylock.
Put all of that under CONFIG_GENERIC_LOCKBREAK, and introduce a
__raw_spin_is_contended that uses the lock data itself to determine whether
there are waiters on the lock, to be used if CONFIG_GENERIC_LOCKBREAK is
not set.
Rename need_lockbreak to spin_needbreak, make it use spin_is_contended to
decouple it from the spinlock implementation, and make it typesafe (rwlocks
do not have any need_lockbreak sites -- why do they even get bloated up
with that break_lock then?).
Signed-off-by: Nick Piggin <npiggin@suse.de>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/arm/Kconfig | 5 | ||||
-rw-r--r-- | arch/ia64/Kconfig | 5 | ||||
-rw-r--r-- | arch/m32r/Kconfig | 5 | ||||
-rw-r--r-- | arch/mips/Kconfig | 5 | ||||
-rw-r--r-- | arch/parisc/Kconfig | 5 | ||||
-rw-r--r-- | arch/powerpc/Kconfig | 5 | ||||
-rw-r--r-- | arch/sparc64/Kconfig | 5 | ||||
-rw-r--r-- | arch/x86/Kconfig | 4 |
8 files changed, 39 insertions, 0 deletions
diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index de211ac3853e..77201d3f7479 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig | |||
@@ -91,6 +91,11 @@ config GENERIC_IRQ_PROBE | |||
91 | bool | 91 | bool |
92 | default y | 92 | default y |
93 | 93 | ||
94 | config GENERIC_LOCKBREAK | ||
95 | bool | ||
96 | default y | ||
97 | depends on SMP && PREEMPT | ||
98 | |||
94 | config RWSEM_GENERIC_SPINLOCK | 99 | config RWSEM_GENERIC_SPINLOCK |
95 | bool | 100 | bool |
96 | default y | 101 | default y |
diff --git a/arch/ia64/Kconfig b/arch/ia64/Kconfig index bef47725d4ad..4a81b7fb191a 100644 --- a/arch/ia64/Kconfig +++ b/arch/ia64/Kconfig | |||
@@ -42,6 +42,11 @@ config MMU | |||
42 | config SWIOTLB | 42 | config SWIOTLB |
43 | bool | 43 | bool |
44 | 44 | ||
45 | config GENERIC_LOCKBREAK | ||
46 | bool | ||
47 | default y | ||
48 | depends on SMP && PREEMPT | ||
49 | |||
45 | config RWSEM_XCHGADD_ALGORITHM | 50 | config RWSEM_XCHGADD_ALGORITHM |
46 | bool | 51 | bool |
47 | default y | 52 | default y |
diff --git a/arch/m32r/Kconfig b/arch/m32r/Kconfig index ab9a264cb194..f7237c5f531e 100644 --- a/arch/m32r/Kconfig +++ b/arch/m32r/Kconfig | |||
@@ -235,6 +235,11 @@ config IRAM_SIZE | |||
235 | # Define implied options from the CPU selection here | 235 | # Define implied options from the CPU selection here |
236 | # | 236 | # |
237 | 237 | ||
238 | config GENERIC_LOCKBREAK | ||
239 | bool | ||
240 | default y | ||
241 | depends on SMP && PREEMPT | ||
242 | |||
238 | config RWSEM_GENERIC_SPINLOCK | 243 | config RWSEM_GENERIC_SPINLOCK |
239 | bool | 244 | bool |
240 | depends on M32R | 245 | depends on M32R |
diff --git a/arch/mips/Kconfig b/arch/mips/Kconfig index 6b0f85f02c79..4fad0a34b997 100644 --- a/arch/mips/Kconfig +++ b/arch/mips/Kconfig | |||
@@ -694,6 +694,11 @@ source "arch/mips/vr41xx/Kconfig" | |||
694 | 694 | ||
695 | endmenu | 695 | endmenu |
696 | 696 | ||
697 | config GENERIC_LOCKBREAK | ||
698 | bool | ||
699 | default y | ||
700 | depends on SMP && PREEMPT | ||
701 | |||
697 | config RWSEM_GENERIC_SPINLOCK | 702 | config RWSEM_GENERIC_SPINLOCK |
698 | bool | 703 | bool |
699 | default y | 704 | default y |
diff --git a/arch/parisc/Kconfig b/arch/parisc/Kconfig index b8ef1787a191..2b649c46631c 100644 --- a/arch/parisc/Kconfig +++ b/arch/parisc/Kconfig | |||
@@ -19,6 +19,11 @@ config MMU | |||
19 | config STACK_GROWSUP | 19 | config STACK_GROWSUP |
20 | def_bool y | 20 | def_bool y |
21 | 21 | ||
22 | config GENERIC_LOCKBREAK | ||
23 | bool | ||
24 | default y | ||
25 | depends on SMP && PREEMPT | ||
26 | |||
22 | config RWSEM_GENERIC_SPINLOCK | 27 | config RWSEM_GENERIC_SPINLOCK |
23 | def_bool y | 28 | def_bool y |
24 | 29 | ||
diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig index 232c298c933f..c17a194beb0e 100644 --- a/arch/powerpc/Kconfig +++ b/arch/powerpc/Kconfig | |||
@@ -53,6 +53,11 @@ config RWSEM_XCHGADD_ALGORITHM | |||
53 | bool | 53 | bool |
54 | default y | 54 | default y |
55 | 55 | ||
56 | config GENERIC_LOCKBREAK | ||
57 | bool | ||
58 | default y | ||
59 | depends on SMP && PREEMPT | ||
60 | |||
56 | config ARCH_HAS_ILOG2_U32 | 61 | config ARCH_HAS_ILOG2_U32 |
57 | bool | 62 | bool |
58 | default y | 63 | default y |
diff --git a/arch/sparc64/Kconfig b/arch/sparc64/Kconfig index 10b212a1f9f5..1e25bce0366d 100644 --- a/arch/sparc64/Kconfig +++ b/arch/sparc64/Kconfig | |||
@@ -200,6 +200,11 @@ config US2E_FREQ | |||
200 | If in doubt, say N. | 200 | If in doubt, say N. |
201 | 201 | ||
202 | # Global things across all Sun machines. | 202 | # Global things across all Sun machines. |
203 | config GENERIC_LOCKBREAK | ||
204 | bool | ||
205 | default y | ||
206 | depends on SMP && PREEMPT | ||
207 | |||
203 | config RWSEM_GENERIC_SPINLOCK | 208 | config RWSEM_GENERIC_SPINLOCK |
204 | bool | 209 | bool |
205 | 210 | ||
diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig index 23936301db56..db434f8171d3 100644 --- a/arch/x86/Kconfig +++ b/arch/x86/Kconfig | |||
@@ -19,6 +19,10 @@ config X86_64 | |||
19 | config X86 | 19 | config X86 |
20 | def_bool y | 20 | def_bool y |
21 | 21 | ||
22 | config GENERIC_LOCKBREAK | ||
23 | def_bool y | ||
24 | depends on SMP && PREEMPT | ||
25 | |||
22 | config GENERIC_TIME | 26 | config GENERIC_TIME |
23 | def_bool y | 27 | def_bool y |
24 | 28 | ||