[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / Transforms / MetaRenamer / opcodes.ll
blob8a78677edbff17232ca1b3b141cb6d519d40ce2c
1 ; RUN: opt -passes=metarenamer -S < %s | FileCheck %s
3 define void @opcodes(ptr %p, ptr %arr) {
4 ; CHECK-LABEL: bb:
5 ; CHECK:         %load = load i32, ptr %arg, align 4
6 ; CHECK:         br label %bb2
7 ; CHECK-LABEL: bb2:                                              ; preds = %bb5, %bb
8 ; CHECK:         %phi = phi i32 [ %load, %bb ], [ %sub, %bb5 ]
9 ; CHECK:         %icmp = icmp eq i32 %phi, 0
10 ; CHECK:         br i1 %icmp, label %bb8, label %bb3
11 ; CHECK-LABEL: bb3:                                              ; preds = %bb2
12 ; CHECK:         %sub = sub i32 %phi, 1
13 ; CHECK:         %icmp4 = icmp ult i32 %sub, %load
14 ; CHECK:         br i1 %icmp4, label %bb5, label %bb9
15 ; CHECK-LABEL: bb5:                                              ; preds = %bb3
16 ; CHECK:         %getelementptr = getelementptr i32, ptr %arg, i32 %phi
17 ; CHECK:         %load6 = load i32, ptr %getelementptr, align 4
18 ; CHECK:         %icmp7 = icmp eq i32 %load6, 0
19 ; CHECK:         br i1 %icmp7, label %bb2, label %bb8
20 preheader:
21   %len = load i32, ptr %p
22   br label %loop
24 loop:
25   %iv = phi i32 [%len, %preheader], [%iv.next, %backedge]
26   %zero_cond = icmp eq i32 %iv, 0
27   br i1 %zero_cond, label %exit, label %range_check_block
29 range_check_block:
30   %iv.next = sub i32 %iv, 1
31   %range_check = icmp ult i32 %iv.next, %len
32   br i1 %range_check, label %backedge, label %fail
34 backedge:
35   %el.ptr = getelementptr i32, ptr %p, i32 %iv
36   %el = load i32, ptr %el.ptr
37   %loop.cond = icmp eq i32 %el, 0
38   br i1 %loop.cond, label %loop, label %exit
40 exit:
41   ret void
43 fail:
44   unreachable