[U-Boot] [PATCH] powerpc/mpc85xx: Change NMG_CPU_A011 workaround condition
York Sun
yorksun at freescale.com
Thu Jul 12 19:17:53 CEST 2012
This erratum applies to the following SoCs:
P4080 rev 1.0, 2.0, fixed in rev 3.0
P2041 rev 1.0, 1.1, fixed in rev 2.0
P3041 rev 1.0, 1.1, fixed in rev 2.0.
Workaround for erratum NMG_CPU_A011 is now enabled by default. It can be
disabled by hwconfig with syntax:
fsl_cpu_a011:disable
Signed-off-by: York Sun <yorksun at freescale.com>
---
arch/powerpc/cpu/mpc85xx/cpu_init.c | 18 +++++++++++-------
arch/powerpc/cpu/mpc85xx/release.S | 2 +-
2 files changed, 12 insertions(+), 8 deletions(-)
diff --git a/arch/powerpc/cpu/mpc85xx/cpu_init.c b/arch/powerpc/cpu/mpc85xx/cpu_init.c
index 026fa63..58b10fb 100644
--- a/arch/powerpc/cpu/mpc85xx/cpu_init.c
+++ b/arch/powerpc/cpu/mpc85xx/cpu_init.c
@@ -317,14 +317,15 @@ int cpu_init_r(void)
* CPU22 and NMG_CPU_A011 share the same workaround.
* CPU22 applies to P4080 rev 1.0, 2.0, fixed in 3.0
* NMG_CPU_A011 applies to P4080 rev 1.0, 2.0, fixed in 3.0
- * also applies to P3041 rev 1.0, 1.1, P2041 rev 1.0, 1.1
- * NMG_CPU_A011 is activated by hwconfig with syntax:
- * fsl_cpu_a011:enable
+ * also applies to P3041 rev 1.0, 1.1, P2041 rev 1.0, 1.1, both
+ * fixed in 2.0. NMG_CPU_A011 is activated by default and can
+ * be disabled by hwconfig with syntax:
+ *
+ * fsl_cpu_a011:disable
*/
extern int enable_cpu_a011_workaround;
#ifdef CONFIG_SYS_P4080_ERRATUM_CPU22
- enable_cpu_a011_workaround =
- (SVR_SOC_VER(svr) != SVR_P4080 || SVR_MAJ(svr) < 3);
+ enable_cpu_a011_workaround = (SVR_MAJ(svr) < 3);
#else
char buffer[HWCONFIG_BUFFER_SIZE];
char *buf = NULL;
@@ -332,9 +333,12 @@ int cpu_init_r(void)
if (getenv_f("hwconfig", buffer, sizeof(buffer)) > 0)
buf = buffer;
- if (hwconfig_arg_cmp_f("fsl_cpu_a011", "enable", buf) > 0) {
+ if (hwconfig_arg_cmp_f("fsl_cpu_a011", "disable", buf) > 0)
+ enable_cpu_a011_workaround = 0;
+ else {
enable_cpu_a011_workaround =
- (SVR_SOC_VER(svr) != SVR_P4080 || SVR_MAJ(svr) < 3);
+ (SVR_SOC_VER(svr) == SVR_P4080 && SVR_MAJ(svr) < 3) ||
+ (SVR_SOC_VER(svr) != SVR_P4080 && SVR_MAJ(svr) < 2);
}
#endif
if (enable_cpu_a011_workaround) {
diff --git a/arch/powerpc/cpu/mpc85xx/release.S b/arch/powerpc/cpu/mpc85xx/release.S
index b8d4a37..1555a9b 100644
--- a/arch/powerpc/cpu/mpc85xx/release.S
+++ b/arch/powerpc/cpu/mpc85xx/release.S
@@ -359,7 +359,7 @@ __spin_table:
.align L1_CACHE_SHIFT
.global enable_cpu_a011_workaround
enable_cpu_a011_workaround:
- .long 0
+ .long 1
/* Fill in the empty space. The actual reset vector is
* the last word of the page */
--
1.7.0.4
More information about the U-Boot
mailing list