xref: /openbmc/u-boot/arch/mips/mach-ath79/cpu.c (revision 83d290c56fab2d38cd1ab4c4cc7099559c1d5046)
1*83d290c5STom Rini // SPDX-License-Identifier: GPL-2.0+
21d3d0f1fSWills Wang /*
31d3d0f1fSWills Wang  * Copyright (C) 2015-2016 Wills Wang <wills.wang@live.com>
41d3d0f1fSWills Wang  */
51d3d0f1fSWills Wang 
61d3d0f1fSWills Wang #include <common.h>
71d3d0f1fSWills Wang #include <asm/io.h>
81d3d0f1fSWills Wang #include <asm/addrspace.h>
91d3d0f1fSWills Wang #include <asm/types.h>
101d3d0f1fSWills Wang #include <mach/ath79.h>
111d3d0f1fSWills Wang #include <mach/ar71xx_regs.h>
121d3d0f1fSWills Wang 
131d3d0f1fSWills Wang struct ath79_soc_desc {
1459e4080cSWills Wang 	const enum ath79_soc_type soc;
151d3d0f1fSWills Wang 	const char *chip;
1659e4080cSWills Wang 	const int major;
1759e4080cSWills Wang 	const int minor;
181d3d0f1fSWills Wang };
191d3d0f1fSWills Wang 
2059e4080cSWills Wang static const struct ath79_soc_desc desc[] = {
211d3d0f1fSWills Wang 	{ATH79_SOC_AR7130,      "7130",
221d3d0f1fSWills Wang 	 REV_ID_MAJOR_AR71XX,   AR71XX_REV_ID_MINOR_AR7130},
231d3d0f1fSWills Wang 	{ATH79_SOC_AR7141,      "7141",
241d3d0f1fSWills Wang 	 REV_ID_MAJOR_AR71XX,   AR71XX_REV_ID_MINOR_AR7141},
251d3d0f1fSWills Wang 	{ATH79_SOC_AR7161,      "7161",
261d3d0f1fSWills Wang 	 REV_ID_MAJOR_AR71XX,   AR71XX_REV_ID_MINOR_AR7161},
271d3d0f1fSWills Wang 	{ATH79_SOC_AR7240,      "7240", REV_ID_MAJOR_AR7240,    0},
281d3d0f1fSWills Wang 	{ATH79_SOC_AR7241,      "7241", REV_ID_MAJOR_AR7241,    0},
291d3d0f1fSWills Wang 	{ATH79_SOC_AR7242,      "7242", REV_ID_MAJOR_AR7242,    0},
301d3d0f1fSWills Wang 	{ATH79_SOC_AR9130,      "9130",
311d3d0f1fSWills Wang 	 REV_ID_MAJOR_AR913X,   AR913X_REV_ID_MINOR_AR9130},
321d3d0f1fSWills Wang 	{ATH79_SOC_AR9132,      "9132",
331d3d0f1fSWills Wang 	 REV_ID_MAJOR_AR913X,   AR913X_REV_ID_MINOR_AR9132},
341d3d0f1fSWills Wang 	{ATH79_SOC_AR9330,      "9330", REV_ID_MAJOR_AR9330,    0},
351d3d0f1fSWills Wang 	{ATH79_SOC_AR9331,      "9331", REV_ID_MAJOR_AR9331,    0},
361d3d0f1fSWills Wang 	{ATH79_SOC_AR9341,      "9341", REV_ID_MAJOR_AR9341,    0},
371d3d0f1fSWills Wang 	{ATH79_SOC_AR9342,      "9342", REV_ID_MAJOR_AR9342,    0},
381d3d0f1fSWills Wang 	{ATH79_SOC_AR9344,      "9344", REV_ID_MAJOR_AR9344,    0},
391d3d0f1fSWills Wang 	{ATH79_SOC_QCA9533,     "9533", REV_ID_MAJOR_QCA9533,   0},
401d3d0f1fSWills Wang 	{ATH79_SOC_QCA9533,     "9533",
411d3d0f1fSWills Wang 	 REV_ID_MAJOR_QCA9533_V2,       0},
421d3d0f1fSWills Wang 	{ATH79_SOC_QCA9556,     "9556", REV_ID_MAJOR_QCA9556,   0},
431d3d0f1fSWills Wang 	{ATH79_SOC_QCA9558,     "9558", REV_ID_MAJOR_QCA9558,   0},
441d3d0f1fSWills Wang 	{ATH79_SOC_TP9343,      "9343", REV_ID_MAJOR_TP9343,    0},
451d3d0f1fSWills Wang 	{ATH79_SOC_QCA9561,     "9561", REV_ID_MAJOR_QCA9561,   0},
461d3d0f1fSWills Wang };
471d3d0f1fSWills Wang 
mach_cpu_init(void)480dfe04d6SPaul Burton int mach_cpu_init(void)
491d3d0f1fSWills Wang {
501d3d0f1fSWills Wang 	void __iomem *base;
511d3d0f1fSWills Wang 	enum ath79_soc_type soc = ATH79_SOC_UNKNOWN;
521d3d0f1fSWills Wang 	u32 id, major, minor = 0;
531d3d0f1fSWills Wang 	u32 rev = 0, ver = 1;
541d3d0f1fSWills Wang 	int i;
551d3d0f1fSWills Wang 
561d3d0f1fSWills Wang 	base = map_physmem(AR71XX_RESET_BASE, AR71XX_RESET_SIZE,
571d3d0f1fSWills Wang 			   MAP_NOCACHE);
581d3d0f1fSWills Wang 
591d3d0f1fSWills Wang 	id = readl(base + AR71XX_RESET_REG_REV_ID);
601d3d0f1fSWills Wang 	major = id & REV_ID_MAJOR_MASK;
611d3d0f1fSWills Wang 	switch (major) {
621d3d0f1fSWills Wang 	case REV_ID_MAJOR_AR71XX:
631d3d0f1fSWills Wang 	case REV_ID_MAJOR_AR913X:
641d3d0f1fSWills Wang 		minor = id & AR71XX_REV_ID_MINOR_MASK;
651d3d0f1fSWills Wang 		rev = id >> AR71XX_REV_ID_REVISION_SHIFT;
661d3d0f1fSWills Wang 		rev &= AR71XX_REV_ID_REVISION_MASK;
671d3d0f1fSWills Wang 		break;
681d3d0f1fSWills Wang 
691d3d0f1fSWills Wang 	case REV_ID_MAJOR_QCA9533_V2:
701d3d0f1fSWills Wang 		ver = 2;
711d3d0f1fSWills Wang 		/* drop through */
721d3d0f1fSWills Wang 
731d3d0f1fSWills Wang 	case REV_ID_MAJOR_AR9341:
741d3d0f1fSWills Wang 	case REV_ID_MAJOR_AR9342:
751d3d0f1fSWills Wang 	case REV_ID_MAJOR_AR9344:
761d3d0f1fSWills Wang 	case REV_ID_MAJOR_QCA9533:
771d3d0f1fSWills Wang 	case REV_ID_MAJOR_QCA9556:
781d3d0f1fSWills Wang 	case REV_ID_MAJOR_QCA9558:
791d3d0f1fSWills Wang 	case REV_ID_MAJOR_TP9343:
801d3d0f1fSWills Wang 	case REV_ID_MAJOR_QCA9561:
811d3d0f1fSWills Wang 		rev = id & AR71XX_REV_ID_REVISION2_MASK;
821d3d0f1fSWills Wang 		break;
831d3d0f1fSWills Wang 	default:
841d3d0f1fSWills Wang 		rev = id & AR71XX_REV_ID_REVISION_MASK;
851d3d0f1fSWills Wang 		break;
861d3d0f1fSWills Wang 	}
871d3d0f1fSWills Wang 
881d3d0f1fSWills Wang 	for (i = 0; i < ARRAY_SIZE(desc); i++) {
891d3d0f1fSWills Wang 		if ((desc[i].major == major) &&
901d3d0f1fSWills Wang 		    (desc[i].minor == minor)) {
911d3d0f1fSWills Wang 			soc = desc[i].soc;
921d3d0f1fSWills Wang 			break;
931d3d0f1fSWills Wang 		}
941d3d0f1fSWills Wang 	}
951d3d0f1fSWills Wang 
961d3d0f1fSWills Wang 	gd->arch.id = id;
971d3d0f1fSWills Wang 	gd->arch.soc = soc;
981d3d0f1fSWills Wang 	gd->arch.rev = rev;
991d3d0f1fSWills Wang 	gd->arch.ver = ver;
1001d3d0f1fSWills Wang 	return 0;
1011d3d0f1fSWills Wang }
1021d3d0f1fSWills Wang 
print_cpuinfo(void)1031d3d0f1fSWills Wang int print_cpuinfo(void)
1041d3d0f1fSWills Wang {
1051d3d0f1fSWills Wang 	enum ath79_soc_type soc = ATH79_SOC_UNKNOWN;
1061d3d0f1fSWills Wang 	const char *chip = "????";
1071d3d0f1fSWills Wang 	u32 id, rev, ver;
1081d3d0f1fSWills Wang 	int i;
1091d3d0f1fSWills Wang 
1101d3d0f1fSWills Wang 	for (i = 0; i < ARRAY_SIZE(desc); i++) {
1111d3d0f1fSWills Wang 		if (desc[i].soc == gd->arch.soc) {
1121d3d0f1fSWills Wang 			chip = desc[i].chip;
1131d3d0f1fSWills Wang 			soc = desc[i].soc;
1141d3d0f1fSWills Wang 			break;
1151d3d0f1fSWills Wang 		}
1161d3d0f1fSWills Wang 	}
1171d3d0f1fSWills Wang 
1181d3d0f1fSWills Wang 	id = gd->arch.id;
1191d3d0f1fSWills Wang 	rev = gd->arch.rev;
1201d3d0f1fSWills Wang 	ver = gd->arch.ver;
1211d3d0f1fSWills Wang 
1221d3d0f1fSWills Wang 	switch (soc) {
1231d3d0f1fSWills Wang 	case ATH79_SOC_QCA9533:
1241d3d0f1fSWills Wang 	case ATH79_SOC_QCA9556:
1251d3d0f1fSWills Wang 	case ATH79_SOC_QCA9558:
1261d3d0f1fSWills Wang 	case ATH79_SOC_QCA9561:
1271d3d0f1fSWills Wang 		printf("Qualcomm Atheros QCA%s ver %u rev %u\n", chip,
1281d3d0f1fSWills Wang 		       ver, rev);
1291d3d0f1fSWills Wang 		break;
1301d3d0f1fSWills Wang 	case ATH79_SOC_TP9343:
1311d3d0f1fSWills Wang 		printf("Qualcomm Atheros TP%s rev %u\n", chip, rev);
1321d3d0f1fSWills Wang 		break;
1331d3d0f1fSWills Wang 	case ATH79_SOC_UNKNOWN:
1341d3d0f1fSWills Wang 		printf("ATH79: unknown SoC, id:0x%08x", id);
1351d3d0f1fSWills Wang 		break;
1361d3d0f1fSWills Wang 	default:
1371d3d0f1fSWills Wang 		printf("Atheros AR%s rev %u\n", chip, rev);
1381d3d0f1fSWills Wang 	}
1391d3d0f1fSWills Wang 
1401d3d0f1fSWills Wang 	return 0;
1411d3d0f1fSWills Wang }
142