cpu.c 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2015-2016 Wills Wang <wills.wang@live.com>
  4. */
  5. #include <common.h>
  6. #include <init.h>
  7. #include <asm/io.h>
  8. #include <asm/addrspace.h>
  9. #include <asm/global_data.h>
  10. #include <asm/types.h>
  11. #include <mach/ath79.h>
  12. #include <mach/ar71xx_regs.h>
  13. struct ath79_soc_desc {
  14. const enum ath79_soc_type soc;
  15. const char *chip;
  16. const int major;
  17. const int minor;
  18. };
  19. static const struct ath79_soc_desc desc[] = {
  20. {ATH79_SOC_AR7130, "7130",
  21. REV_ID_MAJOR_AR71XX, AR71XX_REV_ID_MINOR_AR7130},
  22. {ATH79_SOC_AR7141, "7141",
  23. REV_ID_MAJOR_AR71XX, AR71XX_REV_ID_MINOR_AR7141},
  24. {ATH79_SOC_AR7161, "7161",
  25. REV_ID_MAJOR_AR71XX, AR71XX_REV_ID_MINOR_AR7161},
  26. {ATH79_SOC_AR7240, "7240", REV_ID_MAJOR_AR7240, 0},
  27. {ATH79_SOC_AR7241, "7241", REV_ID_MAJOR_AR7241, 0},
  28. {ATH79_SOC_AR7242, "7242", REV_ID_MAJOR_AR7242, 0},
  29. {ATH79_SOC_AR9130, "9130",
  30. REV_ID_MAJOR_AR913X, AR913X_REV_ID_MINOR_AR9130},
  31. {ATH79_SOC_AR9132, "9132",
  32. REV_ID_MAJOR_AR913X, AR913X_REV_ID_MINOR_AR9132},
  33. {ATH79_SOC_AR9330, "9330", REV_ID_MAJOR_AR9330, 0},
  34. {ATH79_SOC_AR9331, "9331", REV_ID_MAJOR_AR9331, 0},
  35. {ATH79_SOC_AR9341, "9341", REV_ID_MAJOR_AR9341, 0},
  36. {ATH79_SOC_AR9342, "9342", REV_ID_MAJOR_AR9342, 0},
  37. {ATH79_SOC_AR9344, "9344", REV_ID_MAJOR_AR9344, 0},
  38. {ATH79_SOC_QCA9533, "9533", REV_ID_MAJOR_QCA9533, 0},
  39. {ATH79_SOC_QCA9533, "9533",
  40. REV_ID_MAJOR_QCA9533_V2, 0},
  41. {ATH79_SOC_QCA9556, "9556", REV_ID_MAJOR_QCA9556, 0},
  42. {ATH79_SOC_QCA9558, "9558", REV_ID_MAJOR_QCA9558, 0},
  43. {ATH79_SOC_TP9343, "9343", REV_ID_MAJOR_TP9343, 0},
  44. {ATH79_SOC_QCA9561, "9561", REV_ID_MAJOR_QCA9561, 0},
  45. };
  46. int mach_cpu_init(void)
  47. {
  48. void __iomem *base;
  49. enum ath79_soc_type soc = ATH79_SOC_UNKNOWN;
  50. u32 id, major, minor = 0;
  51. u32 rev = 0, ver = 1;
  52. int i;
  53. base = map_physmem(AR71XX_RESET_BASE, AR71XX_RESET_SIZE,
  54. MAP_NOCACHE);
  55. id = readl(base + AR71XX_RESET_REG_REV_ID);
  56. major = id & REV_ID_MAJOR_MASK;
  57. switch (major) {
  58. case REV_ID_MAJOR_AR71XX:
  59. case REV_ID_MAJOR_AR913X:
  60. minor = id & AR71XX_REV_ID_MINOR_MASK;
  61. rev = id >> AR71XX_REV_ID_REVISION_SHIFT;
  62. rev &= AR71XX_REV_ID_REVISION_MASK;
  63. break;
  64. case REV_ID_MAJOR_QCA9533_V2:
  65. ver = 2;
  66. /* drop through */
  67. case REV_ID_MAJOR_AR9341:
  68. case REV_ID_MAJOR_AR9342:
  69. case REV_ID_MAJOR_AR9344:
  70. case REV_ID_MAJOR_QCA9533:
  71. case REV_ID_MAJOR_QCA9556:
  72. case REV_ID_MAJOR_QCA9558:
  73. case REV_ID_MAJOR_TP9343:
  74. case REV_ID_MAJOR_QCA9561:
  75. rev = id & AR71XX_REV_ID_REVISION2_MASK;
  76. break;
  77. default:
  78. rev = id & AR71XX_REV_ID_REVISION_MASK;
  79. break;
  80. }
  81. for (i = 0; i < ARRAY_SIZE(desc); i++) {
  82. if ((desc[i].major == major) &&
  83. (desc[i].minor == minor)) {
  84. soc = desc[i].soc;
  85. break;
  86. }
  87. }
  88. gd->arch.id = id;
  89. gd->arch.soc = soc;
  90. gd->arch.rev = rev;
  91. gd->arch.ver = ver;
  92. return 0;
  93. }
  94. int print_cpuinfo(void)
  95. {
  96. enum ath79_soc_type soc = ATH79_SOC_UNKNOWN;
  97. const char *chip = "????";
  98. u32 id, rev, ver;
  99. int i;
  100. for (i = 0; i < ARRAY_SIZE(desc); i++) {
  101. if (desc[i].soc == gd->arch.soc) {
  102. chip = desc[i].chip;
  103. soc = desc[i].soc;
  104. break;
  105. }
  106. }
  107. id = gd->arch.id;
  108. rev = gd->arch.rev;
  109. ver = gd->arch.ver;
  110. switch (soc) {
  111. case ATH79_SOC_QCA9533:
  112. case ATH79_SOC_QCA9556:
  113. case ATH79_SOC_QCA9558:
  114. case ATH79_SOC_QCA9561:
  115. printf("Qualcomm Atheros QCA%s ver %u rev %u\n", chip,
  116. ver, rev);
  117. break;
  118. case ATH79_SOC_TP9343:
  119. printf("Qualcomm Atheros TP%s rev %u\n", chip, rev);
  120. break;
  121. case ATH79_SOC_UNKNOWN:
  122. printf("ATH79: unknown SoC, id:0x%08x", id);
  123. break;
  124. default:
  125. printf("Atheros AR%s rev %u\n", chip, rev);
  126. }
  127. return 0;
  128. }