x86/xen: resume timer irqs early
[linux/fpc-iii.git] / arch / alpha / include / asm / topology.h
blob9251e13e144f668d0749528a8ffa2a89497f5730
1 #ifndef _ASM_ALPHA_TOPOLOGY_H
2 #define _ASM_ALPHA_TOPOLOGY_H
4 #include <linux/smp.h>
5 #include <linux/threads.h>
6 #include <asm/machvec.h>
8 #ifdef CONFIG_NUMA
9 static inline int cpu_to_node(int cpu)
11 int node;
13 if (!alpha_mv.cpuid_to_nid)
14 return 0;
16 node = alpha_mv.cpuid_to_nid(cpu);
18 #ifdef DEBUG_NUMA
19 BUG_ON(node < 0);
20 #endif
22 return node;
25 extern struct cpumask node_to_cpumask_map[];
26 /* FIXME: This is dumb, recalculating every time. But simple. */
27 static const struct cpumask *cpumask_of_node(int node)
29 int cpu;
31 if (node == -1)
32 return cpu_all_mask;
34 cpumask_clear(&node_to_cpumask_map[node]);
36 for_each_online_cpu(cpu) {
37 if (cpu_to_node(cpu) == node)
38 cpumask_set_cpu(cpu, node_to_cpumask_map[node]);
41 return &node_to_cpumask_map[node];
44 #define cpumask_of_pcibus(bus) (cpu_online_mask)
46 #endif /* !CONFIG_NUMA */
47 # include <asm-generic/topology.h>
49 #endif /* _ASM_ALPHA_TOPOLOGY_H */