Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / SystemZ / branch-03.ll
blobe72f6a77eabe63b082bc37d6961345d53abc454f
1 ; Test all condition-code masks that are relevant for unsigned integer
2 ; comparisons.
4 ; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s
5 define void @f1(ptr %src, i32 %target) {
6 ; CHECK-LABEL: f1:
7 ; CHECK: .cfi_startproc
8 ; CHECK: .L[[LABEL:.*]]:
9 ; CHECK: cl %r3, 0(%r2)
10 ; CHECK-NEXT: jle .L[[LABEL]]
11   br label %loop
12 loop:
13   %val = load volatile i32, ptr %src
14   %cond = icmp ule i32 %target, %val
15   br i1 %cond, label %loop, label %exit
16 exit:
17   ret void
20 define void @f2(ptr %src, i32 %target) {
21 ; CHECK-LABEL: f2:
22 ; CHECK: .cfi_startproc
23 ; CHECK: .L[[LABEL:.*]]:
24 ; CHECK: cl %r3, 0(%r2)
25 ; CHECK-NEXT: jl .L[[LABEL]]
26   br label %loop
27 loop:
28   %val = load volatile i32, ptr %src
29   %cond = icmp ult i32 %target, %val
30   br i1 %cond, label %loop, label %exit
31 exit:
32   ret void
35 define void @f3(ptr %src, i32 %target) {
36 ; CHECK-LABEL: f3:
37 ; CHECK: .cfi_startproc
38 ; CHECK: .L[[LABEL:.*]]:
39 ; CHECK: cl %r3, 0(%r2)
40 ; CHECK-NEXT: jh .L[[LABEL]]
41   br label %loop
42 loop:
43   %val = load volatile i32, ptr %src
44   %cond = icmp ugt i32 %target, %val
45   br i1 %cond, label %loop, label %exit
46 exit:
47   ret void
50 define void @f4(ptr %src, i32 %target) {
51 ; CHECK-LABEL: f4:
52 ; CHECK: .cfi_startproc
53 ; CHECK: .L[[LABEL:.*]]:
54 ; CHECK: cl %r3, 0(%r2)
55 ; CHECK-NEXT: jhe .L[[LABEL]]
56   br label %loop
57 loop:
58   %val = load volatile i32, ptr %src
59   %cond = icmp uge i32 %target, %val
60   br i1 %cond, label %loop, label %exit
61 exit:
62   ret void