diff options
| -rw-r--r-- | arch/powerpc/kernel/smp.c | 23 | ||||
| -rw-r--r-- | include/asm-powerpc/smp.h | 1 | ||||
| -rw-r--r-- | include/asm-powerpc/topology.h | 1 |
3 files changed, 25 insertions, 0 deletions
diff --git a/arch/powerpc/kernel/smp.c b/arch/powerpc/kernel/smp.c index f7a2f81b5b7d..5337ca7bb649 100644 --- a/arch/powerpc/kernel/smp.c +++ b/arch/powerpc/kernel/smp.c | |||
| @@ -380,6 +380,29 @@ int __cpuinit __cpu_up(unsigned int cpu) | |||
| 380 | return 0; | 380 | return 0; |
| 381 | } | 381 | } |
| 382 | 382 | ||
| 383 | /* Return the value of the reg property corresponding to the given | ||
| 384 | * logical cpu. | ||
| 385 | */ | ||
| 386 | int cpu_to_core_id(int cpu) | ||
| 387 | { | ||
| 388 | struct device_node *np; | ||
| 389 | const int *reg; | ||
| 390 | int id = -1; | ||
| 391 | |||
| 392 | np = of_get_cpu_node(cpu, NULL); | ||
| 393 | if (!np) | ||
| 394 | goto out; | ||
| 395 | |||
| 396 | reg = of_get_property(np, "reg", NULL); | ||
| 397 | if (!reg) | ||
| 398 | goto out; | ||
| 399 | |||
| 400 | id = *reg; | ||
| 401 | out: | ||
| 402 | of_node_put(np); | ||
| 403 | return id; | ||
| 404 | } | ||
| 405 | |||
| 383 | /* Must be called when no change can occur to cpu_present_map, | 406 | /* Must be called when no change can occur to cpu_present_map, |
| 384 | * i.e. during cpu online or offline. | 407 | * i.e. during cpu online or offline. |
| 385 | */ | 408 | */ |
diff --git a/include/asm-powerpc/smp.h b/include/asm-powerpc/smp.h index 32e910006250..4d28e1e4521b 100644 --- a/include/asm-powerpc/smp.h +++ b/include/asm-powerpc/smp.h | |||
| @@ -63,6 +63,7 @@ extern int smp_hw_index[]; | |||
| 63 | 63 | ||
| 64 | DECLARE_PER_CPU(cpumask_t, cpu_sibling_map); | 64 | DECLARE_PER_CPU(cpumask_t, cpu_sibling_map); |
| 65 | DECLARE_PER_CPU(cpumask_t, cpu_core_map); | 65 | DECLARE_PER_CPU(cpumask_t, cpu_core_map); |
| 66 | extern int cpu_to_core_id(int cpu); | ||
| 66 | 67 | ||
| 67 | /* Since OpenPIC has only 4 IPIs, we use slightly different message numbers. | 68 | /* Since OpenPIC has only 4 IPIs, we use slightly different message numbers. |
| 68 | * | 69 | * |
diff --git a/include/asm-powerpc/topology.h b/include/asm-powerpc/topology.h index f00e8e551738..c32da6f97999 100644 --- a/include/asm-powerpc/topology.h +++ b/include/asm-powerpc/topology.h | |||
| @@ -109,6 +109,7 @@ static inline void sysfs_remove_device_from_node(struct sys_device *dev, | |||
| 109 | 109 | ||
| 110 | #define topology_thread_siblings(cpu) (per_cpu(cpu_sibling_map, cpu)) | 110 | #define topology_thread_siblings(cpu) (per_cpu(cpu_sibling_map, cpu)) |
| 111 | #define topology_core_siblings(cpu) (per_cpu(cpu_core_map, cpu)) | 111 | #define topology_core_siblings(cpu) (per_cpu(cpu_core_map, cpu)) |
| 112 | #define topology_core_id(cpu) (cpu_to_core_id(cpu)) | ||
| 112 | #endif | 113 | #endif |
| 113 | #endif | 114 | #endif |
| 114 | 115 | ||
