[PATCH] D148446: [X86][tablgen] Remove predicates for definitions of KMOV b/c due to no pattern, NFCI

Kan Shengchen via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Sat Apr 15 22:28:44 PDT 2023


skan abandoned this revision.
skan marked 2 inline comments as done.
skan added inline comments.


================
Comment at: llvm/lib/Target/X86/X86InstrAVX512.td:2885
 
-let Predicates = [HasDQI] in
-  defm KMOVB : avx512_mask_mov<0x90, 0x90, 0x91, "kmovb", VK8, v8i1, i8mem>,
-               avx512_mask_mov_gpr<0x92, 0x93, "kmovb", VK8, GR32>,
-               VEX, PD;
-
-let Predicates = [HasAVX512] in
-  defm KMOVW : avx512_mask_mov<0x90, 0x90, 0x91, "kmovw", VK16, v16i1, i16mem>,
-               avx512_mask_mov_gpr<0x92, 0x93, "kmovw", VK16, GR32>,
-               VEX, PS;
-
-let Predicates = [HasBWI] in {
-  defm KMOVD : avx512_mask_mov<0x90, 0x90, 0x91, "kmovd", VK32, v32i1,i32mem>,
-               VEX, PD, REX_W;
-  defm KMOVD : avx512_mask_mov_gpr<0x92, 0x93, "kmovd", VK32, GR32>,
-               VEX, XD;
-  defm KMOVQ : avx512_mask_mov<0x90, 0x90, 0x91, "kmovq", VK64, v64i1, i64mem>,
-               VEX, PS, REX_W;
-  defm KMOVQ : avx512_mask_mov_gpr<0x92, 0x93, "kmovq", VK64, GR64>,
-               VEX, XD, REX_W;
-}
+defm KMOVB : avx512_mask_mov<0x90, 0x90, 0x91, "kmovb", VK8, v8i1, i8mem>,
+             avx512_mask_mov_gpr<0x92, 0x93, "kmovb", VK8, GR32>,
----------------
craig.topper wrote:
> craig.topper wrote:
> > Aren't there patterns for load/store in avx512_mask_mov?
> It probably doesn't fail any tests because the types involved are only legal when the predicate is true or because lowering knew to change the load/store because it wasn't supported.
Ah, you're right. I didn't notice there is pattern in the definition of  `avx512_mask_mov`. Now I believe this change does not make sense.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D148446/new/

https://reviews.llvm.org/D148446



More information about the llvm-commits mailing list