[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / Transforms / LoopSimplifyCFG / pr39783.ll
blobd6c0a23ebaaaa57f82cde99ef783b386467d6233
1 ; REQUIRES: asserts
2 ; RUN: opt -mcpu=z13 -S -passes=loop-simplifycfg -enable-loop-simplifycfg-term-folding -verify-memoryssa 2>&1 < %s | FileCheck %s
3 target datalayout = "E-m:e-i1:8:16-i8:8:16-i64:64-f128:64-v128:64-a:8:16-n32:64"
5 @global = external dso_local local_unnamed_addr global i8, align 2
6 @global.1 = external dso_local local_unnamed_addr global i32, align 4
7 @global.2 = external dso_local local_unnamed_addr global i32, align 4
8 @global.3 = external dso_local local_unnamed_addr global i16, align 2
9 @global.4 = external dso_local local_unnamed_addr global i32, align 4
11 ; CHECK-LABEL: @test_01(
13 define internal fastcc void @test_01() unnamed_addr {
14 bb:
15   %tmp = load i32, ptr @global.2, align 4
16   %tmp1 = icmp eq i32 %tmp, 0
17   br i1 %tmp1, label %bb3, label %bb2
19 bb2:                                              ; preds = %bb
20   br label %bb7
22 bb3:                                              ; preds = %bb
23   br label %bb4
25 bb4:                                              ; preds = %bb6, %bb3
26   br i1 true, label %bb5, label %bb6
28 bb5:                                              ; preds = %bb4
29   store i16 0, ptr @global.3, align 2
30   br label %bb6
32 bb6:                                              ; preds = %bb5, %bb4
33   br label %bb4
35 bb7:                                              ; preds = %bb7, %bb2
36   %tmp8 = phi i32 [ 1, %bb7 ], [ 0, %bb2 ]
37   %tmp9 = icmp eq i32 %tmp8, 0
38   br i1 %tmp9, label %bb7, label %bb10
40 bb10:                                             ; preds = %bb7
41   br label %bb11
43 bb11:                                             ; preds = %bb13, %bb10
44   %tmp12 = icmp ult i32 %tmp, 6
45   br i1 %tmp12, label %bb13, label %bb14
47 bb13:                                             ; preds = %bb11
48   store i32 0, ptr @global.1, align 4
49   br label %bb11
51 bb14:                                             ; preds = %bb11
52   ret void
55 @global.5 = external dso_local local_unnamed_addr global i16, align 2
57 declare dso_local void @spam() local_unnamed_addr
59 declare dso_local void @blam() local_unnamed_addr
61 declare dso_local i64 @quux.1() local_unnamed_addr
63 declare dso_local void @bar() local_unnamed_addr
65 ; CHECK-LABEL: @test_02(
67 define dso_local void @test_02(i8 signext %arg) local_unnamed_addr {
68 bb:
69   br label %bb1
71 bb1:                                              ; preds = %bb16, %bb
72   %tmp = phi i8 [ %arg, %bb ], [ %tmp17, %bb16 ]
73   %tmp2 = load i16, ptr @global.5, align 2
74   %tmp3 = icmp ugt i16 %tmp2, 56
75   br i1 %tmp3, label %bb4, label %bb18
77 bb4:                                              ; preds = %bb1
78   %tmp5 = tail call i64 @quux.1()
79   %tmp6 = icmp eq i64 %tmp5, 0
80   br i1 %tmp6, label %bb13, label %bb7
82 bb7:                                              ; preds = %bb4
83   br label %bb8
85 bb8:                                              ; preds = %bb8, %bb7
86   %tmp9 = phi i32 [ 26, %bb7 ], [ %tmp10, %bb8 ]
87   tail call void @bar()
88   %tmp10 = add nsw i32 %tmp9, -1
89   %tmp11 = icmp eq i32 %tmp10, 12
90   br i1 %tmp11, label %bb12, label %bb8
92 bb12:                                             ; preds = %bb8
93   br i1 false, label %bb14, label %bb16
95 bb13:                                             ; preds = %bb4
96   tail call void @spam()
97   br label %bb14
99 bb14:                                             ; preds = %bb13, %bb12
100   %tmp15 = phi i8 [ -23, %bb12 ], [ %tmp, %bb13 ]
101   tail call void @blam()
102   br label %bb16
104 bb16:                                             ; preds = %bb14, %bb12
105   %tmp17 = phi i8 [ %tmp15, %bb14 ], [ -23, %bb12 ]
106   br label %bb1
108 bb18:                                             ; preds = %bb1
109   ret void