Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / SystemZ / int-cmp-35.ll
blob33facfc6c04d4fb7f8316994c033569667760e21
1 ; Test 64-bit unsigned comparisons between memory and a constant.
3 ; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s
5 ; Check ordered comparisons with a constant near the low end of the unsigned
6 ; 16-bit range.
7 define double @f1(double %a, double %b, ptr %ptr) {
8 ; CHECK-LABEL: f1:
9 ; CHECK: clghsi 0(%r2), 2
10 ; CHECK-NEXT: blr %r14
11 ; CHECK: ldr %f0, %f2
12 ; CHECK: br %r14
13   %val = load i64, ptr %ptr
14   %cond = icmp ult i64 %val, 2
15   %res = select i1 %cond, double %a, double %b
16   ret double %res
19 ; Check ordered comparisons with the high end of the unsigned 16-bit range.
20 define double @f2(double %a, double %b, ptr %ptr) {
21 ; CHECK-LABEL: f2:
22 ; CHECK: clghsi 0(%r2), 65535
23 ; CHECK-NEXT: blr %r14
24 ; CHECK: ldr %f0, %f2
25 ; CHECK: br %r14
26   %val = load i64, ptr %ptr
27   %cond = icmp ult i64 %val, 65535
28   %res = select i1 %cond, double %a, double %b
29   ret double %res
32 ; Check the next value up, which can't use CLGHSI.
33 define double @f3(double %a, double %b, ptr %ptr) {
34 ; CHECK-LABEL: f3:
35 ; CHECK-NOT: clghsi
36 ; CHECK: br %r14
37   %val = load i64, ptr %ptr
38   %cond = icmp ult i64 %val, 65536
39   %res = select i1 %cond, double %a, double %b
40   ret double %res
43 ; Check equality comparisons with 32768, the lowest value for which
44 ; we prefer CLGHSI to CGHSI.
45 define double @f4(double %a, double %b, ptr %ptr) {
46 ; CHECK-LABEL: f4:
47 ; CHECK: clghsi 0(%r2), 32768
48 ; CHECK-NEXT: ber %r14
49 ; CHECK: ldr %f0, %f2
50 ; CHECK: br %r14
51   %val = load i64, ptr %ptr
52   %cond = icmp eq i64 %val, 32768
53   %res = select i1 %cond, double %a, double %b
54   ret double %res
57 ; Check equality comparisons with the high end of the unsigned 16-bit range.
58 define double @f5(double %a, double %b, ptr %ptr) {
59 ; CHECK-LABEL: f5:
60 ; CHECK: clghsi 0(%r2), 65535
61 ; CHECK-NEXT: ber %r14
62 ; CHECK: ldr %f0, %f2
63 ; CHECK: br %r14
64   %val = load i64, ptr %ptr
65   %cond = icmp eq i64 %val, 65535
66   %res = select i1 %cond, double %a, double %b
67   ret double %res
70 ; Check the next value up, which can't use CLGHSI.
71 define double @f6(double %a, double %b, ptr %ptr) {
72 ; CHECK-LABEL: f6:
73 ; CHECK-NOT: clghsi
74 ; CHECK: br %r14
75   %val = load i64, ptr %ptr
76   %cond = icmp eq i64 %val, 65536
77   %res = select i1 %cond, double %a, double %b
78   ret double %res
81 ; Check the high end of the CLGHSI range.
82 define double @f7(double %a, double %b, i64 %i1, ptr %base) {
83 ; CHECK-LABEL: f7:
84 ; CHECK: clghsi 4088(%r3), 2
85 ; CHECK-NEXT: blr %r14
86 ; CHECK: ldr %f0, %f2
87 ; CHECK: br %r14
88   %ptr = getelementptr i64, ptr %base, i64 511
89   %val = load i64, ptr %ptr
90   %cond = icmp ult i64 %val, 2
91   %res = select i1 %cond, double %a, double %b
92   ret double %res
95 ; Check the next doubleword up, which needs separate address logic,
96 define double @f8(double %a, double %b, ptr %base) {
97 ; CHECK-LABEL: f8:
98 ; CHECK: aghi %r2, 4096
99 ; CHECK: clghsi 0(%r2), 2
100 ; CHECK-NEXT: blr %r14
101 ; CHECK: ldr %f0, %f2
102 ; CHECK: br %r14
103   %ptr = getelementptr i64, ptr %base, i64 512
104   %val = load i64, ptr %ptr
105   %cond = icmp ult i64 %val, 2
106   %res = select i1 %cond, double %a, double %b
107   ret double %res
110 ; Check negative offsets, which also need separate address logic.
111 define double @f9(double %a, double %b, ptr %base) {
112 ; CHECK-LABEL: f9:
113 ; CHECK: aghi %r2, -8
114 ; CHECK: clghsi 0(%r2), 2
115 ; CHECK-NEXT: blr %r14
116 ; CHECK: ldr %f0, %f2
117 ; CHECK: br %r14
118   %ptr = getelementptr i64, ptr %base, i64 -1
119   %val = load i64, ptr %ptr
120   %cond = icmp ult i64 %val, 2
121   %res = select i1 %cond, double %a, double %b
122   ret double %res
125 ; Check that CLGHSI does not allow indices.
126 define double @f10(double %a, double %b, i64 %base, i64 %index) {
127 ; CHECK-LABEL: f10:
128 ; CHECK: agr {{%r2, %r3|%r3, %r2}}
129 ; CHECK: clghsi 0({{%r[23]}}), 2
130 ; CHECK-NEXT: blr %r14
131 ; CHECK: ldr %f0, %f2
132 ; CHECK: br %r14
133   %add = add i64 %base, %index
134   %ptr = inttoptr i64 %add to ptr
135   %val = load i64, ptr %ptr
136   %cond = icmp ult i64 %val, 2
137   %res = select i1 %cond, double %a, double %b
138   ret double %res