powerpc/85xx: Cleanup how SVR_MAJ() is defined on MPC8536
authorKumar Gala <galak@kernel.crashing.org>
Wed, 24 Aug 2011 14:14:16 +0000 (09:14 -0500)
committerKumar Gala <galak@kernel.crashing.org>
Fri, 30 Sep 2011 00:01:05 +0000 (19:01 -0500)
The MPC8536 seems to use only 3 bits for the major revision field in the
SVR rather than the 4 bits used by all other processors.  The most
significant bit is used as a mfg code on MPC8536.

Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
arch/powerpc/cpu/mpc85xx/cpu.c
arch/powerpc/include/asm/processor.h

index f51829e0fe7aad3360e5ed32219d00e83d14fd22..49c0551692985ebca9bc9fe0fc26dfd15acb5196 100644 (file)
@@ -69,9 +69,6 @@ int checkcpu (void)
 
        svr = get_svr();
        major = SVR_MAJ(svr);
-#ifdef CONFIG_MPC8536
-       major &= 0x7; /* the msb of this nibble is a mfg code */
-#endif
        minor = SVR_MIN(svr);
 
        if (cpu_numcores() > 1) {
index 50af6e7fc2f936477da45a42d4a0baa8fe5ffd6a..46f9989756678e66c5ff9623e0af7ce33a5ea1d4 100644 (file)
 #define SVR_FAM(svr)   (((svr) >> 20) & 0xFFF) /* Family field */
 #define SVR_MEM(svr)   (((svr) >> 16) & 0xF)   /* Member field */
 
+#ifdef CONFIG_MPC8536
+#define SVR_MAJ(svr)   (((svr) >>  4) & 0x7)   /* Major revision field*/
+#else
 #define SVR_MAJ(svr)   (((svr) >>  4) & 0xF)   /* Major revision field*/
+#endif
 #define SVR_MIN(svr)   (((svr) >>  0) & 0xF)   /* Minor revision field*/
 
 /* Some parts define SVR[0:23] as the SOC version */