aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2009-08-14 02:00:50 -0400
committerTejun Heo <tj@kernel.org>2009-08-14 02:00:50 -0400
commit9a7737691e90d3cce0e5248f91826c50e5aa3fcf (patch)
treedbe43cb2d2a19539ca3fb58c52e4cbd68b51d24b /arch/x86/kernel
parentf58dc01ba2ca9fe3ab2ba4ca43d9c8a735cf62d8 (diff)
percpu: drop @static_size from first chunk allocators
First chunk allocators assume percpu areas have been linked using one of PERCPU_*() macros and depend on __per_cpu_load symbol defined by those macros, so there isn't much point in passing in static area size explicitly when it can be easily calculated from __per_cpu_start and __per_cpu_end. Drop @static_size from all percpu first chunk allocators and helpers. Signed-off-by: Tejun Heo <tj@kernel.org>
Diffstat (limited to 'arch/x86/kernel')
-rw-r--r--arch/x86/kernel/setup_percpu.c34
1 files changed, 15 insertions, 19 deletions
diff --git a/arch/x86/kernel/setup_percpu.c b/arch/x86/kernel/setup_percpu.c
index b961d99e6416..8aad486c688f 100644
--- a/arch/x86/kernel/setup_percpu.c
+++ b/arch/x86/kernel/setup_percpu.c
@@ -157,7 +157,7 @@ static int pcpu_lpage_cpu_distance(unsigned int from, unsigned int to)
157 return REMOTE_DISTANCE; 157 return REMOTE_DISTANCE;
158} 158}
159 159
160static ssize_t __init setup_pcpu_lpage(size_t static_size, bool chosen) 160static ssize_t __init setup_pcpu_lpage(bool chosen)
161{ 161{
162 size_t reserve = PERCPU_MODULE_RESERVE + PERCPU_DYNAMIC_RESERVE; 162 size_t reserve = PERCPU_MODULE_RESERVE + PERCPU_DYNAMIC_RESERVE;
163 size_t dyn_size = reserve - PERCPU_FIRST_CHUNK_RESERVE; 163 size_t dyn_size = reserve - PERCPU_FIRST_CHUNK_RESERVE;
@@ -184,8 +184,7 @@ static ssize_t __init setup_pcpu_lpage(size_t static_size, bool chosen)
184 return -ENOMEM; 184 return -ENOMEM;
185 } 185 }
186 186
187 ret = pcpu_lpage_build_unit_map(static_size, 187 ret = pcpu_lpage_build_unit_map(PERCPU_FIRST_CHUNK_RESERVE,
188 PERCPU_FIRST_CHUNK_RESERVE,
189 &dyn_size, &unit_size, PMD_SIZE, 188 &dyn_size, &unit_size, PMD_SIZE,
190 unit_map, pcpu_lpage_cpu_distance); 189 unit_map, pcpu_lpage_cpu_distance);
191 if (ret < 0) { 190 if (ret < 0) {
@@ -208,9 +207,8 @@ static ssize_t __init setup_pcpu_lpage(size_t static_size, bool chosen)
208 } 207 }
209 } 208 }
210 209
211 ret = pcpu_lpage_first_chunk(static_size, PERCPU_FIRST_CHUNK_RESERVE, 210 ret = pcpu_lpage_first_chunk(PERCPU_FIRST_CHUNK_RESERVE, dyn_size,
212 dyn_size, unit_size, PMD_SIZE, 211 unit_size, PMD_SIZE, unit_map, nr_units,
213 unit_map, nr_units,
214 pcpu_fc_alloc, pcpu_fc_free, pcpul_map); 212 pcpu_fc_alloc, pcpu_fc_free, pcpul_map);
215out_free: 213out_free:
216 if (ret < 0) 214 if (ret < 0)
@@ -218,7 +216,7 @@ out_free:
218 return ret; 216 return ret;
219} 217}
220#else 218#else
221static ssize_t __init setup_pcpu_lpage(size_t static_size, bool chosen) 219static ssize_t __init setup_pcpu_lpage(bool chosen)
222{ 220{
223 return -EINVAL; 221 return -EINVAL;
224} 222}
@@ -232,7 +230,7 @@ static ssize_t __init setup_pcpu_lpage(size_t static_size, bool chosen)
232 * mapping so that it can use PMD mapping without additional TLB 230 * mapping so that it can use PMD mapping without additional TLB
233 * pressure. 231 * pressure.
234 */ 232 */
235static ssize_t __init setup_pcpu_embed(size_t static_size, bool chosen) 233static ssize_t __init setup_pcpu_embed(bool chosen)
236{ 234{
237 size_t reserve = PERCPU_MODULE_RESERVE + PERCPU_DYNAMIC_RESERVE; 235 size_t reserve = PERCPU_MODULE_RESERVE + PERCPU_DYNAMIC_RESERVE;
238 236
@@ -244,7 +242,7 @@ static ssize_t __init setup_pcpu_embed(size_t static_size, bool chosen)
244 if (!chosen && (!cpu_has_pse || pcpu_need_numa())) 242 if (!chosen && (!cpu_has_pse || pcpu_need_numa()))
245 return -EINVAL; 243 return -EINVAL;
246 244
247 return pcpu_embed_first_chunk(static_size, PERCPU_FIRST_CHUNK_RESERVE, 245 return pcpu_embed_first_chunk(PERCPU_FIRST_CHUNK_RESERVE,
248 reserve - PERCPU_FIRST_CHUNK_RESERVE); 246 reserve - PERCPU_FIRST_CHUNK_RESERVE);
249} 247}
250 248
@@ -260,9 +258,9 @@ static void __init pcpup_populate_pte(unsigned long addr)
260 populate_extra_pte(addr); 258 populate_extra_pte(addr);
261} 259}
262 260
263static ssize_t __init setup_pcpu_page(size_t static_size) 261static ssize_t __init setup_pcpu_page(void)
264{ 262{
265 return pcpu_page_first_chunk(static_size, PERCPU_FIRST_CHUNK_RESERVE, 263 return pcpu_page_first_chunk(PERCPU_FIRST_CHUNK_RESERVE,
266 pcpu_fc_alloc, pcpu_fc_free, 264 pcpu_fc_alloc, pcpu_fc_free,
267 pcpup_populate_pte); 265 pcpup_populate_pte);
268} 266}
@@ -282,7 +280,6 @@ static inline void setup_percpu_segment(int cpu)
282 280
283void __init setup_per_cpu_areas(void) 281void __init setup_per_cpu_areas(void)
284{ 282{
285 size_t static_size = __per_cpu_end - __per_cpu_start;
286 unsigned int cpu; 283 unsigned int cpu;
287 unsigned long delta; 284 unsigned long delta;
288 size_t pcpu_unit_size; 285 size_t pcpu_unit_size;
@@ -300,9 +297,9 @@ void __init setup_per_cpu_areas(void)
300 if (pcpu_chosen_fc != PCPU_FC_AUTO) { 297 if (pcpu_chosen_fc != PCPU_FC_AUTO) {
301 if (pcpu_chosen_fc != PCPU_FC_PAGE) { 298 if (pcpu_chosen_fc != PCPU_FC_PAGE) {
302 if (pcpu_chosen_fc == PCPU_FC_LPAGE) 299 if (pcpu_chosen_fc == PCPU_FC_LPAGE)
303 ret = setup_pcpu_lpage(static_size, true); 300 ret = setup_pcpu_lpage(true);
304 else 301 else
305 ret = setup_pcpu_embed(static_size, true); 302 ret = setup_pcpu_embed(true);
306 303
307 if (ret < 0) 304 if (ret < 0)
308 pr_warning("PERCPU: %s allocator failed (%zd), " 305 pr_warning("PERCPU: %s allocator failed (%zd), "
@@ -310,15 +307,14 @@ void __init setup_per_cpu_areas(void)
310 pcpu_fc_names[pcpu_chosen_fc], ret); 307 pcpu_fc_names[pcpu_chosen_fc], ret);
311 } 308 }
312 } else { 309 } else {
313 ret = setup_pcpu_lpage(static_size, false); 310 ret = setup_pcpu_lpage(false);
314 if (ret < 0) 311 if (ret < 0)
315 ret = setup_pcpu_embed(static_size, false); 312 ret = setup_pcpu_embed(false);
316 } 313 }
317 if (ret < 0) 314 if (ret < 0)
318 ret = setup_pcpu_page(static_size); 315 ret = setup_pcpu_page();
319 if (ret < 0) 316 if (ret < 0)
320 panic("cannot allocate static percpu area (%zu bytes, err=%zd)", 317 panic("cannot initialize percpu area (err=%zd)", ret);
321 static_size, ret);
322 318
323 pcpu_unit_size = ret; 319 pcpu_unit_size = ret;
324 320