diff options
| author | Ingo Molnar <mingo@kernel.org> | 2015-03-04 06:33:49 +0100 | 
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2015-03-04 06:36:15 +0100 | 
| commit | f8e92fb4b0ffc4d62279ab39f34e798e37e90b0b (patch) | |
| tree | 9caa8df664792e64ddcb4ea03fd418a8a529c82e /arch/x86/kernel/cpu/amd.c | |
| parent | d2c032e3dc58137a7261a7824d3acce435db1d66 (diff) | |
| parent | dfecb95cdfeaf7872d83a96bec3a606e9cd95c8d (diff) | |
Merge tag 'alternatives_padding' of git://git.kernel.org/pub/scm/linux/kernel/git/bp/bp into x86/asm
Pull alternative instructions framework improvements from Borislav Petkov:
 "A more involved rework of the alternatives framework to be able to
  pad instructions and thus make using the alternatives macros more
  straightforward and without having to figure out old and new instruction
  sizes but have the toolchain figure that out for us.
  Furthermore, it optimizes JMPs used so that fetch and decode can be
  relieved with smaller versions of the JMPs, where possible.
  Some stats:
    x86_64 defconfig:
    Alternatives sites total:               2478
    Total padding added (in Bytes):         6051
  The padding is currently done for:
    X86_FEATURE_ALWAYS
    X86_FEATURE_ERMS
    X86_FEATURE_LFENCE_RDTSC
    X86_FEATURE_MFENCE_RDTSC
    X86_FEATURE_SMAP
  This is with the latest version of the patchset. Of course, on each
  machine the alternatives sites actually being patched are a proper
  subset of the total number."
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'arch/x86/kernel/cpu/amd.c')
| -rw-r--r-- | arch/x86/kernel/cpu/amd.c | 5 | 
1 files changed, 5 insertions, 0 deletions
| diff --git a/arch/x86/kernel/cpu/amd.c b/arch/x86/kernel/cpu/amd.c index a220239cea65..dd9e50500297 100644 --- a/arch/x86/kernel/cpu/amd.c +++ b/arch/x86/kernel/cpu/amd.c @@ -711,6 +711,11 @@ static void init_amd(struct cpuinfo_x86 *c)  		set_cpu_bug(c, X86_BUG_AMD_APIC_C1E);  	rdmsr_safe(MSR_AMD64_PATCH_LEVEL, &c->microcode, &dummy); + +	/* 3DNow or LM implies PREFETCHW */ +	if (!cpu_has(c, X86_FEATURE_3DNOWPREFETCH)) +		if (cpu_has(c, X86_FEATURE_3DNOW) || cpu_has(c, X86_FEATURE_LM)) +			set_cpu_cap(c, X86_FEATURE_3DNOWPREFETCH);  }  #ifdef CONFIG_X86_32 | 
