1 ; Test 32-bit signed comparisons between memory and a constant. 2 ; 3 ; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s 4 5 ; Check ordered comparisons with 0. 6 define double @f1(double %a, double %b, i32 *%ptr) { 7 ; CHECK-LABEL: f1: 8 ; CHECK: chsi 0(%r2), 0 9 ; CHECK-NEXT: jl 10 ; CHECK: ldr %f0, %f2 11 ; CHECK: br %r14 12 %val = load i32 , i32 *%ptr 13 %cond = icmp slt i32 %val, 0 14 %res = select i1 %cond, double %a, double %b 15 ret double %res 16 } 17 18 ; Check ordered comparisons with 1. 19 define double @f2(double %a, double %b, i32 *%ptr) { 20 ; CHECK-LABEL: f2: 21 ; CHECK: chsi 0(%r2), 0 22 ; CHECK-NEXT: jle 23 ; CHECK: ldr %f0, %f2 24 ; CHECK: br %r14 25 %val = load i32 , i32 *%ptr 26 %cond = icmp slt i32 %val, 1 27 %res = select i1 %cond, double %a, double %b 28 ret double %res 29 } 30 31 ; Check ordered comparisons with the high end of the signed 16-bit range. 32 define double @f3(double %a, double %b, i32 *%ptr) { 33 ; CHECK-LABEL: f3: 34 ; CHECK: chsi 0(%r2), 32767 35 ; CHECK-NEXT: jl 36 ; CHECK: ldr %f0, %f2 37 ; CHECK: br %r14 38 %val = load i32 , i32 *%ptr 39 %cond = icmp slt i32 %val, 32767 40 %res = select i1 %cond, double %a, double %b 41 ret double %res 42 } 43 44 ; Check the next value up, which can't use CHSI. 45 define double @f4(double %a, double %b, i32 *%ptr) { 46 ; CHECK-LABEL: f4: 47 ; CHECK-NOT: chsi 48 ; CHECK: br %r14 49 %val = load i32 , i32 *%ptr 50 %cond = icmp slt i32 %val, 32768 51 %res = select i1 %cond, double %a, double %b 52 ret double %res 53 } 54 55 ; Check ordered comparisons with -1. 56 define double @f5(double %a, double %b, i32 *%ptr) { 57 ; CHECK-LABEL: f5: 58 ; CHECK: chsi 0(%r2), -1 59 ; CHECK-NEXT: jl 60 ; CHECK: ldr %f0, %f2 61 ; CHECK: br %r14 62 %val = load i32 , i32 *%ptr 63 %cond = icmp slt i32 %val, -1 64 %res = select i1 %cond, double %a, double %b 65 ret double %res 66 } 67 68 ; Check ordered comparisons with the low end of the 16-bit signed range. 69 define double @f6(double %a, double %b, i32 *%ptr) { 70 ; CHECK-LABEL: f6: 71 ; CHECK: chsi 0(%r2), -32768 72 ; CHECK-NEXT: jl 73 ; CHECK: ldr %f0, %f2 74 ; CHECK: br %r14 75 %val = load i32 , i32 *%ptr 76 %cond = icmp slt i32 %val, -32768 77 %res = select i1 %cond, double %a, double %b 78 ret double %res 79 } 80 81 ; Check the next value down, which can't use CHSI. 82 define double @f7(double %a, double %b, i32 *%ptr) { 83 ; CHECK-LABEL: f7: 84 ; CHECK-NOT: chsi 85 ; CHECK: br %r14 86 %val = load i32 , i32 *%ptr 87 %cond = icmp slt i32 %val, -32769 88 %res = select i1 %cond, double %a, double %b 89 ret double %res 90 } 91 92 ; Check equality comparisons with 0. 93 define double @f8(double %a, double %b, i32 *%ptr) { 94 ; CHECK-LABEL: f8: 95 ; CHECK: chsi 0(%r2), 0 96 ; CHECK-NEXT: je 97 ; CHECK: ldr %f0, %f2 98 ; CHECK: br %r14 99 %val = load i32 , i32 *%ptr 100 %cond = icmp eq i32 %val, 0 101 %res = select i1 %cond, double %a, double %b 102 ret double %res 103 } 104 105 ; Check equality comparisons with 1. 106 define double @f9(double %a, double %b, i32 *%ptr) { 107 ; CHECK-LABEL: f9: 108 ; CHECK: chsi 0(%r2), 1 109 ; CHECK-NEXT: je 110 ; CHECK: ldr %f0, %f2 111 ; CHECK: br %r14 112 %val = load i32 , i32 *%ptr 113 %cond = icmp eq i32 %val, 1 114 %res = select i1 %cond, double %a, double %b 115 ret double %res 116 } 117 118 ; Check equality comparisons with the high end of the signed 16-bit range. 119 define double @f10(double %a, double %b, i32 *%ptr) { 120 ; CHECK-LABEL: f10: 121 ; CHECK: chsi 0(%r2), 32767 122 ; CHECK-NEXT: je 123 ; CHECK: ldr %f0, %f2 124 ; CHECK: br %r14 125 %val = load i32 , i32 *%ptr 126 %cond = icmp eq i32 %val, 32767 127 %res = select i1 %cond, double %a, double %b 128 ret double %res 129 } 130 131 ; Check the next value up, which can't use CHSI. 132 define double @f11(double %a, double %b, i32 *%ptr) { 133 ; CHECK-LABEL: f11: 134 ; CHECK-NOT: chsi 135 ; CHECK: br %r14 136 %val = load i32 , i32 *%ptr 137 %cond = icmp eq i32 %val, 32768 138 %res = select i1 %cond, double %a, double %b 139 ret double %res 140 } 141 142 ; Check equality comparisons with -1. 143 define double @f12(double %a, double %b, i32 *%ptr) { 144 ; CHECK-LABEL: f12: 145 ; CHECK: chsi 0(%r2), -1 146 ; CHECK-NEXT: je 147 ; CHECK: ldr %f0, %f2 148 ; CHECK: br %r14 149 %val = load i32 , i32 *%ptr 150 %cond = icmp eq i32 %val, -1 151 %res = select i1 %cond, double %a, double %b 152 ret double %res 153 } 154 155 ; Check equality comparisons with the low end of the 16-bit signed range. 156 define double @f13(double %a, double %b, i32 *%ptr) { 157 ; CHECK-LABEL: f13: 158 ; CHECK: chsi 0(%r2), -32768 159 ; CHECK-NEXT: je 160 ; CHECK: ldr %f0, %f2 161 ; CHECK: br %r14 162 %val = load i32 , i32 *%ptr 163 %cond = icmp eq i32 %val, -32768 164 %res = select i1 %cond, double %a, double %b 165 ret double %res 166 } 167 168 ; Check the next value down, which should be treated as a positive value. 169 define double @f14(double %a, double %b, i32 *%ptr) { 170 ; CHECK-LABEL: f14: 171 ; CHECK-NOT: chsi 172 ; CHECK: br %r14 173 %val = load i32 , i32 *%ptr 174 %cond = icmp eq i32 %val, -32769 175 %res = select i1 %cond, double %a, double %b 176 ret double %res 177 } 178 179 ; Check the high end of the CHSI range. 180 define double @f15(double %a, double %b, i32 %i1, i32 *%base) { 181 ; CHECK-LABEL: f15: 182 ; CHECK: chsi 4092(%r3), 0 183 ; CHECK-NEXT: jl 184 ; CHECK: ldr %f0, %f2 185 ; CHECK: br %r14 186 %ptr = getelementptr i32, i32 *%base, i64 1023 187 %val = load i32 , i32 *%ptr 188 %cond = icmp slt i32 %val, 0 189 %res = select i1 %cond, double %a, double %b 190 ret double %res 191 } 192 193 ; Check the next word up, which needs separate address logic, 194 define double @f16(double %a, double %b, i32 *%base) { 195 ; CHECK-LABEL: f16: 196 ; CHECK: aghi %r2, 4096 197 ; CHECK: chsi 0(%r2), 0 198 ; CHECK-NEXT: jl 199 ; CHECK: ldr %f0, %f2 200 ; CHECK: br %r14 201 %ptr = getelementptr i32, i32 *%base, i64 1024 202 %val = load i32 , i32 *%ptr 203 %cond = icmp slt i32 %val, 0 204 %res = select i1 %cond, double %a, double %b 205 ret double %res 206 } 207 208 ; Check negative offsets, which also need separate address logic. 209 define double @f17(double %a, double %b, i32 *%base) { 210 ; CHECK-LABEL: f17: 211 ; CHECK: aghi %r2, -4 212 ; CHECK: chsi 0(%r2), 0 213 ; CHECK-NEXT: jl 214 ; CHECK: ldr %f0, %f2 215 ; CHECK: br %r14 216 %ptr = getelementptr i32, i32 *%base, i64 -1 217 %val = load i32 , i32 *%ptr 218 %cond = icmp slt i32 %val, 0 219 %res = select i1 %cond, double %a, double %b 220 ret double %res 221 } 222 223 ; Check that CHSI does not allow indices. 224 define double @f18(double %a, double %b, i64 %base, i64 %index) { 225 ; CHECK-LABEL: f18: 226 ; CHECK: agr {{%r2, %r3|%r3, %r2}} 227 ; CHECK: chsi 0({{%r[23]}}), 0 228 ; CHECK-NEXT: jl 229 ; CHECK: ldr %f0, %f2 230 ; CHECK: br %r14 231 %add = add i64 %base, %index 232 %ptr = inttoptr i64 %add to i32 * 233 %val = load i32 , i32 *%ptr 234 %cond = icmp slt i32 %val, 0 235 %res = select i1 %cond, double %a, double %b 236 ret double %res 237 } 238