]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - test/CodeGen/AMDGPU/cayman-loop-bug.ll
Vendor import of llvm release_40 branch r296202:
[FreeBSD/FreeBSD.git] / test / CodeGen / AMDGPU / cayman-loop-bug.ll
1 ; RUN: llc < %s -march=r600 -mcpu=cayman | FileCheck %s
2
3 ; CHECK-LABEL: {{^}}main:
4 ; CHECK: LOOP_START_DX10
5 ; CHECK: ALU_PUSH_BEFORE
6 ; CHECK: LOOP_START_DX10
7 ; CHECK: PUSH
8 ; CHECK-NOT: ALU_PUSH_BEFORE
9 ; CHECK: END_LOOP
10 ; CHECK: END_LOOP
11 define amdgpu_ps void @main (<4 x float> inreg %reg0) {
12 entry:
13   br label %outer_loop
14
15 outer_loop:
16   %cnt = phi i32 [0, %entry], [%cnt_incr, %inner_loop]
17   %cond = icmp eq i32 %cnt, 16
18   br i1 %cond, label %outer_loop_body, label %exit
19
20 outer_loop_body:
21   %cnt_incr = add i32 %cnt, 1
22   br label %inner_loop
23
24 inner_loop:
25   %cnt2 = phi i32 [0, %outer_loop_body], [%cnt2_incr, %inner_loop_body]
26   %n = load volatile i32, i32 addrspace(1)* undef
27   %cond2 = icmp slt i32 %cnt2, %n
28   br i1 %cond2, label %inner_loop_body, label %outer_loop
29
30 inner_loop_body:
31   %cnt2_incr = add i32 %cnt2, 1
32   br label %inner_loop
33
34 exit:
35   ret void
36 }