diff options
author | Jason Downs <downsj@cvs.openbsd.org> | 1999-03-08 23:47:27 +0000 |
---|---|---|
committer | Jason Downs <downsj@cvs.openbsd.org> | 1999-03-08 23:47:27 +0000 |
commit | 4d5babe9a53a5ba8e34500bef93832521e116ba6 (patch) | |
tree | b166b51a1410c9cd064f29d5504332b7d65b26c0 /sys/arch/i386/include | |
parent | 2492f35aa95abb2800f1632d1049bbc8c334c96f (diff) |
Add support for CPUID level 2. This is used to determine the L2 cache size
on Intel processors; print out the correct CPU name and cache size at boot.
Also clean up the feature flags, including PPro errata.
Diffstat (limited to 'sys/arch/i386/include')
-rw-r--r-- | sys/arch/i386/include/cpu.h | 6 | ||||
-rw-r--r-- | sys/arch/i386/include/specialreg.h | 16 |
2 files changed, 13 insertions, 9 deletions
diff --git a/sys/arch/i386/include/cpu.h b/sys/arch/i386/include/cpu.h index 150f927211f..41187f703b1 100644 --- a/sys/arch/i386/include/cpu.h +++ b/sys/arch/i386/include/cpu.h @@ -1,4 +1,4 @@ -/* $OpenBSD: cpu.h,v 1.25 1999/02/23 04:10:12 marc Exp $ */ +/* $OpenBSD: cpu.h,v 1.26 1999/03/08 23:47:25 downsj Exp $ */ /* $NetBSD: cpu.h,v 1.35 1996/05/05 19:29:26 christos Exp $ */ /*- @@ -134,7 +134,7 @@ struct cpu_nocpuid_nameclass { const char *cpu_vendorname; const char *cpu_name; int cpu_class; - void (*cpu_setup) __P((const char *, int)); + void (*cpu_setup) __P((const char *, int, int)); }; struct cpu_cpuid_nameclass { @@ -144,7 +144,7 @@ struct cpu_cpuid_nameclass { struct cpu_cpuid_family { int cpu_class; const char *cpu_models[CPU_MAXMODEL+2]; - void (*cpu_setup) __P((const char *, int)); + void (*cpu_setup) __P((const char *, int, int)); } cpu_family[CPU_MAXFAMILY - CPU_MINFAMILY + 1]; }; diff --git a/sys/arch/i386/include/specialreg.h b/sys/arch/i386/include/specialreg.h index 22e37f88f5e..d3b8c027aff 100644 --- a/sys/arch/i386/include/specialreg.h +++ b/sys/arch/i386/include/specialreg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: specialreg.h,v 1.6 1999/02/24 22:05:15 deraadt Exp $ */ +/* $OpenBSD: specialreg.h,v 1.7 1999/03/08 23:47:25 downsj Exp $ */ /* $NetBSD: specialreg.h,v 1.7 1994/10/27 04:16:26 cgd Exp $ */ /*- @@ -93,7 +93,7 @@ #define CPUID_FPU 0x00000001 /* processor has an FPU? */ #define CPUID_VME 0x00000002 /* has virtual mode (%cr4's VME/PVI) */ #define CPUID_DE 0x00000004 /* has debugging extension */ -#define CPUID_PSE 0x00000008 /* has page 4MB page size extension */ +#define CPUID_PSE 0x00000008 /* has 4MB page size extension */ #define CPUID_TSC 0x00000010 /* has time stamp counter */ #define CPUID_MSR 0x00000020 /* has mode specific registers */ #define CPUID_PAE 0x00000040 /* has phys address extension */ @@ -101,15 +101,19 @@ #define CPUID_CX8 0x00000100 /* has CMPXCHG8B instruction */ #define CPUID_APIC 0x00000200 /* has enabled APIC */ #define CPUID_SYS1 0x00000400 /* has SYSCALL/SYSRET inst. (Cyrix) */ -#define CPUID_SYS2 0x00000800 /* has SYSCALL/SYSRET inst. (AMD) */ +#define CPUID_SYS2 0x00000800 /* has SYSCALL/SYSRET inst. (AMD/Intel) */ #define CPUID_MTRR 0x00001000 /* has memory type range register */ #define CPUID_PGE 0x00002000 /* has page global extension */ #define CPUID_MCA 0x00004000 /* has machine check architecture */ #define CPUID_CMOV 0x00008000 /* has CMOVcc instruction */ +#define CPUID_PAT 0x00010000 /* has page attribute table */ +#define CPUID_PSE36 0x00020000 /* has 36bit page size extension */ +#define CPUID_SER 0x00040000 /* has processor serial number */ #define CPUID_MMX 0x00800000 /* has MMX instructions */ -#define CPUID_EMMX 0x01000000 /* has extended MMX (Cyrix) */ -#define CPUID_3D 0x80000000 /* has AMD-3D instructions (AMD) */ -#define CPUID_MMX2 0x02000000 /* has Intel MMX-2 instructions */ +#define CPUID_FXSR 0x01000000 /* has FXRSTOR instruction (Intel) */ +#define CPUID_EMMX 0x01000000 /* has extended MMX (Cyrix; obsolete) */ +#define CPUID_SIMD 0x02000000 /* has SIMD instructions (Intel) */ +#define CPUID_3DNOW 0x80000000 /* has 3DNow! instructions (AMD) */ /* * the following four 3-byte registers control the non-cacheable regions. |