diff options
author | Borislav Petkov <bp@suse.de> | 2013-03-20 10:07:27 -0400 |
---|---|---|
committer | H. Peter Anvin <hpa@zytor.com> | 2013-04-02 13:12:54 -0400 |
commit | e6ee94d58dfd06ec64c55f91581f00d4f98bf1f6 (patch) | |
tree | 81bfb5b71e3d579675c5490be0f77f405995a9d4 /arch/x86/kernel/cpu | |
parent | c5b41a67505cc3c9744d8f105c63a3bf3c443a01 (diff) |
x86, cpu: Convert AMD Erratum 383
Convert the AMD erratum 383 testing code to the bug infrastructure. This
allows keeping the AMD-specific erratum testing machinery private to
amd.c and not export symbols to modules needlessly.
Signed-off-by: Borislav Petkov <bp@suse.de>
Link: http://lkml.kernel.org/r/1363788448-31325-6-git-send-email-bp@alien8.de
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Diffstat (limited to 'arch/x86/kernel/cpu')
-rw-r--r-- | arch/x86/kernel/cpu/amd.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/arch/x86/kernel/cpu/amd.c b/arch/x86/kernel/cpu/amd.c index fa96eb0d02fb..85f84e13d2dd 100644 --- a/arch/x86/kernel/cpu/amd.c +++ b/arch/x86/kernel/cpu/amd.c | |||
@@ -513,6 +513,8 @@ static void __cpuinit early_init_amd(struct cpuinfo_x86 *c) | |||
513 | #endif | 513 | #endif |
514 | } | 514 | } |
515 | 515 | ||
516 | static const int amd_erratum_383[]; | ||
517 | |||
516 | static void __cpuinit init_amd(struct cpuinfo_x86 *c) | 518 | static void __cpuinit init_amd(struct cpuinfo_x86 *c) |
517 | { | 519 | { |
518 | u32 dummy; | 520 | u32 dummy; |
@@ -727,6 +729,9 @@ static void __cpuinit init_amd(struct cpuinfo_x86 *c) | |||
727 | rdmsrl_safe(MSR_AMD64_BU_CFG2, &value); | 729 | rdmsrl_safe(MSR_AMD64_BU_CFG2, &value); |
728 | value &= ~(1ULL << 24); | 730 | value &= ~(1ULL << 24); |
729 | wrmsrl_safe(MSR_AMD64_BU_CFG2, value); | 731 | wrmsrl_safe(MSR_AMD64_BU_CFG2, value); |
732 | |||
733 | if (cpu_has_amd_erratum(amd_erratum_383)) | ||
734 | set_cpu_bug(c, X86_BUG_AMD_TLB_MMATCH); | ||
730 | } | 735 | } |
731 | 736 | ||
732 | rdmsr_safe(MSR_AMD64_PATCH_LEVEL, &c->microcode, &dummy); | 737 | rdmsr_safe(MSR_AMD64_PATCH_LEVEL, &c->microcode, &dummy); |
@@ -863,9 +868,8 @@ const int amd_erratum_400[] = | |||
863 | AMD_MODEL_RANGE(0x10, 0x2, 0x1, 0xff, 0xf)); | 868 | AMD_MODEL_RANGE(0x10, 0x2, 0x1, 0xff, 0xf)); |
864 | EXPORT_SYMBOL_GPL(amd_erratum_400); | 869 | EXPORT_SYMBOL_GPL(amd_erratum_400); |
865 | 870 | ||
866 | const int amd_erratum_383[] = | 871 | static const int amd_erratum_383[] = |
867 | AMD_OSVW_ERRATUM(3, AMD_MODEL_RANGE(0x10, 0, 0, 0xff, 0xf)); | 872 | AMD_OSVW_ERRATUM(3, AMD_MODEL_RANGE(0x10, 0, 0, 0xff, 0xf)); |
868 | EXPORT_SYMBOL_GPL(amd_erratum_383); | ||
869 | 873 | ||
870 | bool cpu_has_amd_erratum(const int *erratum) | 874 | bool cpu_has_amd_erratum(const int *erratum) |
871 | { | 875 | { |