[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