[llvm] r353580 - [x86] add test for miscompiling setcc transform (PR40657); NFC
Sanjay Patel via llvm-commits
llvm-commits at lists.llvm.org
Fri Feb 8 15:34:57 PST 2019
Author: spatel
Date: Fri Feb 8 15:34:57 2019
New Revision: 353580
URL: http://llvm.org/viewvc/llvm-project?rev=353580&view=rev
Log:
[x86] add test for miscompiling setcc transform (PR40657); NFC
Modified:
llvm/trunk/test/CodeGen/X86/setcc-combine.ll
Modified: llvm/trunk/test/CodeGen/X86/setcc-combine.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/X86/setcc-combine.ll?rev=353580&r1=353579&r2=353580&view=diff
==============================================================================
--- llvm/trunk/test/CodeGen/X86/setcc-combine.ll (original)
+++ llvm/trunk/test/CodeGen/X86/setcc-combine.ll Fri Feb 8 15:34:57 2019
@@ -262,3 +262,21 @@ define void @test_i1_uge(i1 *%A2) {
ret void
}
+; FIXME: This should not get folded to 0.
+
+define i64 @PR40657(i8 %var2, i8 %var9) {
+; CHECK-LABEL: PR40657:
+; CHECK: # %bb.0:
+; CHECK-NEXT: xorl %eax, %eax
+; CHECK-NEXT: retq
+ %var6 = trunc i8 %var9 to i1
+ %var7 = trunc i8 175 to i1
+ %var3 = sub nsw i1 %var6, %var7
+ %var4 = icmp eq i64 1114591064, 1114591064
+ %var1 = udiv i1 %var3, %var4
+ %var0 = trunc i8 %var2 to i1
+ %res = sub nsw nuw i1 %var0, %var1
+ %res.cast = zext i1 %res to i64
+ ret i64 %res.cast
+}
+
More information about the llvm-commits
mailing list