1 ; RUN: opt -O3 -S < %s | FileCheck %s
3 ; Test to verify that constants aren't folded when the rounding mode is unknown.
5 ; CHECK: call double @llvm.experimental.constrained.fdiv.f64
6 define double @f1() #0 {
8 %div = call double @llvm.experimental.constrained.fdiv.f64(
11 metadata !"round.dynamic",
12 metadata !"fpexcept.strict") #0
16 ; Verify that 'a - 0' isn't simplified to 'a' when the rounding mode is unknown.
18 ; double f2(double a) {
19 ; // Because the result of '0 - 0' is negative zero if rounding mode is
20 ; // downward, this shouldn't be simplified.
25 ; CHECK: call double @llvm.experimental.constrained.fsub.f64
26 define double @f2(double %a) #0 {
28 %div = call double @llvm.experimental.constrained.fsub.f64(
29 double %a, double 0.000000e+00,
30 metadata !"round.dynamic",
31 metadata !"fpexcept.strict") #0
35 ; Verify that '-((-a)*b)' isn't simplified to 'a*b' when the rounding mode is
38 ; double f3(double a, double b) {
39 ; // Because the intermediate value involved in this calculation may require
40 ; // rounding, this shouldn't be simplified.
45 ; CHECK: call double @llvm.experimental.constrained.fsub.f64
46 ; CHECK: call double @llvm.experimental.constrained.fmul.f64
47 ; CHECK: call double @llvm.experimental.constrained.fsub.f64
48 define double @f3(double %a, double %b) #0 {
50 %sub = call double @llvm.experimental.constrained.fsub.f64(
51 double -0.000000e+00, double %a,
52 metadata !"round.dynamic",
53 metadata !"fpexcept.strict") #0
54 %mul = call double @llvm.experimental.constrained.fmul.f64(
55 double %sub, double %b,
56 metadata !"round.dynamic",
57 metadata !"fpexcept.strict") #0
58 %ret = call double @llvm.experimental.constrained.fsub.f64(
61 metadata !"round.dynamic",
62 metadata !"fpexcept.strict") #0
66 ; Verify that FP operations are not performed speculatively when FP exceptions
67 ; are not being ignored.
69 ; double f4(int n, double a) {
70 ; // Because a + 1 may overflow, this should not be simplified.
80 define double @f4(i32 %n, double %a) #0 {
82 %cmp = icmp sgt i32 %n, 0
83 br i1 %cmp, label %if.then, label %if.end
86 %add = call double @llvm.experimental.constrained.fadd.f64(
87 double 1.000000e+00, double %a,
88 metadata !"round.dynamic",
89 metadata !"fpexcept.strict") #0
93 %a.0 = phi double [%add, %if.then], [ %a, %entry ]
97 ; Verify that sqrt(42.0) isn't simplified when the rounding mode is unknown.
99 ; CHECK: call double @llvm.experimental.constrained.sqrt
100 define double @f5() #0 {
102 %result = call double @llvm.experimental.constrained.sqrt.f64(double 42.0,
103 metadata !"round.dynamic",
104 metadata !"fpexcept.strict") #0
108 ; Verify that pow(42.1, 3.0) isn't simplified when the rounding mode is unknown.
110 ; CHECK: call double @llvm.experimental.constrained.pow
111 define double @f6() #0 {
113 %result = call double @llvm.experimental.constrained.pow.f64(double 42.1,
115 metadata !"round.dynamic",
116 metadata !"fpexcept.strict") #0
120 ; Verify that powi(42.1, 3) isn't simplified when the rounding mode is unknown.
122 ; CHECK: call double @llvm.experimental.constrained.powi
123 define double @f7() #0 {
125 %result = call double @llvm.experimental.constrained.powi.f64(double 42.1,
127 metadata !"round.dynamic",
128 metadata !"fpexcept.strict") #0
132 ; Verify that sin(42.0) isn't simplified when the rounding mode is unknown.
134 ; CHECK: call double @llvm.experimental.constrained.sin
135 define double @f8() #0 {
137 %result = call double @llvm.experimental.constrained.sin.f64(double 42.0,
138 metadata !"round.dynamic",
139 metadata !"fpexcept.strict") #0
143 ; Verify that cos(42.0) isn't simplified when the rounding mode is unknown.
145 ; CHECK: call double @llvm.experimental.constrained.cos
146 define double @f9() #0 {
148 %result = call double @llvm.experimental.constrained.cos.f64(double 42.0,
149 metadata !"round.dynamic",
150 metadata !"fpexcept.strict") #0
154 ; Verify that exp(42.0) isn't simplified when the rounding mode is unknown.
156 ; CHECK: call double @llvm.experimental.constrained.exp
157 define double @f10() #0 {
159 %result = call double @llvm.experimental.constrained.exp.f64(double 42.0,
160 metadata !"round.dynamic",
161 metadata !"fpexcept.strict") #0
165 ; Verify that exp2(42.1) isn't simplified when the rounding mode is unknown.
167 ; CHECK: call double @llvm.experimental.constrained.exp2
168 define double @f11() #0 {
170 %result = call double @llvm.experimental.constrained.exp2.f64(double 42.1,
171 metadata !"round.dynamic",
172 metadata !"fpexcept.strict") #0
176 ; Verify that log(42.0) isn't simplified when the rounding mode is unknown.
178 ; CHECK: call double @llvm.experimental.constrained.log
179 define double @f12() #0 {
181 %result = call double @llvm.experimental.constrained.log.f64(double 42.0,
182 metadata !"round.dynamic",
183 metadata !"fpexcept.strict") #0
187 ; Verify that log10(42.0) isn't simplified when the rounding mode is unknown.
189 ; CHECK: call double @llvm.experimental.constrained.log10
190 define double @f13() #0 {
192 %result = call double @llvm.experimental.constrained.log10.f64(double 42.0,
193 metadata !"round.dynamic",
194 metadata !"fpexcept.strict") #0
198 ; Verify that log2(42.0) isn't simplified when the rounding mode is unknown.
200 ; CHECK: call double @llvm.experimental.constrained.log2
201 define double @f14() #0 {
203 %result = call double @llvm.experimental.constrained.log2.f64(double 42.0,
204 metadata !"round.dynamic",
205 metadata !"fpexcept.strict") #0
209 ; Verify that rint(42.1) isn't simplified when the rounding mode is unknown.
211 ; CHECK: call double @llvm.experimental.constrained.rint
212 define double @f15() #0 {
214 %result = call double @llvm.experimental.constrained.rint.f64(double 42.1,
215 metadata !"round.dynamic",
216 metadata !"fpexcept.strict") #0
220 ; Verify that nearbyint(42.1) isn't simplified when the rounding mode is
223 ; CHECK: call double @llvm.experimental.constrained.nearbyint
224 define double @f16() #0 {
226 %result = call double @llvm.experimental.constrained.nearbyint.f64(
228 metadata !"round.dynamic",
229 metadata !"fpexcept.strict") #0
233 ; Verify that fma(42.1) isn't simplified when the rounding mode is
236 ; CHECK: call double @llvm.experimental.constrained.fma
237 define double @f17() #0 {
239 %result = call double @llvm.experimental.constrained.fma.f64(double 42.1, double 42.1, double 42.1,
240 metadata !"round.dynamic",
241 metadata !"fpexcept.strict") #0
245 ; Verify that fptoui(42.1) isn't simplified when the rounding mode is
248 ; CHECK: call zeroext i32 @llvm.experimental.constrained.fptoui
249 define zeroext i32 @f18() #0 {
251 %result = call zeroext i32 @llvm.experimental.constrained.fptoui.i32.f64(
253 metadata !"fpexcept.strict") #0
257 ; Verify that fptosi(42.1) isn't simplified when the rounding mode is
260 ; CHECK: call i32 @llvm.experimental.constrained.fptosi
261 define i32 @f19() #0 {
263 %result = call i32 @llvm.experimental.constrained.fptosi.i32.f64(double 42.1,
264 metadata !"fpexcept.strict") #0
268 ; Verify that fptrunc(42.1) isn't simplified when the rounding mode is
271 ; CHECK: call float @llvm.experimental.constrained.fptrunc
272 define float @f20() #0 {
274 %result = call float @llvm.experimental.constrained.fptrunc.f32.f64(
276 metadata !"round.dynamic",
277 metadata !"fpexcept.strict") #0
281 ; Verify that fpext(42.1) isn't simplified when the rounding mode is
284 ; CHECK: call double @llvm.experimental.constrained.fpext
285 define double @f21() #0 {
287 %result = call double @llvm.experimental.constrained.fpext.f64.f32(float 42.0,
288 metadata !"fpexcept.strict") #0
292 ; Verify that lrint(42.1) isn't simplified when the rounding mode is unknown.
294 ; CHECK: call i32 @llvm.experimental.constrained.lrint
295 define i32 @f22() #0 {
297 %result = call i32 @llvm.experimental.constrained.lrint.i32.f64(double 42.1,
298 metadata !"round.dynamic",
299 metadata !"fpexcept.strict") #0
303 ; Verify that lrintf(42.0) isn't simplified when the rounding mode is unknown.
305 ; CHECK: call i32 @llvm.experimental.constrained.lrint
306 define i32 @f23() #0 {
308 %result = call i32 @llvm.experimental.constrained.lrint.i32.f32(float 42.0,
309 metadata !"round.dynamic",
310 metadata !"fpexcept.strict") #0
314 ; Verify that llrint(42.1) isn't simplified when the rounding mode is unknown.
316 ; CHECK: call i64 @llvm.experimental.constrained.llrint
317 define i64 @f24() #0 {
319 %result = call i64 @llvm.experimental.constrained.llrint.i64.f64(double 42.1,
320 metadata !"round.dynamic",
321 metadata !"fpexcept.strict") #0
325 ; Verify that llrint(42.0) isn't simplified when the rounding mode is unknown.
327 ; CHECK: call i64 @llvm.experimental.constrained.llrint
328 define i64 @f25() #0 {
330 %result = call i64 @llvm.experimental.constrained.llrint.i64.f32(float 42.0,
331 metadata !"round.dynamic",
332 metadata !"fpexcept.strict") #0
336 ; Verify that lround(42.1) isn't simplified when the rounding mode is unknown.
338 ; CHECK: call i32 @llvm.experimental.constrained.lround
339 define i32 @f26() #0 {
341 %result = call i32 @llvm.experimental.constrained.lround.i32.f64(double 42.1,
342 metadata !"fpexcept.strict") #0
346 ; Verify that lround(42.0) isn't simplified when the rounding mode is unknown.
348 ; CHECK: call i32 @llvm.experimental.constrained.lround
349 define i32 @f27() #0 {
351 %result = call i32 @llvm.experimental.constrained.lround.i32.f32(float 42.0,
352 metadata !"fpexcept.strict") #0
356 ; Verify that llround(42.1) isn't simplified when the rounding mode is unknown.
358 ; CHECK: call i64 @llvm.experimental.constrained.llround
359 define i64 @f28() #0 {
361 %result = call i64 @llvm.experimental.constrained.llround.i64.f64(double 42.1,
362 metadata !"fpexcept.strict") #0
366 ; Verify that llround(42.0) isn't simplified when the rounding mode is unknown.
368 ; CHECK: call i64 @llvm.experimental.constrained.llround
369 define i64 @f29() #0 {
371 %result = call i64 @llvm.experimental.constrained.llround.i64.f32(float 42.0,
372 metadata !"fpexcept.strict") #0
376 ; Verify that sitofp(42) isn't simplified when the rounding mode is unknown.
378 ; CHECK: call double @llvm.experimental.constrained.sitofp
379 define double @f30() #0 {
381 %result = call double @llvm.experimental.constrained.sitofp.f64.i32(i32 42,
382 metadata !"round.dynamic",
383 metadata !"fpexcept.strict") #0
387 ; Verify that uitofp(42) isn't simplified when the rounding mode is unknown.
389 ; CHECK: call double @llvm.experimental.constrained.uitofp
390 define double @f31() #0 {
392 %result = call double @llvm.experimental.constrained.uitofp.f64.i32(i32 42,
393 metadata !"round.dynamic",
394 metadata !"fpexcept.strict") #0
398 attributes #0 = { strictfp }
400 @llvm.fp.env = thread_local global i8 zeroinitializer, section "llvm.metadata"
401 declare double @llvm.experimental.constrained.fdiv.f64(double, double, metadata, metadata)
402 declare double @llvm.experimental.constrained.fmul.f64(double, double, metadata, metadata)
403 declare double @llvm.experimental.constrained.fadd.f64(double, double, metadata, metadata)
404 declare double @llvm.experimental.constrained.fsub.f64(double, double, metadata, metadata)
405 declare double @llvm.experimental.constrained.sqrt.f64(double, metadata, metadata)
406 declare double @llvm.experimental.constrained.pow.f64(double, double, metadata, metadata)
407 declare double @llvm.experimental.constrained.powi.f64(double, i32, metadata, metadata)
408 declare double @llvm.experimental.constrained.sin.f64(double, metadata, metadata)
409 declare double @llvm.experimental.constrained.cos.f64(double, metadata, metadata)
410 declare double @llvm.experimental.constrained.exp.f64(double, metadata, metadata)
411 declare double @llvm.experimental.constrained.exp2.f64(double, metadata, metadata)
412 declare double @llvm.experimental.constrained.log.f64(double, metadata, metadata)
413 declare double @llvm.experimental.constrained.log10.f64(double, metadata, metadata)
414 declare double @llvm.experimental.constrained.log2.f64(double, metadata, metadata)
415 declare double @llvm.experimental.constrained.rint.f64(double, metadata, metadata)
416 declare double @llvm.experimental.constrained.nearbyint.f64(double, metadata, metadata)
417 declare double @llvm.experimental.constrained.fma.f64(double, double, double, metadata, metadata)
418 declare i32 @llvm.experimental.constrained.fptosi.i32.f64(double, metadata)
419 declare i32 @llvm.experimental.constrained.fptoui.i32.f64(double, metadata)
420 declare float @llvm.experimental.constrained.fptrunc.f32.f64(double, metadata, metadata)
421 declare double @llvm.experimental.constrained.fpext.f64.f32(float, metadata)
422 declare i32 @llvm.experimental.constrained.lrint.i32.f64(double, metadata, metadata)
423 declare i32 @llvm.experimental.constrained.lrint.i32.f32(float, metadata, metadata)
424 declare i64 @llvm.experimental.constrained.llrint.i64.f64(double, metadata, metadata)
425 declare i64 @llvm.experimental.constrained.llrint.i64.f32(float, metadata, metadata)
426 declare i32 @llvm.experimental.constrained.lround.i32.f64(double, metadata)
427 declare i32 @llvm.experimental.constrained.lround.i32.f32(float, metadata)
428 declare i64 @llvm.experimental.constrained.llround.i64.f64(double, metadata)
429 declare i64 @llvm.experimental.constrained.llround.i64.f32(float, metadata)
430 declare double @llvm.experimental.constrained.sitofp.f64.i32(i32, metadata, metadata)
431 declare double @llvm.experimental.constrained.uitofp.f64.i32(i32, metadata, metadata)