at91sam9.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. /*
  2. * Setup code for AT91SAM9
  3. *
  4. * Copyright (C) 2011 Atmel,
  5. * 2011 Nicolas Ferre <nicolas.ferre@atmel.com>
  6. *
  7. * Licensed under GPLv2 or later.
  8. */
  9. #include <linux/of.h>
  10. #include <linux/of_platform.h>
  11. #include <asm/mach/arch.h>
  12. #include <asm/system_misc.h>
  13. #include "generic.h"
  14. #include "soc.h"
  15. static const struct at91_soc at91sam9_socs[] = {
  16. AT91_SOC(AT91SAM9260_CIDR_MATCH, 0, "at91sam9260", NULL),
  17. AT91_SOC(AT91SAM9261_CIDR_MATCH, 0, "at91sam9261", NULL),
  18. AT91_SOC(AT91SAM9263_CIDR_MATCH, 0, "at91sam9263", NULL),
  19. AT91_SOC(AT91SAM9G20_CIDR_MATCH, 0, "at91sam9g20", NULL),
  20. AT91_SOC(AT91SAM9RL64_CIDR_MATCH, 0, "at91sam9rl64", NULL),
  21. AT91_SOC(AT91SAM9G45_CIDR_MATCH, AT91SAM9M11_EXID_MATCH,
  22. "at91sam9m11", "at91sam9g45"),
  23. AT91_SOC(AT91SAM9G45_CIDR_MATCH, AT91SAM9M10_EXID_MATCH,
  24. "at91sam9m10", "at91sam9g45"),
  25. AT91_SOC(AT91SAM9G45_CIDR_MATCH, AT91SAM9G46_EXID_MATCH,
  26. "at91sam9g46", "at91sam9g45"),
  27. AT91_SOC(AT91SAM9G45_CIDR_MATCH, AT91SAM9G45_EXID_MATCH,
  28. "at91sam9g45", "at91sam9g45"),
  29. AT91_SOC(AT91SAM9X5_CIDR_MATCH, AT91SAM9G15_EXID_MATCH,
  30. "at91sam9g15", "at91sam9x5"),
  31. AT91_SOC(AT91SAM9X5_CIDR_MATCH, AT91SAM9G35_EXID_MATCH,
  32. "at91sam9g35", "at91sam9x5"),
  33. AT91_SOC(AT91SAM9X5_CIDR_MATCH, AT91SAM9X35_EXID_MATCH,
  34. "at91sam9x35", "at91sam9x5"),
  35. AT91_SOC(AT91SAM9X5_CIDR_MATCH, AT91SAM9G25_EXID_MATCH,
  36. "at91sam9g25", "at91sam9x5"),
  37. AT91_SOC(AT91SAM9X5_CIDR_MATCH, AT91SAM9X25_EXID_MATCH,
  38. "at91sam9x25", "at91sam9x5"),
  39. AT91_SOC(AT91SAM9N12_CIDR_MATCH, AT91SAM9CN12_EXID_MATCH,
  40. "at91sam9cn12", "at91sam9n12"),
  41. AT91_SOC(AT91SAM9N12_CIDR_MATCH, AT91SAM9N12_EXID_MATCH,
  42. "at91sam9n12", "at91sam9n12"),
  43. AT91_SOC(AT91SAM9N12_CIDR_MATCH, AT91SAM9CN11_EXID_MATCH,
  44. "at91sam9cn11", "at91sam9n12"),
  45. AT91_SOC(AT91SAM9XE128_CIDR_MATCH, 0, "at91sam9xe128", "at91sam9xe128"),
  46. AT91_SOC(AT91SAM9XE256_CIDR_MATCH, 0, "at91sam9xe256", "at91sam9xe256"),
  47. AT91_SOC(AT91SAM9XE512_CIDR_MATCH, 0, "at91sam9xe512", "at91sam9xe512"),
  48. { /* sentinel */ },
  49. };
  50. static void __init at91sam9_common_init(void)
  51. {
  52. struct soc_device *soc;
  53. struct device *soc_dev = NULL;
  54. soc = at91_soc_init(at91sam9_socs);
  55. if (soc != NULL)
  56. soc_dev = soc_device_to_device(soc);
  57. of_platform_populate(NULL, of_default_bus_match_table, NULL, soc_dev);
  58. arm_pm_idle = at91sam9_idle;
  59. }
  60. static void __init at91sam9_dt_device_init(void)
  61. {
  62. at91sam9_common_init();
  63. at91sam9260_pm_init();
  64. }
  65. static const char *const at91_dt_board_compat[] __initconst = {
  66. "atmel,at91sam9",
  67. NULL
  68. };
  69. DT_MACHINE_START(at91sam_dt, "Atmel AT91SAM9")
  70. /* Maintainer: Atmel */
  71. .init_machine = at91sam9_dt_device_init,
  72. .dt_compat = at91_dt_board_compat,
  73. MACHINE_END
  74. static void __init at91sam9g45_dt_device_init(void)
  75. {
  76. at91sam9_common_init();
  77. at91sam9g45_pm_init();
  78. }
  79. static const char *const at91sam9g45_board_compat[] __initconst = {
  80. "atmel,at91sam9g45",
  81. NULL
  82. };
  83. DT_MACHINE_START(at91sam9g45_dt, "Atmel AT91SAM9G45")
  84. /* Maintainer: Atmel */
  85. .init_machine = at91sam9g45_dt_device_init,
  86. .dt_compat = at91sam9g45_board_compat,
  87. MACHINE_END
  88. static void __init at91sam9x5_dt_device_init(void)
  89. {
  90. at91sam9_common_init();
  91. at91sam9x5_pm_init();
  92. }
  93. static const char *const at91sam9x5_board_compat[] __initconst = {
  94. "atmel,at91sam9x5",
  95. "atmel,at91sam9n12",
  96. NULL
  97. };
  98. DT_MACHINE_START(at91sam9x5_dt, "Atmel AT91SAM9")
  99. /* Maintainer: Atmel */
  100. .init_machine = at91sam9x5_dt_device_init,
  101. .dt_compat = at91sam9x5_board_compat,
  102. MACHINE_END