ARM: mach-omap2: Kconfig: Make SYS_MPUCLK dependent on AM33XX
[oweals/u-boot.git] / arch / arm / mach-rmobile / cpu_info-rcar.c
index 42ee30fbe7acf29ac423ac966f8490aaf13ff0a8..ce9312f9d8286e434925efdbe48c164f96c42d19 100644 (file)
@@ -1,26 +1,46 @@
+// SPDX-License-Identifier: GPL-2.0
 /*
  * arch/arm/cpu/armv7/rmobile/cpu_info-rcar.c
  *
  * Copyright (C) 2013,2014 Renesas Electronics Corporation
- *
- * SPDX-License-Identifier: GPL-2.0
  */
 #include <common.h>
 #include <asm/io.h>
 
-#define PRR 0xFF000044
+#define PRR_MASK               0x7fff
+#define R8A7796_REV_1_0                0x5200
+#define R8A7796_REV_1_1                0x5210
+
+static u32 rmobile_get_prr(void)
+{
+#ifdef CONFIG_RCAR_GEN3
+       return readl(0xFFF00044);
+#else
+       return readl(0xFF000044);
+#endif
+}
 
 u32 rmobile_get_cpu_type(void)
 {
-       return (readl(PRR) & 0x00007F00) >> 8;
+       return (rmobile_get_prr() & 0x00007F00) >> 8;
 }
 
 u32 rmobile_get_cpu_rev_integer(void)
 {
-       return ((readl(PRR) & 0x000000F0) >> 4) + 1;
+       const u32 prr = rmobile_get_prr();
+
+       if ((prr & PRR_MASK) == R8A7796_REV_1_1)
+               return 1;
+       else
+               return ((prr & 0x000000F0) >> 4) + 1;
 }
 
 u32 rmobile_get_cpu_rev_fraction(void)
 {
-       return readl(PRR) & 0x0000000F;
+       const u32 prr = rmobile_get_prr();
+
+       if ((prr & PRR_MASK) == R8A7796_REV_1_1)
+               return 1;
+       else
+               return prr & 0x0000000F;
 }