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 [ ] ;
2005-06-23 00:08:18 -07:00
extern unsigned char pci_bus_to_node [ ] ;
2005-04-16 15:20:36 -07:00
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)
# define node_to_first_cpu(node) (__ffs(node_to_cpumask[node]))
# define node_to_cpumask(node) (node_to_cpumask[node])
2005-06-23 00:08:18 -07:00
# define pcibus_to_node(bus) pci_bus_to_node[(bus)->number]
# define pcibus_to_cpumask(bus) node_to_cpumask(pcibus_to_node(bus));
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 , \
. cache_hot_time = ( 10 * 1000000 ) , \
2005-06-25 14:57:13 -07:00
. cache_nice_tries = 2 , \
. busy_idx = 3 , \
. idle_idx = 2 , \
. newidle_idx = 1 , \
. wake_idx = 1 , \
2005-04-16 15:20:36 -07:00
. per_cpu_gain = 100 , \
. flags = SD_LOAD_BALANCE \
| SD_BALANCE_NEWIDLE \
| SD_BALANCE_EXEC \
| SD_WAKE_BALANCE , \
. last_balance = jiffies , \
. balance_interval = 1 , \
. nr_balance_failed = 0 , \
}
# endif
# include <asm-generic/topology.h>
# endif