topology.h 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. #ifndef _ASM_ALPHA_TOPOLOGY_H
  2. #define _ASM_ALPHA_TOPOLOGY_H
  3. #include <linux/smp.h>
  4. #include <linux/threads.h>
  5. #include <asm/machvec.h>
  6. #ifdef CONFIG_NUMA
  7. static inline int cpu_to_node(int cpu)
  8. {
  9. int node;
  10. if (!alpha_mv.cpuid_to_nid)
  11. return 0;
  12. node = alpha_mv.cpuid_to_nid(cpu);
  13. #ifdef DEBUG_NUMA
  14. BUG_ON(node < 0);
  15. #endif
  16. return node;
  17. }
  18. static inline cpumask_t node_to_cpumask(int node)
  19. {
  20. cpumask_t node_cpu_mask = CPU_MASK_NONE;
  21. int cpu;
  22. for_each_online_cpu(cpu) {
  23. if (cpu_to_node(cpu) == node)
  24. cpu_set(cpu, node_cpu_mask);
  25. }
  26. #ifdef DEBUG_NUMA
  27. printk("node %d: cpu_mask: %016lx\n", node, node_cpu_mask);
  28. #endif
  29. return node_cpu_mask;
  30. }
  31. extern struct cpumask node_to_cpumask_map[];
  32. /* FIXME: This is dumb, recalculating every time. But simple. */
  33. static const struct cpumask *cpumask_of_node(int node)
  34. {
  35. int cpu;
  36. cpumask_clear(&node_to_cpumask_map[node]);
  37. for_each_online_cpu(cpu) {
  38. if (cpu_to_node(cpu) == node)
  39. cpumask_set_cpu(cpu, node_to_cpumask_map[node]);
  40. }
  41. return &node_to_cpumask_map[node];
  42. }
  43. #define pcibus_to_cpumask(bus) (cpu_online_map)
  44. #define cpumask_of_pcibus(bus) (cpu_online_mask)
  45. #endif /* !CONFIG_NUMA */
  46. # include <asm-generic/topology.h>
  47. #endif /* _ASM_ALPHA_TOPOLOGY_H */