diff options
Diffstat (limited to 'sys')
-rw-r--r-- | sys/arch/mvme88k/mvme88k/m88110.c | 40 |
1 files changed, 32 insertions, 8 deletions
diff --git a/sys/arch/mvme88k/mvme88k/m88110.c b/sys/arch/mvme88k/mvme88k/m88110.c index 9fb5de38a43..7d706dab07e 100644 --- a/sys/arch/mvme88k/mvme88k/m88110.c +++ b/sys/arch/mvme88k/mvme88k/m88110.c @@ -1,4 +1,4 @@ -/* $OpenBSD: m88110.c,v 1.52 2007/12/15 19:37:41 miod Exp $ */ +/* $OpenBSD: m88110.c,v 1.53 2007/12/22 17:13:53 miod Exp $ */ /* * Copyright (c) 1998 Steve Murphree, Jr. * All rights reserved. @@ -252,6 +252,7 @@ m88110_initialize_cpu(cpuid_t cpu) extern int cpuspeed; u_int ictl, dctl; int i; + int procvers = (get_cpu_pid() & PID_VN) >> VN_SHIFT; /* clear BATCs */ for (i = 0; i < 8; i++) { @@ -264,13 +265,6 @@ m88110_initialize_cpu(cpuid_t cpu) /* clear PATCs */ patc_clear(); - /* - * 88110 errata #1: - * ``Under certain conditions involving exceptions, with branch - * prediction enabled, the CPU may hang. - * Suggested fix: Clear the PREN bit of the ICTL. This will - * disable branch prediction.'' - */ ictl = BATC_512K | CMMU_ICTL_DID | CMMU_ICTL_CEN | CMMU_ICTL_BEN; /* @@ -312,6 +306,36 @@ m88110_initialize_cpu(cpuid_t cpu) dctl = BATC_512K | CMMU_DCTL_CEN | CMMU_DCTL_ADS; dctl |= CMMU_DCTL_RSVD1; /* Data Matching Disable */ + /* + * 88110 rev 4.2 errata #1: + * ``Under certain conditions involving exceptions, with branch + * prediction enabled, the CPU may hang. + * Suggested fix: Clear the PREN bit of the ICTL. This will + * disable branch prediction.'' + * + * ...but this errata becomes... + * + * 88110 rev 5.1 errata #1: + * ``Under certain conditions involving exceptions, with branch + * prediction enabled and decoupled loads/stores enabled, load + * instructions may complete incorrectly or stores may execute + * to the wrong. address. + * Suggested fix: Clear the PREN bit of the ICTL or the DEN bit + * of the DCTL.'' + * + * So since branch prediction appears to give better performance + * than data cache decoupling, and it is not known whether the + * problem has been understood better and thus the conditions + * narrowed on 5.1, or changes between 4.2 and 5.1 only restrict + * the conditions on which it may occur, we'll enable branch + * prediction on 5.1 processors and data cache decoupling on + * earlier versions. + */ + if (procvers >= 0xf) /* > 0xb ? */ + ictl |= CMMU_ICTL_PREN; + else + dctl |= CMMU_DCTL_DEN; + mc88110_inval_inst(); /* clear instruction cache & TIC */ mc88110_inval_data(); /* clear data cache */ |