1; RUN: llc < %s -mtriple=x86_64-- -mcpu=corei7-avx -mattr=-slow-incdec -disable-lsr -pre-RA-sched=source -enable-misched -verify-machineinstrs | FileCheck %s
2
3; Verify that TEST+JE are scheduled together.
4; CHECK: test_je
5; CHECK: %loop
6; CHECK: test
7; CHECK-NEXT: je
8define void @test_je() {
9entry:
10  br label %loop
11
12loop:
13  %var = phi i32* [ null, %entry ], [ %next.load, %loop1 ], [ %var, %loop2 ]
14  %next.ptr = phi i32** [ null, %entry ], [ %next.ptr, %loop1 ], [ %gep, %loop2 ]
15  br label %loop1
16
17loop1:
18  %cond = icmp eq i32* %var, null
19  %next.load = load i32*, i32** %next.ptr
20  br i1 %cond, label %loop, label %loop2
21
22loop2:                                           ; preds = %loop1
23  %gep = getelementptr inbounds i32*, i32** %next.ptr, i32 1
24  store i32* %next.load, i32** undef
25  br label %loop
26}
27
28; Verify that DEC+JE are scheduled together.
29; CHECK: dec_je
30; CHECK: %loop1
31; CHECK: dec
32; CHECK-NEXT: je
33define void @dec_je() {
34entry:
35  br label %loop
36
37loop:
38  %var = phi i32 [ 0, %entry ], [ %next.var, %loop1 ], [ %var2, %loop2 ]
39  %next.ptr = phi i32** [ null, %entry ], [ %next.ptr, %loop1 ], [ %gep, %loop2 ]
40  br label %loop1
41
42loop1:
43  %var2 = sub i32 %var, 1
44  %cond = icmp eq i32 %var2, 0
45  %next.load = load i32*, i32** %next.ptr
46  %next.var = load i32, i32* %next.load
47  br i1 %cond, label %loop, label %loop2
48
49loop2:
50  %gep = getelementptr inbounds i32*, i32** %next.ptr, i32 1
51  store i32* %next.load, i32** undef
52  br label %loop
53}
54
55; DEC+JS should *not* be scheduled together.
56; CHECK: dec_js
57; CHECK: %loop1
58; CHECK: dec
59; CHECK: mov
60; CHECK: js
61define void @dec_js() {
62entry:
63  br label %loop2a
64
65loop2a:                                           ; preds = %loop1, %body, %entry
66  %var = phi i32 [ 0, %entry ], [ %next.var, %loop1 ], [ %var2, %loop2b ]
67  %next.ptr = phi i32** [ null, %entry ], [ %next.ptr, %loop1 ], [ %gep, %loop2b ]
68  br label %loop1
69
70loop1:                                            ; preds = %loop2a, %loop2b
71  %var2 = sub i32 %var, 1
72  %cond = icmp slt i32 %var2, 0
73  %next.load = load i32*, i32** %next.ptr
74  %next.var = load i32, i32* %next.load
75  br i1 %cond, label %loop2a, label %loop2b
76
77loop2b:                                           ; preds = %loop1
78  %gep = getelementptr inbounds i32*, i32** %next.ptr, i32 1
79  store i32* %next.load, i32** undef
80  br label %loop2a
81}
82
83; Verify that CMP+JB are scheduled together.
84; CHECK: cmp_jb
85; CHECK: %loop1
86; CHECK: cmp
87; CHECK-NEXT: jb
88define void @cmp_jb(i32 %n) {
89entry:
90  br label %loop2a
91
92loop2a:                                           ; preds = %loop1, %body, %entry
93  %var = phi i32 [ 0, %entry ], [ %next.var, %loop1 ], [ %var2, %loop2b ]
94  %next.ptr = phi i32** [ null, %entry ], [ %next.ptr, %loop1 ], [ %gep, %loop2b ]
95  br label %loop1
96
97loop1:                                            ; preds = %loop2a, %loop2b
98  %var2 = sub i32 %var, 1
99  %cond = icmp ult i32 %var2, %n
100  %next.load = load i32*, i32** %next.ptr
101  %next.var = load i32, i32* %next.load
102  br i1 %cond, label %loop2a, label %loop2b
103
104loop2b:                                           ; preds = %loop1
105  %gep = getelementptr inbounds i32*, i32** %next.ptr, i32 1
106  store i32* %next.load, i32** undef
107  br label %loop2a
108}
109