[PATCH] D25692: [AVX-512] Disassembler support for rounding control and SAE attribute.

Maksim Panchenko via llvm-commits llvm-commits at lists.llvm.org
Tue Oct 25 15:16:27 PDT 2016


maksfb marked 2 inline comments as done.
maksfb added inline comments.


================
Comment at: lib/Target/X86/X86InstrAVX512.td:1886
                                     imm:$cc,
-                                (i32 FROUND_NO_EXC))>, EVEX_B;
+                                (i32 FROUND_NO_EXC))>, VEX_LIG, EVEX_B;
 
----------------
delena wrote:
> I don't see LIG specification in the "sae" form of VCMP:
> 
> EVEX.NDS.512.66.0F.W1 C2 /r ib FV V/V AVX512F Compare packed double-precision floating-point values
> in zmm3/m512/m64bcst and zmm2 using bits 4:0 of
> imm8 as a comparison predicate with writemask k2
> and leave the result in mask register k1.
> VCMPPD k1 {k2}, zmm2,
> zmm3/m512/m64bcst{sae}, imm8
The spec for SAE says it "applies to scalar and 512-bit vector lengths". I don't know how CPU actually treats `L'L` when `{sae}` is set, except that  LLVM assembler generates `{0,0}`, not `{1,0}` that corresponds to 512-bit length.

As a result if you feed assembler output to disassembler it causes disassembler to fail.

I can speculate that LIG is implied in this case, but folks at Intel would know better. Could you check?


================
Comment at: lib/Target/X86/X86InstrAVX512.td:5817
+    defm Z : avx512_cvt_fp_rc_scalar<opc, OpcodeStr, _dst, _src,
+                               OpNodeRnd>, VEX_W, EVEX_CD8<64, CD8VT1>, XD;
   }
----------------
delena wrote:
> Why do you need to remove EVEX_V512 from the second pattern?
Because RC implies 512-bit length ("Vector Length Orthogonality"), and putting EVEX_V512 enforces disassembler to accept `L'L={1,0}` only, while LLVM assembler generates `{0,0}` IIRC.


https://reviews.llvm.org/D25692





More information about the llvm-commits mailing list