AVX-512: Fixed size of mask registers
authorElena Demikhovsky <elena.demikhovsky@intel.com>
Tue, 18 Feb 2014 07:52:26 +0000 (07:52 +0000)
committerElena Demikhovsky <elena.demikhovsky@intel.com>
Tue, 18 Feb 2014 07:52:26 +0000 (07:52 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@201546 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/X86/X86RegisterInfo.td

index 8d79e13b1db87391458f50ec6797aa2990ff5058..a88b2bb1f15a4f95bf3667a705be32c31a6e8a1f 100644 (file)
@@ -463,11 +463,13 @@ def VR128X : RegisterClass<"X86", [v16i8, v8i16, v4i32, v2i64, v4f32, v2f64],
 def VR256X : RegisterClass<"X86", [v32i8, v16i16, v8i32, v4i64, v8f32, v4f64],
                           256, (sequence "YMM%u", 0, 31)>;
 
-def VK1     : RegisterClass<"X86", [i1],     1, (sequence "K%u", 0, 7)>;
-def VK8     : RegisterClass<"X86", [v8i1],   8, (sequence "K%u", 0, 7)>;
+// The size of the all masked registers is 16 bit because we have only one
+// KMOVW istruction that can store this register in memory, and it writes 2 bytes
+def VK1     : RegisterClass<"X86", [i1],    16, (sequence "K%u", 0, 7)>;
+def VK8     : RegisterClass<"X86", [v8i1],  16, (sequence "K%u", 0, 7)>;
 def VK16    : RegisterClass<"X86", [v16i1], 16, (add VK8)>;
 
-def VK1WM   : RegisterClass<"X86", [i1],     1, (sub VK1, K0)>;
-def VK8WM   : RegisterClass<"X86", [v8i1],   8, (sub VK8, K0)>;
+def VK1WM   : RegisterClass<"X86", [i1],    16, (sub VK1, K0)>;
+def VK8WM   : RegisterClass<"X86", [v8i1],  16, (sub VK8, K0)>;
 def VK16WM  : RegisterClass<"X86", [v16i1], 16, (add VK8WM)>;