2005-04-16 15:20:36 -07:00
# ifndef _ASM_X86_64_TOPOLOGY_H
# define _ASM_X86_64_TOPOLOGY_H
# include <linux/config.h>
2005-06-23 00:08:06 -07:00
# ifdef CONFIG_NUMA
2005-04-16 15:20:36 -07:00
# include <asm/mpspec.h>
# include <asm/bitops.h>
/* Map the K8 CPU local memory controllers to a simple 1:1 CPU:NODE topology */
extern cpumask_t cpu_online_map ;
extern unsigned char cpu_to_node [ ] ;
extern cpumask_t node_to_cpumask [ ] ;
# ifdef CONFIG_ACPI_NUMA
extern int __node_distance ( int , int ) ;
# define node_distance(a,b) __node_distance(a,b)
/* #else fallback version */
# endif
# define cpu_to_node(cpu) (cpu_to_node[cpu])
# define parent_node(node) (node)
2005-12-22 14:21:34 -08:00
# define node_to_first_cpu(node) (first_cpu(node_to_cpumask[node]))
2005-04-16 15:20:36 -07:00
# define node_to_cpumask(node) (node_to_cpumask[node])
2005-09-12 18:49:24 +02:00
# define pcibus_to_node(bus) ((long)(bus->sysdata))
2005-06-23 00:08:18 -07:00
# define pcibus_to_cpumask(bus) node_to_cpumask(pcibus_to_node(bus));
2005-04-16 15:20:36 -07:00
2005-11-05 17:25:53 +01:00
# define numa_node_id() read_pda(nodenumber)
2005-04-16 15:20:36 -07:00
/* sched_domains SD_NODE_INIT for x86_64 machines */
# define SD_NODE_INIT (struct sched_domain) { \
. span = CPU_MASK_NONE , \
. parent = NULL , \
. groups = NULL , \
. min_interval = 8 , \
. max_interval = 32 , \
. busy_factor = 32 , \
. imbalance_pct = 125 , \
2005-06-25 14:57:13 -07:00
. cache_nice_tries = 2 , \
. busy_idx = 3 , \
. idle_idx = 2 , \
2005-06-25 14:57:21 -07:00
. newidle_idx = 0 , \
2005-06-25 14:57:13 -07:00
. wake_idx = 1 , \
2005-06-25 14:57:19 -07:00
. forkexec_idx = 1 , \
2005-04-16 15:20:36 -07:00
. per_cpu_gain = 100 , \
. flags = SD_LOAD_BALANCE \
2005-06-25 14:57:19 -07:00
| SD_BALANCE_FORK \
2005-04-16 15:20:36 -07:00
| SD_BALANCE_EXEC \
| SD_WAKE_BALANCE , \
. last_balance = jiffies , \
. balance_interval = 1 , \
. nr_balance_failed = 0 , \
}
# endif
# include <asm-generic/topology.h>
# endif