-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
yaml --- r: 88808 b: refs/heads/master c: 4fe29a8 h: refs/heads/master v: v3
- Loading branch information
Glauber de Oliveira Costa
authored and
Ingo Molnar
committed
Apr 17, 2008
1 parent
73c1a75
commit 9cc2525
Showing
6 changed files
with
108 additions
and
80 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,2 @@ | ||
--- | ||
refs/heads/master: fbac7fcbadc54cc5d374873a2e60e924a056d198 | ||
refs/heads/master: 4fe29a85642544503cf81e9cf251ef0f4e65b162 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,103 @@ | ||
#include <linux/kernel.h> | ||
#include <linux/module.h> | ||
#include <linux/init.h> | ||
#include <linux/bootmem.h> | ||
#include <linux/percpu.h> | ||
#include <asm/smp.h> | ||
#include <asm/percpu.h> | ||
#include <asm/sections.h> | ||
#include <asm/processor.h> | ||
#include <asm/setup.h> | ||
#include <asm/topology.h> | ||
|
||
#ifdef CONFIG_HAVE_SETUP_PER_CPU_AREA | ||
/* | ||
* Copy data used in early init routines from the initial arrays to the | ||
* per cpu data areas. These arrays then become expendable and the | ||
* *_early_ptr's are zeroed indicating that the static arrays are gone. | ||
*/ | ||
static void __init setup_per_cpu_maps(void) | ||
{ | ||
int cpu; | ||
|
||
for_each_possible_cpu(cpu) { | ||
#ifdef CONFIG_SMP | ||
if (per_cpu_offset(cpu)) { | ||
#endif | ||
per_cpu(x86_cpu_to_apicid, cpu) = | ||
x86_cpu_to_apicid_init[cpu]; | ||
per_cpu(x86_bios_cpu_apicid, cpu) = | ||
x86_bios_cpu_apicid_init[cpu]; | ||
#ifdef CONFIG_NUMA | ||
per_cpu(x86_cpu_to_node_map, cpu) = | ||
x86_cpu_to_node_map_init[cpu]; | ||
#endif | ||
#ifdef CONFIG_SMP | ||
} else | ||
printk(KERN_NOTICE "per_cpu_offset zero for cpu %d\n", | ||
cpu); | ||
#endif | ||
} | ||
|
||
/* indicate the early static arrays will soon be gone */ | ||
x86_cpu_to_apicid_early_ptr = NULL; | ||
x86_bios_cpu_apicid_early_ptr = NULL; | ||
#ifdef CONFIG_NUMA | ||
x86_cpu_to_node_map_early_ptr = NULL; | ||
#endif | ||
} | ||
|
||
#ifdef CONFIG_X86_32 | ||
/* | ||
* Great future not-so-futuristic plan: make i386 and x86_64 do it | ||
* the same way | ||
*/ | ||
unsigned long __per_cpu_offset[NR_CPUS] __read_mostly; | ||
EXPORT_SYMBOL(__per_cpu_offset); | ||
#endif | ||
|
||
/* | ||
* Great future plan: | ||
* Declare PDA itself and support (irqstack,tss,pgd) as per cpu data. | ||
* Always point %gs to its beginning | ||
*/ | ||
void __init setup_per_cpu_areas(void) | ||
{ | ||
int i; | ||
unsigned long size; | ||
|
||
#ifdef CONFIG_HOTPLUG_CPU | ||
prefill_possible_map(); | ||
#endif | ||
|
||
/* Copy section for each CPU (we discard the original) */ | ||
size = PERCPU_ENOUGH_ROOM; | ||
|
||
printk(KERN_INFO "PERCPU: Allocating %lu bytes of per cpu data\n", | ||
size); | ||
for_each_cpu_mask(i, cpu_possible_map) { | ||
char *ptr; | ||
#ifndef CONFIG_NEED_MULTIPLE_NODES | ||
ptr = alloc_bootmem_pages(size); | ||
#else | ||
int node = early_cpu_to_node(i); | ||
if (!node_online(node) || !NODE_DATA(node)) | ||
ptr = alloc_bootmem_pages(size); | ||
else | ||
ptr = alloc_bootmem_pages_node(NODE_DATA(node), size); | ||
#endif | ||
if (!ptr) | ||
panic("Cannot allocate cpu data for CPU %d\n", i); | ||
#ifdef CONFIG_X86_64 | ||
cpu_pda(i)->data_offset = ptr - __per_cpu_start; | ||
#else | ||
__per_cpu_offset[i] = ptr - __per_cpu_start; | ||
#endif | ||
memcpy(ptr, __per_cpu_start, __per_cpu_end - __per_cpu_start); | ||
} | ||
|
||
/* setup percpu data maps early */ | ||
setup_per_cpu_maps(); | ||
} | ||
|
||
#endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters