ARM: S3C24XX: Identify S3C2416 if S3C2412/S3C2413 built in
authorBen Dooks <ben-linux@fluff.org>
Wed, 28 Apr 2010 09:00:07 +0000 (18:00 +0900)
committerBen Dooks <ben-linux@fluff.org>
Mon, 10 May 2010 02:44:41 +0000 (11:44 +0900)
Extend the ARMv5 ID code to deal with S3C2416 being built with
S3C2412/S3C2413 enabled, as these have their ID registers in a
different place.

Signed-off-by: Ben Dooks <ben-linux@fluff.org>
arch/arm/plat-s3c24xx/cpu.c

index 494f4f3a9332bd3ff7e380fb351d62b4db884beb..32db85651af0af0317c835f3f2d18f0d1bdd1a31 100644 (file)
@@ -181,10 +181,18 @@ static struct map_desc s3c_iodesc[] __initdata = {
 
 static unsigned long s3c24xx_read_idcode_v5(void)
 {
+#if defined(CONFIG_CPU_S3C2416)
+       /* s3c2416 is v5, with S3C24XX_GSTATUS1 instead of S3C2412_GSTATUS1 */
+
+       u32 gs = __raw_readl(S3C24XX_GSTATUS1);
+
+       /* test for s3c2416 or similar device */
+       if ((gs >> 16) == 0x3245)
+               return gs;
+#endif
+
 #if defined(CONFIG_CPU_S3C2412) || defined(CONFIG_CPU_S3C2413)
        return __raw_readl(S3C2412_GSTATUS1);
-#elif defined(CONFIG_CPU_S3C2416)
-       return __raw_readl(S3C24XX_GSTATUS1);
 #else
        return 1UL;     /* don't look like an 2400 */
 #endif