Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / X86 / pr26870.ll
blob303696544d23a8fadf5f2c75bf8ee9a3dc680317
1 ; RUN: llc < %s -mtriple=i686-pc-windows-msvc18.0.0 -mcpu=pentium4
3 define x86_thiscallcc ptr @fn4(ptr %this, ptr dereferenceable(1) %p1) {
4 entry:
5   %call.i = tail call x86_thiscallcc i64 @fn1(ptr %this)
6   %0 = load i32, ptr %this, align 4
7   %call.i8 = tail call x86_thiscallcc i64 @fn1(ptr %this)
8   %1 = insertelement <2 x i64> undef, i64 %call.i, i32 0
9   %2 = insertelement <2 x i64> %1, i64 %call.i8, i32 1
10   %3 = add nsw <2 x i64> %2, <i64 7, i64 7>
11   %4 = sdiv <2 x i64> %3, <i64 8, i64 8>
12   %5 = add nsw <2 x i64> %4, <i64 1, i64 1>
13   %6 = load i32, ptr %this, align 4
14   %7 = insertelement <2 x i32> undef, i32 %0, i32 0
15   %8 = insertelement <2 x i32> %7, i32 %6, i32 1
16   %9 = zext <2 x i32> %8 to <2 x i64>
17   %10 = srem <2 x i64> %5, %9
18   %11 = sub <2 x i64> %5, %10
19   %12 = trunc <2 x i64> %11 to <2 x i32>
20   %13 = extractelement <2 x i32> %12, i32 0
21   %14 = extractelement <2 x i32> %12, i32 1
22   %cmp = icmp eq i32 %13, %14
23   br i1 %cmp, label %if.then, label %cleanup
25 if.then:
26   %call4 = tail call x86_thiscallcc ptr @fn3(ptr nonnull %p1)
27   br label %cleanup
29 cleanup:
30   %retval.0 = phi ptr [ %call4, %if.then ], [ undef, %entry ]
31   ret ptr %retval.0
34 declare x86_thiscallcc ptr @fn3(ptr)
35 declare x86_thiscallcc i64 @fn1(ptr)