2005-04-16 18:20:36 -04:00
|
|
|
#ifndef _ASM_ALPHA_TOPOLOGY_H
|
|
|
|
#define _ASM_ALPHA_TOPOLOGY_H
|
|
|
|
|
|
|
|
#include <linux/smp.h>
|
|
|
|
#include <linux/threads.h>
|
|
|
|
#include <asm/machvec.h>
|
|
|
|
|
|
|
|
#ifdef CONFIG_NUMA
|
|
|
|
static inline int cpu_to_node(int cpu)
|
|
|
|
{
|
|
|
|
int node;
|
|
|
|
|
|
|
|
if (!alpha_mv.cpuid_to_nid)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
node = alpha_mv.cpuid_to_nid(cpu);
|
|
|
|
|
|
|
|
#ifdef DEBUG_NUMA
|
|
|
|
BUG_ON(node < 0);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return node;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline cpumask_t node_to_cpumask(int node)
|
|
|
|
{
|
|
|
|
cpumask_t node_cpu_mask = CPU_MASK_NONE;
|
|
|
|
int cpu;
|
|
|
|
|
2006-03-23 06:01:05 -05:00
|
|
|
for_each_online_cpu(cpu) {
|
|
|
|
if (cpu_to_node(cpu) == node)
|
2005-04-16 18:20:36 -04:00
|
|
|
cpu_set(cpu, node_cpu_mask);
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef DEBUG_NUMA
|
|
|
|
printk("node %d: cpu_mask: %016lx\n", node, node_cpu_mask);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return node_cpu_mask;
|
|
|
|
}
|
|
|
|
|
2008-12-26 06:53:41 -05:00
|
|
|
extern struct cpumask node_to_cpumask_map[];
|
|
|
|
/* FIXME: This is dumb, recalculating every time. But simple. */
|
|
|
|
static const struct cpumask *cpumask_of_node(int node)
|
|
|
|
{
|
|
|
|
int cpu;
|
|
|
|
|
|
|
|
cpumask_clear(&node_to_cpumask_map[node]);
|
|
|
|
|
|
|
|
for_each_online_cpu(cpu) {
|
|
|
|
if (cpu_to_node(cpu) == node)
|
|
|
|
cpumask_set_cpu(cpu, node_to_cpumask_map[node]);
|
|
|
|
}
|
|
|
|
|
|
|
|
return &node_to_cpumask_map[node];
|
|
|
|
}
|
|
|
|
|
2005-04-16 18:20:36 -04:00
|
|
|
#define pcibus_to_cpumask(bus) (cpu_online_map)
|
2008-12-26 06:53:41 -05:00
|
|
|
#define cpumask_of_pcibus(bus) (cpu_online_mask)
|
2005-04-16 18:20:36 -04:00
|
|
|
|
|
|
|
#endif /* !CONFIG_NUMA */
|
2008-03-31 11:41:55 -04:00
|
|
|
# include <asm-generic/topology.h>
|
2005-04-16 18:20:36 -04:00
|
|
|
|
|
|
|
#endif /* _ASM_ALPHA_TOPOLOGY_H */
|