blob: 4f5c71effe696934b2cb38047041e480fc994604 [file] [log] [blame]
Simon Dardisd2ed8ab2016-09-27 13:15:54 +00001; RUN: llc -march=mipsel -relocation-model=pic -mips-tail-calls=1 < %s | FileCheck %s
Akira Hatanakaaf4211a2013-09-28 00:12:32 +00002
3; CHECK-LABEL: foo6:
4; CHECK: %while.body
5; CHECK: lw $25, %call16(foo2)(${{[0-9]+}})
6; CHECK: jalr $25
7; CHECK: %while.end
8
9define void @foo6(i32 %n) {
10entry:
11 %tobool1 = icmp eq i32 %n, 0
12 br i1 %tobool1, label %while.end, label %while.body
13
14while.body: ; preds = %entry, %while.body
15 %n.addr.02 = phi i32 [ %dec, %while.body ], [ %n, %entry ]
16 %dec = add nsw i32 %n.addr.02, -1
17 tail call void @foo2()
18 %tobool = icmp eq i32 %dec, 0
19 br i1 %tobool, label %while.end, label %while.body
20
21while.end: ; preds = %while.body, %entry
22 ret void
23}
24
25declare void @foo2()
26
27; CHECK-LABEL: foo1:
28; CHECK: lw $25, %call16(foo2)(${{[0-9]+}})
29; CHECK: jalr $25
30; CHECK: lw $25, %call16(foo2)(${{[0-9]+}})
31; CHECK: jalr $25
32; CHECK: lw $25, %call16(foo2)(${{[0-9]+}})
Simon Dardis1dcb9112016-11-20 21:23:08 +000033; CHECK: jalr $25
Akira Hatanakaaf4211a2013-09-28 00:12:32 +000034
35define void @foo1() {
36entry:
37 tail call void @foo2()
38 tail call void @foo2()
39 tail call void @foo2()
40 ret void
41}