blob: b4f284c72ff3ed303425ac437df0b74f75defc90 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef _ASM_ALPHA_TOPOLOGY_H
2#define _ASM_ALPHA_TOPOLOGY_H
3
4#include <linux/smp.h>
5#include <linux/threads.h>
6#include <asm/machvec.h>
7
8#ifdef CONFIG_NUMA
9static inline int cpu_to_node(int cpu)
10{
11 int node;
12
13 if (!alpha_mv.cpuid_to_nid)
14 return 0;
15
16 node = alpha_mv.cpuid_to_nid(cpu);
17
18#ifdef DEBUG_NUMA
19 BUG_ON(node < 0);
20#endif
21
22 return node;
23}
24
25static inline cpumask_t node_to_cpumask(int node)
26{
27 cpumask_t node_cpu_mask = CPU_MASK_NONE;
28 int cpu;
29
Andrew Morton394e3902006-03-23 03:01:05 -080030 for_each_online_cpu(cpu) {
31 if (cpu_to_node(cpu) == node)
Linus Torvalds1da177e2005-04-16 15:20:36 -070032 cpu_set(cpu, node_cpu_mask);
33 }
34
35#ifdef DEBUG_NUMA
36 printk("node %d: cpu_mask: %016lx\n", node, node_cpu_mask);
37#endif
38
39 return node_cpu_mask;
40}
41
Rusty Russell2258a5b2008-12-26 22:23:41 +103042extern struct cpumask node_to_cpumask_map[];
43/* FIXME: This is dumb, recalculating every time. But simple. */
44static const struct cpumask *cpumask_of_node(int node)
45{
46 int cpu;
47
48 cpumask_clear(&node_to_cpumask_map[node]);
49
50 for_each_online_cpu(cpu) {
51 if (cpu_to_node(cpu) == node)
52 cpumask_set_cpu(cpu, node_to_cpumask_map[node]);
53 }
54
55 return &node_to_cpumask_map[node];
56}
57
Linus Torvalds1da177e2005-04-16 15:20:36 -070058#define pcibus_to_cpumask(bus) (cpu_online_map)
Rusty Russell2258a5b2008-12-26 22:23:41 +103059#define cpumask_of_pcibus(bus) (cpu_online_mask)
Linus Torvalds1da177e2005-04-16 15:20:36 -070060
Linus Torvalds1da177e2005-04-16 15:20:36 -070061#endif /* !CONFIG_NUMA */
Mike Travisaa6b5442008-03-31 08:41:55 -070062# include <asm-generic/topology.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070063
64#endif /* _ASM_ALPHA_TOPOLOGY_H */