diff options
| author | Craig Topper <craig.topper@intel.com> | 2018-01-29 07:52:55 +0000 |
|---|---|---|
| committer | Craig Topper <craig.topper@intel.com> | 2018-01-29 07:52:55 +0000 |
| commit | 62b62356fae9a66a7bdbf33d5790d7db39c9af5e (patch) | |
| tree | 60b62197fd34bfe11c9ab719a3c05f4885593362 /llvm/test | |
| parent | 8b797a0fd25d8000b239c76016833ad4ab81339b (diff) | |
| download | bcm5719-llvm-62b62356fae9a66a7bdbf33d5790d7db39c9af5e.tar.gz bcm5719-llvm-62b62356fae9a66a7bdbf33d5790d7db39c9af5e.zip | |
[X86] Make foldLogicOfSetCCs work better for vectors pre legal types/operations
Summary:
There's a check in the code to only check getSetCCResultType after LegalOperations or if the type is MVT::i1. But the i1 check is only allowing scalar types through. I think it should check that the scalar type is MVT::i1 so that it will work for vectors.
The changed test already does this combine with AVX512VL where getSetCCResultType returns vXi1. But with avx512f and no VLX getSetCCResultType returns a type matching the width of the input type.
Reviewers: spatel, RKSimon
Reviewed By: spatel
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D42619
llvm-svn: 323631
Diffstat (limited to 'llvm/test')
| -rw-r--r-- | llvm/test/CodeGen/X86/avx512vl-vec-cmp.ll | 4 |
1 files changed, 1 insertions, 3 deletions
diff --git a/llvm/test/CodeGen/X86/avx512vl-vec-cmp.ll b/llvm/test/CodeGen/X86/avx512vl-vec-cmp.ll index e75e6ea0ad5..dd9ed2c0a60 100644 --- a/llvm/test/CodeGen/X86/avx512vl-vec-cmp.ll +++ b/llvm/test/CodeGen/X86/avx512vl-vec-cmp.ll @@ -1132,10 +1132,8 @@ define <8 x i32> @testnm_and(<8 x i32> %a, <8 x i32> %b, <8 x i32> %x, <8 x i32> ; NoVLX: # %bb.0: ; NoVLX-NEXT: # kill: def %ymm3 killed %ymm3 def %zmm3 ; NoVLX-NEXT: # kill: def %ymm2 killed %ymm2 def %zmm2 -; NoVLX-NEXT: # kill: def %ymm1 killed %ymm1 def %zmm1 -; NoVLX-NEXT: # kill: def %ymm0 killed %ymm0 def %zmm0 +; NoVLX-NEXT: vpor %ymm1, %ymm0, %ymm0 ; NoVLX-NEXT: vptestnmd %zmm0, %zmm0, %k1 -; NoVLX-NEXT: vptestnmd %zmm1, %zmm1, %k1 {%k1} ; NoVLX-NEXT: vpblendmd %zmm2, %zmm3, %zmm0 {%k1} ; NoVLX-NEXT: # kill: def %ymm0 killed %ymm0 killed %zmm0 ; NoVLX-NEXT: retq |

