[llvm] r327030 - [x86] fix test to be independent of FP undef

Sanjay Patel via llvm-commits llvm-commits at lists.llvm.org
Thu Mar 8 09:24:30 PST 2018


Author: spatel
Date: Thu Mar  8 09:24:30 2018
New Revision: 327030

URL: http://llvm.org/viewvc/llvm-project?rev=327030&view=rev
Log:
[x86] fix test to be independent of FP undef 

Modified:
    llvm/trunk/test/CodeGen/X86/undef-label.ll

Modified: llvm/trunk/test/CodeGen/X86/undef-label.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/X86/undef-label.ll?rev=327030&r1=327029&r2=327030&view=diff
==============================================================================
--- llvm/trunk/test/CodeGen/X86/undef-label.ll (original)
+++ llvm/trunk/test/CodeGen/X86/undef-label.ll Thu Mar  8 09:24:30 2018
@@ -4,31 +4,32 @@
 ; This is a case where we would incorrectly conclude that LBB0_1 could only
 ; be reached via fall through and would therefore omit the label.
 
+ at g = global i32 0
+
 define void @xyz() {
 ; CHECK-LABEL: xyz:
 ; CHECK:       # %bb.0: # %entry
-; CHECK-NEXT:    xorpd %xmm0, %xmm0
-; CHECK-NEXT:    ucomisd %xmm0, %xmm0
+; CHECK-NEXT:    movl $g, %eax
+; CHECK-NEXT:    movq %rax, %xmm1
+; CHECK-NEXT:    xorps %xmm0, %xmm0
+; CHECK-NEXT:    ucomisd %xmm0, %xmm1
 ; CHECK-NEXT:    jne .LBB0_1
 ; CHECK-NEXT:    jnp .LBB0_3
 ; CHECK-NEXT:  .LBB0_1: # %foo.preheader
-; CHECK-NEXT:    mulsd %xmm0, %xmm1
-; CHECK-NEXT:    movapd %xmm1, %xmm0
-; CHECK-NEXT:    subsd %xmm0, %xmm0
-; CHECK-NEXT:    divsd %xmm1, %xmm0
-; CHECK-NEXT:    movsd {{.*#+}} xmm1 = mem[0],zero
+; CHECK-NEXT:    movl $g, %eax
+; CHECK-NEXT:    movq %rax, %xmm1
 ; CHECK-NEXT:    .p2align 4, 0x90
 ; CHECK-NEXT:  .LBB0_2: # %foo
 ; CHECK-NEXT:    # =>This Inner Loop Header: Depth=1
-; CHECK-NEXT:    ucomisd %xmm1, %xmm0
+; CHECK-NEXT:    ucomisd %xmm0, %xmm1
 ; CHECK-NEXT:    ja .LBB0_2
 ; CHECK-NEXT:  .LBB0_3: # %bar
 ; CHECK-NEXT:    retq
 entry:
-  br i1 fcmp oeq (double fsub (double undef, double undef), double 0.000000e+00), label %bar, label %foo
+  br i1 fcmp oeq (double bitcast (i64 ptrtoint (i32* @g to i64) to double), double 0.000000e+00), label %bar, label %foo
 
 foo:
-  br i1 fcmp ogt (double fdiv (double fsub (double fmul (double undef, double undef), double fsub (double undef, double undef)), double fmul (double undef, double undef)), double 1.0), label %foo, label %bar
+  br i1 fcmp ogt (double bitcast (i64 ptrtoint (i32* @g to i64) to double), double 0.000000e+00), label %foo, label %bar
 
 bar:
   ret void




More information about the llvm-commits mailing list