[PATCH] D124756: Update movmsk-cmp.ll to match improvements made to InstCombine
Amaury SECHET via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon May 2 03:45:08 PDT 2022
deadalnix updated this revision to Diff 426370.
deadalnix added a comment.
Keep the unoptimized test case.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D124756/new/
https://reviews.llvm.org/D124756
Files:
llvm/test/CodeGen/X86/movmsk-cmp.ll
Index: llvm/test/CodeGen/X86/movmsk-cmp.ll
===================================================================
--- llvm/test/CodeGen/X86/movmsk-cmp.ll
+++ llvm/test/CodeGen/X86/movmsk-cmp.ll
@@ -4539,6 +4539,8 @@
ret i1 %val
}
+; TODO: We expect similar result as for PR39665_c_ray_opt,
+; but this is not the case in practice.
define i32 @PR39665_c_ray(<2 x double> %x, <2 x double> %y) {
; SSE-LABEL: PR39665_c_ray:
; SSE: # %bb.0:
@@ -4597,3 +4599,55 @@
%r = select i1 %u, i32 42, i32 99
ret i32 %r
}
+
+define i32 @PR39665_c_ray_opt(<2 x double> %x, <2 x double> %y) {
+; SSE-LABEL: PR39665_c_ray_opt:
+; SSE: # %bb.0:
+; SSE-NEXT: cmpltpd %xmm0, %xmm1
+; SSE-NEXT: movmskpd %xmm1, %eax
+; SSE-NEXT: cmpb $3, %al
+; SSE-NEXT: movl $42, %ecx
+; SSE-NEXT: movl $99, %eax
+; SSE-NEXT: cmovel %ecx, %eax
+; SSE-NEXT: retq
+;
+; AVX1OR2-LABEL: PR39665_c_ray_opt:
+; AVX1OR2: # %bb.0:
+; AVX1OR2-NEXT: vcmpltpd %xmm0, %xmm1, %xmm0
+; AVX1OR2-NEXT: vmovmskpd %xmm0, %eax
+; AVX1OR2-NEXT: cmpb $3, %al
+; AVX1OR2-NEXT: movl $42, %ecx
+; AVX1OR2-NEXT: movl $99, %eax
+; AVX1OR2-NEXT: cmovel %ecx, %eax
+; AVX1OR2-NEXT: retq
+;
+; KNL-LABEL: PR39665_c_ray_opt:
+; KNL: # %bb.0:
+; KNL-NEXT: # kill: def $xmm1 killed $xmm1 def $zmm1
+; KNL-NEXT: # kill: def $xmm0 killed $xmm0 def $zmm0
+; KNL-NEXT: vcmpltpd %zmm0, %zmm1, %k0
+; KNL-NEXT: knotw %k0, %k0
+; KNL-NEXT: kmovw %k0, %eax
+; KNL-NEXT: testb $3, %al
+; KNL-NEXT: movl $42, %ecx
+; KNL-NEXT: movl $99, %eax
+; KNL-NEXT: cmovel %ecx, %eax
+; KNL-NEXT: vzeroupper
+; KNL-NEXT: retq
+;
+; SKX-LABEL: PR39665_c_ray_opt:
+; SKX: # %bb.0:
+; SKX-NEXT: vcmpltpd %xmm0, %xmm1, %k0
+; SKX-NEXT: kmovd %k0, %eax
+; SKX-NEXT: cmpb $3, %al
+; SKX-NEXT: movl $42, %ecx
+; SKX-NEXT: movl $99, %eax
+; SKX-NEXT: cmovel %ecx, %eax
+; SKX-NEXT: retq
+ %cmp = fcmp ogt <2 x double> %x, %y
+ %shift = shufflevector <2 x i1> %cmp, <2 x i1> poison, <2 x i32> <i32 1, i32 undef>
+ %1 = and <2 x i1> %cmp, %shift
+ %u = extractelement <2 x i1> %1, i64 0
+ %r = select i1 %u, i32 42, i32 99
+ ret i32 %r
+}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D124756.426370.patch
Type: text/x-patch
Size: 2184 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20220502/77130e74/attachment.bin>
More information about the llvm-commits
mailing list