Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / ARM / arm-frame-lowering-no-terminator.ll
blob1ea5b4b9c25831878879387460875ae9837c3704
1 ; RUN: llc < %s
2 ; Ensure that ARMFrameLowering can emit an epilogue when there's no terminator.
3 ; This is the crasher from PR29072.
5 target datalayout = "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64"
6 target triple = "armv7-unknown-linux-gnueabihf"
8 %t1 = type { [4 x float] }
9 %t3 = type { ptr }
10 %t2 = type { %t3, i8, %t1, %t1, float }
12 define internal void @foo(ptr nocapture %this, ptr nocapture readonly %triangle, i32 %partId, i32 %triangleIndex) {
13 entry:
14   br i1 undef, label %if.else, label %if.end
16 if.else:                                          ; preds = %entry
17   %0 = load float, ptr %triangle, align 4
18   %arrayidx5.i = getelementptr inbounds %t1, ptr %triangle, i32 0, i32 0, i32 1
19   %1 = load float, ptr %arrayidx5.i, align 4
20   %2 = load float, ptr null, align 4
21   %arrayidx11.i = getelementptr inbounds %t1, ptr %triangle, i32 0, i32 0, i32 2
22   %3 = load float, ptr %arrayidx11.i, align 4
23   %arrayidx13.i = getelementptr inbounds %t2, ptr %this, i32 0, i32 2, i32 0, i32 2
24   %4 = load float, ptr %arrayidx13.i, align 4
25   %arrayidx.i129 = getelementptr inbounds %t1, ptr %triangle, i32 1, i32 0, i32 0
26   %5 = load float, ptr %arrayidx.i129, align 4
27   %sub.i131 = fsub float %5, 0.000000e+00
28   %arrayidx5.i132 = getelementptr inbounds %t1, ptr %triangle, i32 1, i32 0, i32 1
29   %6 = load float, ptr %arrayidx5.i132, align 4
30   %sub8.i134 = fsub float %6, %2
31   %arrayidx11.i135 = getelementptr inbounds %t1, ptr %triangle, i32 1, i32 0, i32 2
32   %7 = load float, ptr %arrayidx11.i135, align 4
33   %sub14.i137 = fsub float %7, %4
34   %arrayidx.i149 = getelementptr inbounds %t1, ptr %triangle, i32 2, i32 0, i32 0
35   %8 = load float, ptr %arrayidx.i149, align 4
36   %sub.i151 = fsub float %8, 0.000000e+00
37   %arrayidx5.i152 = getelementptr inbounds %t1, ptr %triangle, i32 2, i32 0, i32 1
38   %9 = load float, ptr %arrayidx5.i152, align 4
39   %sub8.i154 = fsub float %9, %2
40   %10 = load float, ptr undef, align 4
41   %sub14.i157 = fsub float %10, %4
42   %mul.i = fmul float %sub8.i134, %sub14.i157
43   %mul10.i = fmul float %sub14.i137, %sub8.i154
44   %sub.i146 = fsub float %mul.i, %mul10.i
45   %mul11.i = fmul float undef, %sub.i146
46   %mul18.i = fmul float %sub14.i137, %sub.i151
47   %mul23.i = fmul float %sub.i131, %sub14.i157
48   %sub24.i = fsub float %mul18.i, %mul23.i
49   %mul25.i = fmul float undef, %sub24.i
50   %add.i148 = fadd float %mul11.i, %mul25.i
51   %add40.i = fadd float undef, %add.i148
52   %call.i = tail call float @fabsf(float %add40.i)
53   %mul = fmul float %call.i, 2.500000e-01
54   %add.i118 = fadd float %0, %5
55   %add8.i121 = fadd float %1, %6
56   %add14.i124 = fadd float %3, %7
57   %add.i105 = fadd float %add.i118, %8
58   %add8.i108 = fadd float %add8.i121, %9
59   %add14.i111 = fadd float %add14.i124, %10
60   %add.i93 = fadd float 0.000000e+00, %add.i105
61   %add8.i96 = fadd float %2, %add8.i108
62   %add14.i = fadd float %4, %add14.i111
63   %mul.i.i = fmul float %add.i93, %mul
64   %mul4.i.i = fmul float %add8.i96, %mul
65   %mul8.i.i = fmul float %mul, %add14.i
66   %arrayidx3.i = getelementptr inbounds %t2, ptr %this, i32 0, i32 3, i32 0, i32 0
67   %add.i = fadd float undef, %mul.i.i
68   store float %add.i, ptr %arrayidx3.i, align 4
69   %arrayidx7.i86 = getelementptr inbounds %t2, ptr %this, i32 0, i32 3, i32 0, i32 1
70   %add8.i = fadd float %mul4.i.i, undef
71   store float %add8.i, ptr %arrayidx7.i86, align 4
72   %arrayidx12.i = getelementptr inbounds %t2, ptr %this, i32 0, i32 3, i32 0, i32 2
73   %add13.i = fadd float %mul8.i.i, undef
74   store float %add13.i, ptr %arrayidx12.i, align 4
75   br label %if.end
77 if.end:                                           ; preds = %if.else, %entry
78   ret void
81 declare float @fabsf(float) readnone