|
@@ -118,7 +118,7 @@ static const struct file_operations acpi_processor_info_fops = {
|
|
|
.release = single_release,
|
|
|
};
|
|
|
|
|
|
-struct acpi_processor *processors[NR_CPUS];
|
|
|
+DEFINE_PER_CPU(struct acpi_processor *, processors);
|
|
|
struct acpi_processor_errata errata __read_mostly;
|
|
|
|
|
|
/* --------------------------------------------------------------------------
|
|
@@ -614,7 +614,7 @@ static int acpi_processor_get_info(struct acpi_processor *pr, unsigned has_uid)
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
-static void *processor_device_array[NR_CPUS];
|
|
|
+static DEFINE_PER_CPU(void *, processor_device_array);
|
|
|
|
|
|
static int __cpuinit acpi_processor_start(struct acpi_device *device)
|
|
|
{
|
|
@@ -638,15 +638,15 @@ static int __cpuinit acpi_processor_start(struct acpi_device *device)
|
|
|
* ACPI id of processors can be reported wrongly by the BIOS.
|
|
|
* Don't trust it blindly
|
|
|
*/
|
|
|
- if (processor_device_array[pr->id] != NULL &&
|
|
|
- processor_device_array[pr->id] != device) {
|
|
|
+ if (per_cpu(processor_device_array, pr->id) != NULL &&
|
|
|
+ per_cpu(processor_device_array, pr->id) != device) {
|
|
|
printk(KERN_WARNING "BIOS reported wrong ACPI id "
|
|
|
"for the processor\n");
|
|
|
return -ENODEV;
|
|
|
}
|
|
|
- processor_device_array[pr->id] = device;
|
|
|
+ per_cpu(processor_device_array, pr->id) = device;
|
|
|
|
|
|
- processors[pr->id] = pr;
|
|
|
+ per_cpu(processors, pr->id) = pr;
|
|
|
|
|
|
result = acpi_processor_add_fs(device);
|
|
|
if (result)
|
|
@@ -753,7 +753,7 @@ static int acpi_cpu_soft_notify(struct notifier_block *nfb,
|
|
|
unsigned long action, void *hcpu)
|
|
|
{
|
|
|
unsigned int cpu = (unsigned long)hcpu;
|
|
|
- struct acpi_processor *pr = processors[cpu];
|
|
|
+ struct acpi_processor *pr = per_cpu(processors, cpu);
|
|
|
|
|
|
if (action == CPU_ONLINE && pr) {
|
|
|
acpi_processor_ppc_has_changed(pr);
|
|
@@ -825,8 +825,8 @@ static int acpi_processor_remove(struct acpi_device *device, int type)
|
|
|
pr->cdev = NULL;
|
|
|
}
|
|
|
|
|
|
- processors[pr->id] = NULL;
|
|
|
- processor_device_array[pr->id] = NULL;
|
|
|
+ per_cpu(processors, pr->id) = NULL;
|
|
|
+ per_cpu(processor_device_array, pr->id) = NULL;
|
|
|
kfree(pr);
|
|
|
|
|
|
return 0;
|
|
@@ -1074,8 +1074,6 @@ static int __init acpi_processor_init(void)
|
|
|
{
|
|
|
int result = 0;
|
|
|
|
|
|
-
|
|
|
- memset(&processors, 0, sizeof(processors));
|
|
|
memset(&errata, 0, sizeof(errata));
|
|
|
|
|
|
#ifdef CONFIG_SMP
|