summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorMichael Shalayeff <mickey@cvs.openbsd.org>2003-04-30 22:37:12 +0000
committerMichael Shalayeff <mickey@cvs.openbsd.org>2003-04-30 22:37:12 +0000
commita7fa64c009c4503b794e61655e126fe5493d6a5c (patch)
tree05551d9782d0e9564187e07f97b10e634b68c38e /sys
parent72dec8185f03d3407362cd91da1cbdd4921126ee (diff)
from netbsd:
The AMD-K5 Model 0 gets the PGE bit in the CPU features word wrong using the APIC bit instead, according to the AMD Processor Recognition App. Note. Add a fixup routine to patch up cpu_feature in this case. XXX Need a way to kick the pmap to enable pmap_pg_g -- look at how the MP branch deals with this.
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/i386/i386/machdep.c28
1 files changed, 26 insertions, 2 deletions
diff --git a/sys/arch/i386/i386/machdep.c b/sys/arch/i386/i386/machdep.c
index 9d6b46e3a0c..84df6fe2f57 100644
--- a/sys/arch/i386/i386/machdep.c
+++ b/sys/arch/i386/i386/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.225 2003/04/17 03:56:20 drahn Exp $ */
+/* $OpenBSD: machdep.c,v 1.226 2003/04/30 22:37:11 mickey Exp $ */
/* $NetBSD: machdep.c,v 1.214 1996/11/10 03:16:17 thorpej Exp $ */
/*-
@@ -312,6 +312,7 @@ int allowaperture = 0;
#endif
void winchip_cpu_setup(const char *, int, int);
+void amd_family5_setup(const char *, int, int);
void cyrix3_cpu_setup(const char *, int, int);
void cyrix6x86_cpu_setup(const char *, int, int);
void natsem6x86_cpu_setup(const char *, int, int);
@@ -766,7 +767,7 @@ const struct cpu_cpuid_nameclass i386_cpuid_cpus[] = {
"K6-2+/III+", 0, 0,
"K5 or K6" /* Default */
},
- NULL
+ amd_family5_setup
},
/* Family 6 */
{
@@ -1183,6 +1184,29 @@ intel586_cpu_setup(cpu_device, model, step)
}
void
+amd_family5_setup(cpu_device, model, step)
+ const char *cpu_device;
+ int model, step;
+{
+ switch (model) {
+ case 0: /* AMD-K5 Model 0 */
+ /*
+ * According to the AMD Processor Recognition App Note,
+ * the AMD-K5 Model 0 uses the wrong bit to indicate
+ * support for global PTEs, instead using bit 9 (APIC)
+ * rather than bit 13 (i.e. "0x200" vs. 0x2000". Oops!).
+ */
+ if (cpu_feature & CPUID_APIC)
+ cpu_feature = (cpu_feature & ~CPUID_APIC) | CPUID_PGE;
+ /*
+ * XXX But pmap_pg_g is already initialized -- need to kick
+ * XXX the pmap somehow. How does the MP branch do this?
+ */
+ break;
+ }
+}
+
+void
intel686_cpu_setup(cpu_device, model, step)
const char *cpu_device;
int model, step;