Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #ifndef _ASM_X86_64_TOPOLOGY_H |
| 2 | #define _ASM_X86_64_TOPOLOGY_H |
| 3 | |
| 4 | #include <linux/config.h> |
| 5 | |
Matt Tolentino | 2b97690 | 2005-06-23 00:08:06 -0700 | [diff] [blame] | 6 | #ifdef CONFIG_NUMA |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 7 | |
| 8 | #include <asm/mpspec.h> |
| 9 | #include <asm/bitops.h> |
| 10 | |
| 11 | /* Map the K8 CPU local memory controllers to a simple 1:1 CPU:NODE topology */ |
| 12 | |
| 13 | extern cpumask_t cpu_online_map; |
| 14 | |
| 15 | extern unsigned char cpu_to_node[]; |
| 16 | extern cpumask_t node_to_cpumask[]; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 17 | |
| 18 | #ifdef CONFIG_ACPI_NUMA |
| 19 | extern int __node_distance(int, int); |
| 20 | #define node_distance(a,b) __node_distance(a,b) |
| 21 | /* #else fallback version */ |
| 22 | #endif |
| 23 | |
| 24 | #define cpu_to_node(cpu) (cpu_to_node[cpu]) |
| 25 | #define parent_node(node) (node) |
Ravikiran G Thirumalai | c660439 | 2005-12-22 14:21:34 -0800 | [diff] [blame] | 26 | #define node_to_first_cpu(node) (first_cpu(node_to_cpumask[node])) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 27 | #define node_to_cpumask(node) (node_to_cpumask[node]) |
Andi Kleen | 69e1a33 | 2005-09-12 18:49:24 +0200 | [diff] [blame] | 28 | #define pcibus_to_node(bus) ((long)(bus->sysdata)) |
Christoph Lameter | 8c5a090 | 2005-06-23 00:08:18 -0700 | [diff] [blame] | 29 | #define pcibus_to_cpumask(bus) node_to_cpumask(pcibus_to_node(bus)); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 30 | |
Andi Kleen | 69d81fc | 2005-11-05 17:25:53 +0100 | [diff] [blame] | 31 | #define numa_node_id() read_pda(nodenumber) |
| 32 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 33 | /* sched_domains SD_NODE_INIT for x86_64 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, \ |
Nick Piggin | 7897986 | 2005-06-25 14:57:13 -0700 | [diff] [blame] | 42 | .cache_nice_tries = 2, \ |
| 43 | .busy_idx = 3, \ |
| 44 | .idle_idx = 2, \ |
Nick Piggin | 687f166 | 2005-06-25 14:57:21 -0700 | [diff] [blame] | 45 | .newidle_idx = 0, \ |
Nick Piggin | 7897986 | 2005-06-25 14:57:13 -0700 | [diff] [blame] | 46 | .wake_idx = 1, \ |
Nick Piggin | 147cbb4 | 2005-06-25 14:57:19 -0700 | [diff] [blame] | 47 | .forkexec_idx = 1, \ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 48 | .per_cpu_gain = 100, \ |
| 49 | .flags = SD_LOAD_BALANCE \ |
Nick Piggin | 147cbb4 | 2005-06-25 14:57:19 -0700 | [diff] [blame] | 50 | | SD_BALANCE_FORK \ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 51 | | SD_BALANCE_EXEC \ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 52 | | SD_WAKE_BALANCE, \ |
| 53 | .last_balance = jiffies, \ |
| 54 | .balance_interval = 1, \ |
| 55 | .nr_balance_failed = 0, \ |
| 56 | } |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 57 | |
| 58 | #endif |
| 59 | |
Zhang, Yanmin | 69dcc99 | 2006-02-03 03:04:36 -0800 | [diff] [blame] | 60 | #ifdef CONFIG_SMP |
| 61 | #define topology_physical_package_id(cpu) \ |
| 62 | (phys_proc_id[cpu] == BAD_APICID ? -1 : phys_proc_id[cpu]) |
| 63 | #define topology_core_id(cpu) \ |
| 64 | (cpu_core_id[cpu] == BAD_APICID ? 0 : cpu_core_id[cpu]) |
| 65 | #define topology_core_siblings(cpu) (cpu_core_map[cpu]) |
| 66 | #define topology_thread_siblings(cpu) (cpu_sibling_map[cpu]) |
| 67 | #endif |
| 68 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 69 | #include <asm-generic/topology.h> |
| 70 | |
| 71 | #endif |