diff options
author | Gayatri Kammela <gayatri.kammela@intel.com> | 2017-10-30 21:20:29 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2017-10-31 06:02:26 -0400 |
commit | c128dbfa0f879f8ce7b79054037889b0b2240728 (patch) | |
tree | 347a83c5ec8a22ec7d4b8280d315f7b06b2009dc | |
parent | 57b8b1a1856adaa849d02d547411a553a531022b (diff) |
x86/cpufeatures: Enable new SSE/AVX/AVX512 CPU features
Add a few new SSE/AVX/AVX512 instruction groups/features for enumeration
in /proc/cpuinfo: AVX512_VBMI2, GFNI, VAES, VPCLMULQDQ, AVX512_VNNI,
AVX512_BITALG.
CPUID.(EAX=7,ECX=0):ECX[bit 6] AVX512_VBMI2
CPUID.(EAX=7,ECX=0):ECX[bit 8] GFNI
CPUID.(EAX=7,ECX=0):ECX[bit 9] VAES
CPUID.(EAX=7,ECX=0):ECX[bit 10] VPCLMULQDQ
CPUID.(EAX=7,ECX=0):ECX[bit 11] AVX512_VNNI
CPUID.(EAX=7,ECX=0):ECX[bit 12] AVX512_BITALG
Detailed information of CPUID bits for these features can be found
in the Intel Architecture Instruction Set Extensions and Future Features
Programming Interface document (refer to Table 1-1. and Table 1-2.).
A copy of this document is available at
https://bugzilla.kernel.org/show_bug.cgi?id=197239
Signed-off-by: Gayatri Kammela <gayatri.kammela@intel.com>
Acked-by: Thomas Gleixner <tglx@linutronix.de>
Cc: Andi Kleen <andi.kleen@intel.com>
Cc: Fenghua Yu <fenghua.yu@intel.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Ravi Shankar <ravi.v.shankar@intel.com>
Cc: Ricardo Neri <ricardo.neri@intel.com>
Cc: Yang Zhong <yang.zhong@intel.com>
Cc: bp@alien8.de
Link: http://lkml.kernel.org/r/1509412829-23380-1-git-send-email-gayatri.kammela@intel.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
-rw-r--r-- | arch/x86/include/asm/cpufeatures.h | 6 | ||||
-rw-r--r-- | arch/x86/kernel/cpu/cpuid-deps.c | 6 |
2 files changed, 12 insertions, 0 deletions
diff --git a/arch/x86/include/asm/cpufeatures.h b/arch/x86/include/asm/cpufeatures.h index 401a70992060..b0556f882aa8 100644 --- a/arch/x86/include/asm/cpufeatures.h +++ b/arch/x86/include/asm/cpufeatures.h | |||
@@ -299,6 +299,12 @@ | |||
299 | #define X86_FEATURE_AVX512VBMI (16*32+ 1) /* AVX512 Vector Bit Manipulation instructions*/ | 299 | #define X86_FEATURE_AVX512VBMI (16*32+ 1) /* AVX512 Vector Bit Manipulation instructions*/ |
300 | #define X86_FEATURE_PKU (16*32+ 3) /* Protection Keys for Userspace */ | 300 | #define X86_FEATURE_PKU (16*32+ 3) /* Protection Keys for Userspace */ |
301 | #define X86_FEATURE_OSPKE (16*32+ 4) /* OS Protection Keys Enable */ | 301 | #define X86_FEATURE_OSPKE (16*32+ 4) /* OS Protection Keys Enable */ |
302 | #define X86_FEATURE_AVX512_VBMI2 (16*32+ 6) /* Additional AVX512 Vector Bit Manipulation Instructions */ | ||
303 | #define X86_FEATURE_GFNI (16*32+ 8) /* Galois Field New Instructions */ | ||
304 | #define X86_FEATURE_VAES (16*32+ 9) /* Vector AES */ | ||
305 | #define X86_FEATURE_VPCLMULQDQ (16*32+ 10) /* Carry-Less Multiplication Double Quadword */ | ||
306 | #define X86_FEATURE_AVX512_VNNI (16*32+ 11) /* Vector Neural Network Instructions */ | ||
307 | #define X86_FEATURE_AVX512_BITALG (16*32+12) /* Support for VPOPCNT[B,W] and VPSHUF-BITQMB */ | ||
302 | #define X86_FEATURE_AVX512_VPOPCNTDQ (16*32+14) /* POPCNT for vectors of DW/QW */ | 308 | #define X86_FEATURE_AVX512_VPOPCNTDQ (16*32+14) /* POPCNT for vectors of DW/QW */ |
303 | #define X86_FEATURE_LA57 (16*32+16) /* 5-level page tables */ | 309 | #define X86_FEATURE_LA57 (16*32+16) /* 5-level page tables */ |
304 | #define X86_FEATURE_RDPID (16*32+22) /* RDPID instruction */ | 310 | #define X86_FEATURE_RDPID (16*32+22) /* RDPID instruction */ |
diff --git a/arch/x86/kernel/cpu/cpuid-deps.c b/arch/x86/kernel/cpu/cpuid-deps.c index c1d49842a411..c21f22d836ad 100644 --- a/arch/x86/kernel/cpu/cpuid-deps.c +++ b/arch/x86/kernel/cpu/cpuid-deps.c | |||
@@ -50,6 +50,12 @@ const static struct cpuid_dep cpuid_deps[] = { | |||
50 | { X86_FEATURE_AVX512BW, X86_FEATURE_AVX512F }, | 50 | { X86_FEATURE_AVX512BW, X86_FEATURE_AVX512F }, |
51 | { X86_FEATURE_AVX512VL, X86_FEATURE_AVX512F }, | 51 | { X86_FEATURE_AVX512VL, X86_FEATURE_AVX512F }, |
52 | { X86_FEATURE_AVX512VBMI, X86_FEATURE_AVX512F }, | 52 | { X86_FEATURE_AVX512VBMI, X86_FEATURE_AVX512F }, |
53 | { X86_FEATURE_AVX512_VBMI2, X86_FEATURE_AVX512VL }, | ||
54 | { X86_FEATURE_GFNI, X86_FEATURE_AVX512VL }, | ||
55 | { X86_FEATURE_VAES, X86_FEATURE_AVX512VL }, | ||
56 | { X86_FEATURE_VPCLMULQDQ, X86_FEATURE_AVX512VL }, | ||
57 | { X86_FEATURE_AVX512_VNNI, X86_FEATURE_AVX512VL }, | ||
58 | { X86_FEATURE_AVX512_BITALG, X86_FEATURE_AVX512VL }, | ||
53 | { X86_FEATURE_AVX512_4VNNIW, X86_FEATURE_AVX512F }, | 59 | { X86_FEATURE_AVX512_4VNNIW, X86_FEATURE_AVX512F }, |
54 | { X86_FEATURE_AVX512_4FMAPS, X86_FEATURE_AVX512F }, | 60 | { X86_FEATURE_AVX512_4FMAPS, X86_FEATURE_AVX512F }, |
55 | { X86_FEATURE_AVX512_VPOPCNTDQ, X86_FEATURE_AVX512F }, | 61 | { X86_FEATURE_AVX512_VPOPCNTDQ, X86_FEATURE_AVX512F }, |