diff options
author | Fenghua Yu <fenghua.yu@intel.com> | 2007-07-19 04:48:12 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-07-19 13:04:44 -0400 |
commit | 5fb7dc37dc16fbc8b80d81318a582201ef7e280d (patch) | |
tree | 4d6bb4441ece64380e7186ebadd35ad2f5486f9f /arch | |
parent | 3d7e33825d8799115dd2495c9944badd3272a623 (diff) |
define new percpu interface for shared data
per cpu data section contains two types of data. One set which is
exclusively accessed by the local cpu and the other set which is per cpu,
but also shared by remote cpus. In the current kernel, these two sets are
not clearely separated out. This can potentially cause the same data
cacheline shared between the two sets of data, which will result in
unnecessary bouncing of the cacheline between cpus.
One way to fix the problem is to cacheline align the remotely accessed per
cpu data, both at the beginning and at the end. Because of the padding at
both ends, this will likely cause some memory wastage and also the
interface to achieve this is not clean.
This patch:
Moves the remotely accessed per cpu data (which is currently marked
as ____cacheline_aligned_in_smp) into a different section, where all the data
elements are cacheline aligned. And as such, this differentiates the local
only data and remotely accessed data cleanly.
Signed-off-by: Fenghua Yu <fenghua.yu@intel.com>
Acked-by: Suresh Siddha <suresh.b.siddha@intel.com>
Cc: Rusty Russell <rusty@rustcorp.com.au>
Cc: Christoph Lameter <clameter@sgi.com>
Cc: <linux-arch@vger.kernel.org>
Cc: "Luck, Tony" <tony.luck@intel.com>
Cc: Andi Kleen <ak@suse.de>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/alpha/kernel/vmlinux.lds.S | 5 | ||||
-rw-r--r-- | arch/arm/kernel/vmlinux.lds.S | 1 | ||||
-rw-r--r-- | arch/cris/arch-v32/vmlinux.lds.S | 5 | ||||
-rw-r--r-- | arch/frv/kernel/vmlinux.lds.S | 5 | ||||
-rw-r--r-- | arch/i386/kernel/vmlinux.lds.S | 1 | ||||
-rw-r--r-- | arch/ia64/kernel/vmlinux.lds.S | 1 | ||||
-rw-r--r-- | arch/m32r/kernel/vmlinux.lds.S | 5 | ||||
-rw-r--r-- | arch/mips/kernel/vmlinux.lds.S | 5 | ||||
-rw-r--r-- | arch/parisc/kernel/vmlinux.lds.S | 7 | ||||
-rw-r--r-- | arch/powerpc/kernel/vmlinux.lds.S | 1 | ||||
-rw-r--r-- | arch/ppc/kernel/vmlinux.lds.S | 5 | ||||
-rw-r--r-- | arch/s390/kernel/vmlinux.lds.S | 5 | ||||
-rw-r--r-- | arch/sh/kernel/vmlinux.lds.S | 5 | ||||
-rw-r--r-- | arch/sh64/kernel/vmlinux.lds.S | 5 | ||||
-rw-r--r-- | arch/sparc/kernel/vmlinux.lds.S | 5 | ||||
-rw-r--r-- | arch/sparc64/kernel/vmlinux.lds.S | 6 | ||||
-rw-r--r-- | arch/x86_64/kernel/vmlinux.lds.S | 6 | ||||
-rw-r--r-- | arch/xtensa/kernel/vmlinux.lds.S | 5 |
18 files changed, 25 insertions, 53 deletions
diff --git a/arch/alpha/kernel/vmlinux.lds.S b/arch/alpha/kernel/vmlinux.lds.S index 449e76f118..6f4f0378e7 100644 --- a/arch/alpha/kernel/vmlinux.lds.S +++ b/arch/alpha/kernel/vmlinux.lds.S | |||
@@ -69,10 +69,7 @@ SECTIONS | |||
69 | . = ALIGN(8); | 69 | . = ALIGN(8); |
70 | SECURITY_INIT | 70 | SECURITY_INIT |
71 | 71 | ||
72 | . = ALIGN(8192); | 72 | PERCPU(8192) |
73 | __per_cpu_start = .; | ||
74 | .data.percpu : { *(.data.percpu) } | ||
75 | __per_cpu_end = .; | ||
76 | 73 | ||
77 | . = ALIGN(2*8192); | 74 | . = ALIGN(2*8192); |
78 | __init_end = .; | 75 | __init_end = .; |
diff --git a/arch/arm/kernel/vmlinux.lds.S b/arch/arm/kernel/vmlinux.lds.S index 2b7a8f5d8c..5ff5406666 100644 --- a/arch/arm/kernel/vmlinux.lds.S +++ b/arch/arm/kernel/vmlinux.lds.S | |||
@@ -66,6 +66,7 @@ SECTIONS | |||
66 | . = ALIGN(4096); | 66 | . = ALIGN(4096); |
67 | __per_cpu_start = .; | 67 | __per_cpu_start = .; |
68 | *(.data.percpu) | 68 | *(.data.percpu) |
69 | *(.data.percpu.shared_aligned) | ||
69 | __per_cpu_end = .; | 70 | __per_cpu_end = .; |
70 | #ifndef CONFIG_XIP_KERNEL | 71 | #ifndef CONFIG_XIP_KERNEL |
71 | __init_begin = _stext; | 72 | __init_begin = _stext; |
diff --git a/arch/cris/arch-v32/vmlinux.lds.S b/arch/cris/arch-v32/vmlinux.lds.S index dfa25e1542..651a77f2cc 100644 --- a/arch/cris/arch-v32/vmlinux.lds.S +++ b/arch/cris/arch-v32/vmlinux.lds.S | |||
@@ -91,10 +91,7 @@ SECTIONS | |||
91 | } | 91 | } |
92 | SECURITY_INIT | 92 | SECURITY_INIT |
93 | 93 | ||
94 | . = ALIGN (8192); | 94 | PERCPU(8192) |
95 | __per_cpu_start = .; | ||
96 | .data.percpu : { *(.data.percpu) } | ||
97 | __per_cpu_end = .; | ||
98 | 95 | ||
99 | #ifdef CONFIG_BLK_DEV_INITRD | 96 | #ifdef CONFIG_BLK_DEV_INITRD |
100 | .init.ramfs : { | 97 | .init.ramfs : { |
diff --git a/arch/frv/kernel/vmlinux.lds.S b/arch/frv/kernel/vmlinux.lds.S index 481dc13746..3b71e0c863 100644 --- a/arch/frv/kernel/vmlinux.lds.S +++ b/arch/frv/kernel/vmlinux.lds.S | |||
@@ -57,10 +57,7 @@ SECTIONS | |||
57 | __alt_instructions_end = .; | 57 | __alt_instructions_end = .; |
58 | .altinstr_replacement : { *(.altinstr_replacement) } | 58 | .altinstr_replacement : { *(.altinstr_replacement) } |
59 | 59 | ||
60 | . = ALIGN(4096); | 60 | PERCPU(4096) |
61 | __per_cpu_start = .; | ||
62 | .data.percpu : { *(.data.percpu) } | ||
63 | __per_cpu_end = .; | ||
64 | 61 | ||
65 | #ifdef CONFIG_BLK_DEV_INITRD | 62 | #ifdef CONFIG_BLK_DEV_INITRD |
66 | . = ALIGN(4096); | 63 | . = ALIGN(4096); |
diff --git a/arch/i386/kernel/vmlinux.lds.S b/arch/i386/kernel/vmlinux.lds.S index 00f1bc47d3..4dc44b8007 100644 --- a/arch/i386/kernel/vmlinux.lds.S +++ b/arch/i386/kernel/vmlinux.lds.S | |||
@@ -181,6 +181,7 @@ SECTIONS | |||
181 | .data.percpu : AT(ADDR(.data.percpu) - LOAD_OFFSET) { | 181 | .data.percpu : AT(ADDR(.data.percpu) - LOAD_OFFSET) { |
182 | __per_cpu_start = .; | 182 | __per_cpu_start = .; |
183 | *(.data.percpu) | 183 | *(.data.percpu) |
184 | *(.data.percpu.shared_aligned) | ||
184 | __per_cpu_end = .; | 185 | __per_cpu_end = .; |
185 | } | 186 | } |
186 | . = ALIGN(4096); | 187 | . = ALIGN(4096); |
diff --git a/arch/ia64/kernel/vmlinux.lds.S b/arch/ia64/kernel/vmlinux.lds.S index 5a65965c8b..860f251d2f 100644 --- a/arch/ia64/kernel/vmlinux.lds.S +++ b/arch/ia64/kernel/vmlinux.lds.S | |||
@@ -206,6 +206,7 @@ SECTIONS | |||
206 | { | 206 | { |
207 | __per_cpu_start = .; | 207 | __per_cpu_start = .; |
208 | *(.data.percpu) | 208 | *(.data.percpu) |
209 | *(.data.percpu.shared_aligned) | ||
209 | __per_cpu_end = .; | 210 | __per_cpu_end = .; |
210 | } | 211 | } |
211 | . = __phys_per_cpu_start + PERCPU_PAGE_SIZE; /* ensure percpu data fits | 212 | . = __phys_per_cpu_start + PERCPU_PAGE_SIZE; /* ensure percpu data fits |
diff --git a/arch/m32r/kernel/vmlinux.lds.S b/arch/m32r/kernel/vmlinux.lds.S index 4e2d5b9f0a..942a8c7a44 100644 --- a/arch/m32r/kernel/vmlinux.lds.S +++ b/arch/m32r/kernel/vmlinux.lds.S | |||
@@ -110,10 +110,7 @@ SECTIONS | |||
110 | __initramfs_end = .; | 110 | __initramfs_end = .; |
111 | #endif | 111 | #endif |
112 | 112 | ||
113 | . = ALIGN(4096); | 113 | PERCPU(4096) |
114 | __per_cpu_start = .; | ||
115 | .data.percpu : { *(.data.percpu) } | ||
116 | __per_cpu_end = .; | ||
117 | . = ALIGN(4096); | 114 | . = ALIGN(4096); |
118 | __init_end = .; | 115 | __init_end = .; |
119 | /* freed after init ends here */ | 116 | /* freed after init ends here */ |
diff --git a/arch/mips/kernel/vmlinux.lds.S b/arch/mips/kernel/vmlinux.lds.S index 9b9992cd56..bc9bae2a73 100644 --- a/arch/mips/kernel/vmlinux.lds.S +++ b/arch/mips/kernel/vmlinux.lds.S | |||
@@ -119,10 +119,7 @@ SECTIONS | |||
119 | .init.ramfs : { *(.init.ramfs) } | 119 | .init.ramfs : { *(.init.ramfs) } |
120 | __initramfs_end = .; | 120 | __initramfs_end = .; |
121 | #endif | 121 | #endif |
122 | . = ALIGN(_PAGE_SIZE); | 122 | PERCPU(_PAGE_SIZE) |
123 | __per_cpu_start = .; | ||
124 | .data.percpu : { *(.data.percpu) } | ||
125 | __per_cpu_end = .; | ||
126 | . = ALIGN(_PAGE_SIZE); | 123 | . = ALIGN(_PAGE_SIZE); |
127 | __init_end = .; | 124 | __init_end = .; |
128 | /* freed after init ends here */ | 125 | /* freed after init ends here */ |
diff --git a/arch/parisc/kernel/vmlinux.lds.S b/arch/parisc/kernel/vmlinux.lds.S index 4d96ba4b98..d4e6a93c8d 100644 --- a/arch/parisc/kernel/vmlinux.lds.S +++ b/arch/parisc/kernel/vmlinux.lds.S | |||
@@ -181,10 +181,9 @@ SECTIONS | |||
181 | .init.ramfs : { *(.init.ramfs) } | 181 | .init.ramfs : { *(.init.ramfs) } |
182 | __initramfs_end = .; | 182 | __initramfs_end = .; |
183 | #endif | 183 | #endif |
184 | . = ALIGN(ASM_PAGE_SIZE); | 184 | |
185 | __per_cpu_start = .; | 185 | PERCPU(ASM_PAGE_SIZE) |
186 | .data.percpu : { *(.data.percpu) } | 186 | |
187 | __per_cpu_end = .; | ||
188 | . = ALIGN(ASM_PAGE_SIZE); | 187 | . = ALIGN(ASM_PAGE_SIZE); |
189 | __init_end = .; | 188 | __init_end = .; |
190 | /* freed after init ends here */ | 189 | /* freed after init ends here */ |
diff --git a/arch/powerpc/kernel/vmlinux.lds.S b/arch/powerpc/kernel/vmlinux.lds.S index ae4acd8414..39fda6e6aa 100644 --- a/arch/powerpc/kernel/vmlinux.lds.S +++ b/arch/powerpc/kernel/vmlinux.lds.S | |||
@@ -144,6 +144,7 @@ SECTIONS | |||
144 | .data.percpu : { | 144 | .data.percpu : { |
145 | __per_cpu_start = .; | 145 | __per_cpu_start = .; |
146 | *(.data.percpu) | 146 | *(.data.percpu) |
147 | *(.data.percpu.shared_aligned) | ||
147 | __per_cpu_end = .; | 148 | __per_cpu_end = .; |
148 | } | 149 | } |
149 | 150 | ||
diff --git a/arch/ppc/kernel/vmlinux.lds.S b/arch/ppc/kernel/vmlinux.lds.S index 19db8746ff..c0aac3ff9e 100644 --- a/arch/ppc/kernel/vmlinux.lds.S +++ b/arch/ppc/kernel/vmlinux.lds.S | |||
@@ -130,10 +130,7 @@ SECTIONS | |||
130 | __ftr_fixup : { *(__ftr_fixup) } | 130 | __ftr_fixup : { *(__ftr_fixup) } |
131 | __stop___ftr_fixup = .; | 131 | __stop___ftr_fixup = .; |
132 | 132 | ||
133 | . = ALIGN(4096); | 133 | PERCPU(4096) |
134 | __per_cpu_start = .; | ||
135 | .data.percpu : { *(.data.percpu) } | ||
136 | __per_cpu_end = .; | ||
137 | 134 | ||
138 | #ifdef CONFIG_BLK_DEV_INITRD | 135 | #ifdef CONFIG_BLK_DEV_INITRD |
139 | . = ALIGN(4096); | 136 | . = ALIGN(4096); |
diff --git a/arch/s390/kernel/vmlinux.lds.S b/arch/s390/kernel/vmlinux.lds.S index 7158a804a5..61ffd50fac 100644 --- a/arch/s390/kernel/vmlinux.lds.S +++ b/arch/s390/kernel/vmlinux.lds.S | |||
@@ -107,10 +107,7 @@ SECTIONS | |||
107 | . = ALIGN(2); | 107 | . = ALIGN(2); |
108 | __initramfs_end = .; | 108 | __initramfs_end = .; |
109 | #endif | 109 | #endif |
110 | . = ALIGN(4096); | 110 | PERCPU(4096) |
111 | __per_cpu_start = .; | ||
112 | .data.percpu : { *(.data.percpu) } | ||
113 | __per_cpu_end = .; | ||
114 | . = ALIGN(4096); | 111 | . = ALIGN(4096); |
115 | __init_end = .; | 112 | __init_end = .; |
116 | /* freed after init ends here */ | 113 | /* freed after init ends here */ |
diff --git a/arch/sh/kernel/vmlinux.lds.S b/arch/sh/kernel/vmlinux.lds.S index 0696402f44..5ba216180b 100644 --- a/arch/sh/kernel/vmlinux.lds.S +++ b/arch/sh/kernel/vmlinux.lds.S | |||
@@ -60,10 +60,7 @@ SECTIONS | |||
60 | . = ALIGN(PAGE_SIZE); | 60 | . = ALIGN(PAGE_SIZE); |
61 | __nosave_end = .; | 61 | __nosave_end = .; |
62 | 62 | ||
63 | . = ALIGN(PAGE_SIZE); | 63 | PERCPU(PAGE_SIZE) |
64 | __per_cpu_start = .; | ||
65 | .data.percpu : { *(.data.percpu) } | ||
66 | __per_cpu_end = .; | ||
67 | .data.cacheline_aligned : { *(.data.cacheline_aligned) } | 64 | .data.cacheline_aligned : { *(.data.cacheline_aligned) } |
68 | 65 | ||
69 | _edata = .; /* End of data section */ | 66 | _edata = .; /* End of data section */ |
diff --git a/arch/sh64/kernel/vmlinux.lds.S b/arch/sh64/kernel/vmlinux.lds.S index 02aea86c59..8ac9c7c5f8 100644 --- a/arch/sh64/kernel/vmlinux.lds.S +++ b/arch/sh64/kernel/vmlinux.lds.S | |||
@@ -87,7 +87,10 @@ SECTIONS | |||
87 | 87 | ||
88 | . = ALIGN(PAGE_SIZE); | 88 | . = ALIGN(PAGE_SIZE); |
89 | __per_cpu_start = .; | 89 | __per_cpu_start = .; |
90 | .data.percpu : C_PHYS(.data.percpu) { *(.data.percpu) } | 90 | .data.percpu : C_PHYS(.data.percpu) { |
91 | *(.data.percpu) | ||
92 | *(.data.percpu.shared_aligned) | ||
93 | } | ||
91 | __per_cpu_end = . ; | 94 | __per_cpu_end = . ; |
92 | .data.cacheline_aligned : C_PHYS(.data.cacheline_aligned) { *(.data.cacheline_aligned) } | 95 | .data.cacheline_aligned : C_PHYS(.data.cacheline_aligned) { *(.data.cacheline_aligned) } |
93 | 96 | ||
diff --git a/arch/sparc/kernel/vmlinux.lds.S b/arch/sparc/kernel/vmlinux.lds.S index f75a1b8227..47583887ab 100644 --- a/arch/sparc/kernel/vmlinux.lds.S +++ b/arch/sparc/kernel/vmlinux.lds.S | |||
@@ -65,10 +65,7 @@ SECTIONS | |||
65 | __initramfs_end = .; | 65 | __initramfs_end = .; |
66 | #endif | 66 | #endif |
67 | 67 | ||
68 | . = ALIGN(4096); | 68 | PERCPU(4096) |
69 | __per_cpu_start = .; | ||
70 | .data.percpu : { *(.data.percpu) } | ||
71 | __per_cpu_end = .; | ||
72 | . = ALIGN(4096); | 69 | . = ALIGN(4096); |
73 | __init_end = .; | 70 | __init_end = .; |
74 | . = ALIGN(32); | 71 | . = ALIGN(32); |
diff --git a/arch/sparc64/kernel/vmlinux.lds.S b/arch/sparc64/kernel/vmlinux.lds.S index 3ad10f3027..481861764d 100644 --- a/arch/sparc64/kernel/vmlinux.lds.S +++ b/arch/sparc64/kernel/vmlinux.lds.S | |||
@@ -90,10 +90,8 @@ SECTIONS | |||
90 | __initramfs_end = .; | 90 | __initramfs_end = .; |
91 | #endif | 91 | #endif |
92 | 92 | ||
93 | . = ALIGN(PAGE_SIZE); | 93 | PERCPU(PAGE_SIZE) |
94 | __per_cpu_start = .; | 94 | |
95 | .data.percpu : { *(.data.percpu) } | ||
96 | __per_cpu_end = .; | ||
97 | . = ALIGN(PAGE_SIZE); | 95 | . = ALIGN(PAGE_SIZE); |
98 | __init_end = .; | 96 | __init_end = .; |
99 | __bss_start = .; | 97 | __bss_start = .; |
diff --git a/arch/x86_64/kernel/vmlinux.lds.S b/arch/x86_64/kernel/vmlinux.lds.S index dbccfda836..22590690a8 100644 --- a/arch/x86_64/kernel/vmlinux.lds.S +++ b/arch/x86_64/kernel/vmlinux.lds.S | |||
@@ -194,10 +194,8 @@ SECTIONS | |||
194 | __initramfs_end = .; | 194 | __initramfs_end = .; |
195 | #endif | 195 | #endif |
196 | 196 | ||
197 | . = ALIGN(4096); | 197 | PERCPU(4096) |
198 | __per_cpu_start = .; | 198 | |
199 | .data.percpu : AT(ADDR(.data.percpu) - LOAD_OFFSET) { *(.data.percpu) } | ||
200 | __per_cpu_end = .; | ||
201 | . = ALIGN(4096); | 199 | . = ALIGN(4096); |
202 | __init_end = .; | 200 | __init_end = .; |
203 | 201 | ||
diff --git a/arch/xtensa/kernel/vmlinux.lds.S b/arch/xtensa/kernel/vmlinux.lds.S index b0582c3c5f..3e31512109 100644 --- a/arch/xtensa/kernel/vmlinux.lds.S +++ b/arch/xtensa/kernel/vmlinux.lds.S | |||
@@ -190,10 +190,7 @@ SECTIONS | |||
190 | __initramfs_end = .; | 190 | __initramfs_end = .; |
191 | #endif | 191 | #endif |
192 | 192 | ||
193 | . = ALIGN(4096); | 193 | PERCPU(4096) |
194 | __per_cpu_start = .; | ||
195 | .data.percpu : { *(.data.percpu) } | ||
196 | __per_cpu_end = .; | ||
197 | 194 | ||
198 | 195 | ||
199 | /* We need this dummy segment here */ | 196 | /* We need this dummy segment here */ |