1; RUN: llc -mcpu=corei7 -mtriple=x86_64-linux < %s | FileCheck %s -check-prefix=CHECK
2; RUN: llc -mcpu=corei7 -mtriple=x86_64-linux -outline-optional-branches < %s | FileCheck %s -check-prefix=CHECK-OUTLINE
3
4define void @foo(i32 %t1, i32 %t2, i32 %t3) {
5; Test that we lift the call to 'c' up to immediately follow the call to 'b'
6; when we disable the cfg conflict check.
7;
8; CHECK-LABEL: foo:
9; CHECK: callq a
10; CHECK: callq a
11; CHECK: callq a
12; CHECK: callq a
13; CHECK: callq b
14; CHECK: callq c
15; CHECK: callq d
16; CHECK: callq e
17; CHECK: callq f
18;
19; CHECK-OUTLINE-LABEL: foo:
20; CHECK-OUTLINE: callq b
21; CHECK-OUTLINE: callq c
22; CHECK-OUTLINE: callq d
23; CHECK-OUTLINE: callq e
24; CHECK-OUTLINE: callq f
25; CHECK-OUTLINE: callq a
26; CHECK-OUTLINE: callq a
27; CHECK-OUTLINE: callq a
28; CHECK-OUTLINE: callq a
29
30entry:
31  %cmp = icmp eq i32 %t1, 0
32  br i1 %cmp, label %if.then, label %if.end
33
34if.then:
35  call void @a()
36  call void @a()
37  call void @a()
38  call void @a()
39  br label %if.end
40
41if.end:
42  call void @b()
43  br label %hotbranch
44
45hotbranch:
46  %cmp2 = icmp eq i32 %t2, 0
47  br i1 %cmp2, label %if.then2, label %if.end2, !prof !1
48
49if.then2:
50  call void @c()
51  br label %if.end2
52
53if.end2:
54  call void @d()
55  br label %shortbranch
56
57shortbranch:
58  %cmp3 = icmp eq i32 %t3, 0
59  br i1 %cmp3, label %if.then3, label %if.end3
60
61if.then3:
62  call void @e()
63  br label %if.end3
64
65if.end3:
66  call void @f()
67  ret void
68}
69
70declare void @a()
71declare void @b()
72declare void @c()
73declare void @d()
74declare void @e()
75declare void @f()
76
77!1 = !{!"branch_weights", i32 64, i32 4}
78