topology.c 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. /*
  2. * arch/sh/kernel/topology.c
  3. *
  4. * Copyright (C) 2007 Paul Mundt
  5. *
  6. * This file is subject to the terms and conditions of the GNU General Public
  7. * License. See the file "COPYING" in the main directory of this archive
  8. * for more details.
  9. */
  10. #include <linux/cpu.h>
  11. #include <linux/cpumask.h>
  12. #include <linux/init.h>
  13. #include <linux/percpu.h>
  14. #include <linux/topology.h>
  15. #include <linux/node.h>
  16. #include <linux/nodemask.h>
  17. #include <linux/export.h>
  18. static DEFINE_PER_CPU(struct cpu, cpu_devices);
  19. cpumask_t cpu_core_map[NR_CPUS];
  20. EXPORT_SYMBOL(cpu_core_map);
  21. static cpumask_t cpu_coregroup_map(unsigned int cpu)
  22. {
  23. /*
  24. * Presently all SH-X3 SMP cores are multi-cores, so just keep it
  25. * simple until we have a method for determining topology..
  26. */
  27. return *cpu_possible_mask;
  28. }
  29. const struct cpumask *cpu_coregroup_mask(unsigned int cpu)
  30. {
  31. return &cpu_core_map[cpu];
  32. }
  33. int arch_update_cpu_topology(void)
  34. {
  35. unsigned int cpu;
  36. for_each_possible_cpu(cpu)
  37. cpu_core_map[cpu] = cpu_coregroup_map(cpu);
  38. return 0;
  39. }
  40. static int __init topology_init(void)
  41. {
  42. int i, ret;
  43. #ifdef CONFIG_NEED_MULTIPLE_NODES
  44. for_each_online_node(i)
  45. register_one_node(i);
  46. #endif
  47. for_each_present_cpu(i) {
  48. struct cpu *c = &per_cpu(cpu_devices, i);
  49. c->hotpluggable = 1;
  50. ret = register_cpu(c, i);
  51. if (unlikely(ret))
  52. printk(KERN_WARNING "%s: register_cpu %d failed (%d)\n",
  53. __func__, i, ret);
  54. }
  55. #if defined(CONFIG_NUMA) && !defined(CONFIG_SMP)
  56. /*
  57. * In the UP case, make sure the CPU association is still
  58. * registered under each node. Without this, sysfs fails
  59. * to make the connection between nodes other than node0
  60. * and cpu0.
  61. */
  62. for_each_online_node(i)
  63. if (i != numa_node_id())
  64. register_cpu_under_node(raw_smp_processor_id(), i);
  65. #endif
  66. return 0;
  67. }
  68. subsys_initcall(topology_init);