blob: 1e19cd00af25856445a44912051964b1fe456671 [file] [log] [blame]
jdl@freescale.comdd56fdf2005-09-07 15:59:48 -05001#ifndef _ASM_POWERPC_TOPOLOGY_H
2#define _ASM_POWERPC_TOPOLOGY_H
Arnd Bergmann88ced032005-12-16 22:43:46 +01003#ifdef __KERNEL__
Linus Torvalds1da177e2005-04-16 15:20:36 -07004
5#include <linux/config.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07006
7#ifdef CONFIG_NUMA
8
jdl@freescale.comdd56fdf2005-09-07 15:59:48 -05009#include <asm/mmzone.h>
10
Linus Torvalds1da177e2005-04-16 15:20:36 -070011static inline int cpu_to_node(int cpu)
12{
Anton Blanchard45fb6ce2005-11-11 14:22:35 +110013 return numa_cpu_lookup_table[cpu];
Linus Torvalds1da177e2005-04-16 15:20:36 -070014}
15
16#define parent_node(node) (node)
17
18static inline cpumask_t node_to_cpumask(int node)
19{
20 return numa_cpumask_lookup_table[node];
21}
22
23static inline int node_to_first_cpu(int node)
24{
25 cpumask_t tmp;
26 tmp = node_to_cpumask(node);
27 return first_cpu(tmp);
28}
29
Anton Blanchard561fb7652005-08-01 21:11:46 -070030#define pcibus_to_node(node) (-1)
Linus Torvalds1da177e2005-04-16 15:20:36 -070031#define pcibus_to_cpumask(bus) (cpu_online_map)
32
Linus Torvalds1da177e2005-04-16 15:20:36 -070033/* sched_domains SD_NODE_INIT for PPC64 machines */
34#define SD_NODE_INIT (struct sched_domain) { \
35 .span = CPU_MASK_NONE, \
36 .parent = NULL, \
37 .groups = NULL, \
38 .min_interval = 8, \
39 .max_interval = 32, \
40 .busy_factor = 32, \
41 .imbalance_pct = 125, \
Linus Torvalds1da177e2005-04-16 15:20:36 -070042 .cache_nice_tries = 1, \
43 .per_cpu_gain = 100, \
Nick Piggin5cfccd72005-11-16 23:37:53 +110044 .busy_idx = 3, \
Michael Ellermand2a33172005-11-17 20:34:35 +110045 .idle_idx = 1, \
Nick Piggin5cfccd72005-11-16 23:37:53 +110046 .newidle_idx = 2, \
47 .wake_idx = 1, \
Linus Torvalds1da177e2005-04-16 15:20:36 -070048 .flags = SD_LOAD_BALANCE \
49 | SD_BALANCE_EXEC \
50 | SD_BALANCE_NEWIDLE \
51 | SD_WAKE_IDLE \
52 | SD_WAKE_BALANCE, \
53 .last_balance = jiffies, \
54 .balance_interval = 1, \
55 .nr_balance_failed = 0, \
56}
57
Anton Blanchard4b703a22005-12-13 06:56:47 +110058extern void __init dump_numa_cpu_topology(void);
59
Anton Blanchard561fb7652005-08-01 21:11:46 -070060#else
Linus Torvalds1da177e2005-04-16 15:20:36 -070061
Anton Blanchard4b703a22005-12-13 06:56:47 +110062static inline void dump_numa_cpu_topology(void) {}
63
Linus Torvalds1da177e2005-04-16 15:20:36 -070064#include <asm-generic/topology.h>
65
Anton Blanchard561fb7652005-08-01 21:11:46 -070066#endif /* CONFIG_NUMA */
67
Arnd Bergmann88ced032005-12-16 22:43:46 +010068#endif /* __KERNEL__ */
jdl@freescale.comdd56fdf2005-09-07 15:59:48 -050069#endif /* _ASM_POWERPC_TOPOLOGY_H */