From: Igor Breger Date: Mon, 31 Aug 2015 13:30:19 +0000 (+0000) Subject: AVX512: ktest implemantation X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=046f79fbb05a29c381ceb0bc971e1a377f9a62f4;p=oota-llvm.git AVX512: ktest implemantation Added tests for encoding. Differential Revision: http://reviews.llvm.org/D11979 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@246439 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Target/X86/X86ISelLowering.cpp b/lib/Target/X86/X86ISelLowering.cpp index 9817e23ef11..707fa5e6c6e 100644 --- a/lib/Target/X86/X86ISelLowering.cpp +++ b/lib/Target/X86/X86ISelLowering.cpp @@ -19317,6 +19317,7 @@ const char *X86TargetLowering::getTargetNodeName(unsigned Opcode) const { case X86ISD::TESTM: return "X86ISD::TESTM"; case X86ISD::TESTNM: return "X86ISD::TESTNM"; case X86ISD::KORTEST: return "X86ISD::KORTEST"; + case X86ISD::KTEST: return "X86ISD::KTEST"; case X86ISD::PACKSS: return "X86ISD::PACKSS"; case X86ISD::PACKUS: return "X86ISD::PACKUS"; case X86ISD::PALIGNR: return "X86ISD::PALIGNR"; diff --git a/lib/Target/X86/X86ISelLowering.h b/lib/Target/X86/X86ISelLowering.h index daa1ab23677..b48fdbc135b 100644 --- a/lib/Target/X86/X86ISelLowering.h +++ b/lib/Target/X86/X86ISelLowering.h @@ -352,6 +352,7 @@ namespace llvm { // OR/AND test for masks KORTEST, + KTEST, // Several flavors of instructions with vector shuffle behaviors. PACKSS, diff --git a/lib/Target/X86/X86InstrAVX512.td b/lib/Target/X86/X86InstrAVX512.td index 3c11e96f864..170cd8d5232 100644 --- a/lib/Target/X86/X86InstrAVX512.td +++ b/lib/Target/X86/X86InstrAVX512.td @@ -2080,28 +2080,27 @@ defm : avx512_mask_unpck_int<"kunpck", "KUNPCK">; // Mask bit testing multiclass avx512_mask_testop opc, string OpcodeStr, RegisterClass KRC, - SDNode OpNode> { - let Predicates = [HasAVX512], Defs = [EFLAGS] in + SDNode OpNode, Predicate prd> { + let Predicates = [prd], Defs = [EFLAGS] in def rr : I; } -multiclass avx512_mask_testop_w opc, string OpcodeStr, SDNode OpNode> { - defm W : avx512_mask_testop, - VEX, PS; - let Predicates = [HasDQI] in - defm B : avx512_mask_testop, - VEX, PD; - let Predicates = [HasBWI] in { - defm Q : avx512_mask_testop, - VEX, PS, VEX_W; - defm D : avx512_mask_testop, - VEX, PD, VEX_W; - } +multiclass avx512_mask_testop_w opc, string OpcodeStr, SDNode OpNode, + Predicate prdW = HasAVX512> { + defm B : avx512_mask_testop, + VEX, PD; + defm W : avx512_mask_testop, + VEX, PS; + defm Q : avx512_mask_testop, + VEX, PS, VEX_W; + defm D : avx512_mask_testop, + VEX, PD, VEX_W; } defm KORTEST : avx512_mask_testop_w<0x98, "kortest", X86kortest>; +defm KTEST : avx512_mask_testop_w<0x99, "ktest", X86ktest, HasDQI>; // Mask shift multiclass avx512_mask_shiftop opc, string OpcodeStr, RegisterClass KRC, diff --git a/lib/Target/X86/X86InstrFragmentsSIMD.td b/lib/Target/X86/X86InstrFragmentsSIMD.td index 5cd04d84347..aa005a19016 100644 --- a/lib/Target/X86/X86InstrFragmentsSIMD.td +++ b/lib/Target/X86/X86InstrFragmentsSIMD.td @@ -191,6 +191,7 @@ def X86avg : SDNode<"X86ISD::AVG" , SDTIntBinOp>; def X86ptest : SDNode<"X86ISD::PTEST", SDTX86CmpPTest>; def X86testp : SDNode<"X86ISD::TESTP", SDTX86CmpPTest>; def X86kortest : SDNode<"X86ISD::KORTEST", SDTX86CmpPTest>; +def X86ktest : SDNode<"X86ISD::KTEST", SDTX86CmpPTest>; def X86testm : SDNode<"X86ISD::TESTM", SDTypeProfile<1, 2, [SDTCisVec<0>, SDTCisVec<1>, SDTCisSameAs<2, 1>, SDTCVecEltisVT<0, i1>, diff --git a/test/MC/X86/avx512-encodings.s b/test/MC/X86/avx512-encodings.s index c0ef0cb0e29..c9f7334445b 100644 --- a/test/MC/X86/avx512-encodings.s +++ b/test/MC/X86/avx512-encodings.s @@ -14958,6 +14958,10 @@ vpermilpd $0x23, 0x400(%rbx), %zmm2 // CHECK: encoding: [0x62,0xf2,0xc5,0x08,0x43,0x92,0xf8,0xfb,0xff,0xff] vgetexpsd -1032(%rdx), %xmm7, %xmm2 +// CHECK: kortestw %k6, %k2 +// CHECK: encoding: [0xc5,0xf8,0x98,0xd6] + kortestw %k6, %k2 + // CHECK: vscatterqps %ymm6, 123(%r14,%zmm27,8) {%k1} // CHECK: encoding: [0x62,0x92,0x7d,0x41,0xa3,0xb4,0xde,0x7b,0x00,0x00,0x00] vscatterqps %ymm6, 123(%r14,%zmm27,8) {%k1} diff --git a/test/MC/X86/x86-64-avx512bw.s b/test/MC/X86/x86-64-avx512bw.s index c83e525e282..a13c49aaac6 100644 --- a/test/MC/X86/x86-64-avx512bw.s +++ b/test/MC/X86/x86-64-avx512bw.s @@ -4112,6 +4112,22 @@ // CHECK: encoding: [0x62,0x61,0x2d,0x40,0x69,0xb2,0xc0,0xdf,0xff,0xff] vpunpckhwd -8256(%rdx), %zmm26, %zmm30 +// CHECK: ktestd %k3, %k3 +// CHECK: encoding: [0xc4,0xe1,0xf9,0x99,0xdb] + ktestd %k3, %k3 + +// CHECK: ktestq %k6, %k2 +// CHECK: encoding: [0xc4,0xe1,0xf8,0x99,0xd6] + ktestq %k6, %k2 + +// CHECK: kortestd %k3, %k4 +// CHECK: encoding: [0xc4,0xe1,0xf9,0x98,0xe3] + kortestd %k3, %k4 + +// CHECK: kortestq %k4, %k5 +// CHECK: encoding: [0xc4,0xe1,0xf8,0x98,0xec] + kortestq %k4, %k5 + // CHECK: kaddd %k6, %k6, %k2 // CHECK: encoding: [0xc4,0xe1,0xcd,0x4a,0xd6] kaddd %k6, %k6, %k2 diff --git a/test/MC/X86/x86-64-avx512dq.s b/test/MC/X86/x86-64-avx512dq.s index c1fae622780..354b1e0187d 100644 --- a/test/MC/X86/x86-64-avx512dq.s +++ b/test/MC/X86/x86-64-avx512dq.s @@ -2371,6 +2371,30 @@ // CHECK: encoding: [0x62,0xa1,0xff,0xca,0x7a,0xd5] vcvtuqq2ps %zmm21, %ymm18 {%k2} {z} +// CHECK: ktestb %k6, %k4 +// CHECK: encoding: [0xc5,0xf9,0x99,0xe6] + ktestb %k6, %k4 + +// CHECK: ktestb %k4, %k5 +// CHECK: encoding: [0xc5,0xf9,0x99,0xec] + ktestb %k4, %k5 + +// CHECK: ktestw %k4, %k5 +// CHECK: encoding: [0xc5,0xf8,0x99,0xec] + ktestw %k4, %k5 + +// CHECK: ktestw %k6, %k2 +// CHECK: encoding: [0xc5,0xf8,0x99,0xd6] + ktestw %k6, %k2 + +// CHECK: kortestb %k3, %k2 +// CHECK: encoding: [0xc5,0xf9,0x98,0xd3] + kortestb %k3, %k2 + +// CHECK: kortestb %k6, %k2 +// CHECK: encoding: [0xc5,0xf9,0x98,0xd6] + kortestb %k6, %k2 + // CHECK: kaddb %k7, %k4, %k5 // CHECK: encoding: [0xc5,0xdd,0x4a,0xef] kaddb %k7, %k4, %k5