[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / Transforms / LCSSA / unreachable-use.ll
blob98f7584d6f253a2d227ce533ea35dd5e2e4832b9
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -passes=lcssa -S -verify-loop-info | FileCheck %s
4 ; LCSSA doesn't need to transform uses in blocks not reachable
5 ; from the entry block.
7 ; PR6546
8 define void @test_pr6546(ptr %src, i1 %c) {
9 ; CHECK-LABEL: @test_pr6546(
10 ; CHECK-NEXT:  bb:
11 ; CHECK-NEXT:    br label [[BB44:%.*]]
12 ; CHECK:       bb44:
13 ; CHECK-NEXT:    br i1 [[C:%.*]], label [[BB7:%.*]], label [[BB45:%.*]]
14 ; CHECK:       bb7:
15 ; CHECK-NEXT:    [[TMP:%.*]] = getelementptr ptr, ptr [[SRC:%.*]], i64 3
16 ; CHECK-NEXT:    br label [[BB15:%.*]]
17 ; CHECK:       bb15:
18 ; CHECK-NEXT:    br label [[BB44]]
19 ; CHECK:       bb32:
20 ; CHECK-NEXT:    [[TMP33:%.*]] = load ptr, ptr [[TMP]], align 8
21 ; CHECK-NEXT:    br label [[BB45]]
22 ; CHECK:       bb45:
23 ; CHECK-NEXT:    unreachable
25 bb:
26   br label %bb44
28 bb44:
29   br i1 %c, label %bb7, label %bb45
31 bb7:
32   %tmp = getelementptr ptr, ptr %src, i64 3
33   br label %bb15
35 bb15:
36   br label %bb44
38 bb32:
39   %tmp33 = load ptr, ptr %tmp, align 8
40   br label %bb45
42 bb45:
43   unreachable
46 define void @multiple_unreachable_uses(ptr %A, ptr %B) {
47 entry:
48   br label %loop
50 loop:
51   %gep.A = getelementptr inbounds float, ptr %A, i64 10
52   %gep.B = getelementptr inbounds ptr, ptr %B, i64 20
53   br i1 false, label %exit, label %loop
55 dead:                 ; No predecessors!
56   %l1 = load float, ptr %gep.A, align 4
57   %l2 = load ptr, ptr %gep.B, align 8
58   br label %exit
60 exit:
61   ret void