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 tan(42.0) isn't simplified when the rounding mode is unknown.
156 ; CHECK: call double @llvm.experimental.constrained.tan
157 define double @ftan() #0 {
159 %result = call double @llvm.experimental.constrained.tan.f64(double 42.0,
160 metadata !"round.dynamic",
161 metadata !"fpexcept.strict") #0
165 ; Verify that acos(42.0) isn't simplified when the rounding mode is unknown.
167 ; CHECK: call double @llvm.experimental.constrained.acos
168 define double @facos() #0 {
170 %result = call double @llvm.experimental.constrained.acos.f64(double 42.0,
171 metadata !"round.dynamic",
172 metadata !"fpexcept.strict") #0
176 ; Verify that asin(42.0) isn't simplified when the rounding mode is unknown.
178 ; CHECK: call double @llvm.experimental.constrained.asin
179 define double @fasin() #0 {
181 %result = call double @llvm.experimental.constrained.asin.f64(double 42.0,
182 metadata !"round.dynamic",
183 metadata !"fpexcept.strict") #0
187 ; Verify that atan(42.0, 23.0) isn't simplified when the rounding mode is unknown.
189 ; CHECK: call double @llvm.experimental.constrained.atan
190 define double @fatan() #0 {
192 %result = call double @llvm.experimental.constrained.atan.f64(double 42.0,
193 metadata !"round.dynamic",
194 metadata !"fpexcept.strict") #0
198 ; Verify that atan2(42.0) isn't simplified when the rounding mode is unknown.
199 ; CHECK-LABEL: fatan2
200 ; CHECK: call double @llvm.experimental.constrained.atan2
201 define double @fatan2() #0 {
203 %result = call double @llvm.experimental.constrained.atan2.f64(
206 metadata !"round.dynamic",
207 metadata !"fpexcept.strict") #0
211 ; Verify that cosh(42.0) isn't simplified when the rounding mode is unknown.
213 ; CHECK: call double @llvm.experimental.constrained.cosh
214 define double @fcosh() #0 {
216 %result = call double @llvm.experimental.constrained.cosh.f64(double 42.0,
217 metadata !"round.dynamic",
218 metadata !"fpexcept.strict") #0
222 ; Verify that sinh(42.0) isn't simplified when the rounding mode is unknown.
224 ; CHECK: call double @llvm.experimental.constrained.sinh
225 define double @fsinh() #0 {
227 %result = call double @llvm.experimental.constrained.sinh.f64(double 42.0,
228 metadata !"round.dynamic",
229 metadata !"fpexcept.strict") #0
233 ; Verify that tanh(42.0) isn't simplified when the rounding mode is unknown.
235 ; CHECK: call double @llvm.experimental.constrained.tanh
236 define double @ftanh() #0 {
238 %result = call double @llvm.experimental.constrained.tanh.f64(double 42.0,
239 metadata !"round.dynamic",
240 metadata !"fpexcept.strict") #0
244 ; Verify that exp(42.0) isn't simplified when the rounding mode is unknown.
246 ; CHECK: call double @llvm.experimental.constrained.exp
247 define double @f10() #0 {
249 %result = call double @llvm.experimental.constrained.exp.f64(double 42.0,
250 metadata !"round.dynamic",
251 metadata !"fpexcept.strict") #0
255 ; Verify that exp2(42.1) isn't simplified when the rounding mode is unknown.
257 ; CHECK: call double @llvm.experimental.constrained.exp2
258 define double @f11() #0 {
260 %result = call double @llvm.experimental.constrained.exp2.f64(double 42.1,
261 metadata !"round.dynamic",
262 metadata !"fpexcept.strict") #0
266 ; Verify that log(42.0) isn't simplified when the rounding mode is unknown.
268 ; CHECK: call double @llvm.experimental.constrained.log
269 define double @f12() #0 {
271 %result = call double @llvm.experimental.constrained.log.f64(double 42.0,
272 metadata !"round.dynamic",
273 metadata !"fpexcept.strict") #0
277 ; Verify that log10(42.0) isn't simplified when the rounding mode is unknown.
279 ; CHECK: call double @llvm.experimental.constrained.log10
280 define double @f13() #0 {
282 %result = call double @llvm.experimental.constrained.log10.f64(double 42.0,
283 metadata !"round.dynamic",
284 metadata !"fpexcept.strict") #0
288 ; Verify that log2(42.0) isn't simplified when the rounding mode is unknown.
290 ; CHECK: call double @llvm.experimental.constrained.log2
291 define double @f14() #0 {
293 %result = call double @llvm.experimental.constrained.log2.f64(double 42.0,
294 metadata !"round.dynamic",
295 metadata !"fpexcept.strict") #0
299 ; Verify that rint(42.1) isn't simplified when the rounding mode is unknown.
301 ; CHECK: call double @llvm.experimental.constrained.rint
302 define double @f15() #0 {
304 %result = call double @llvm.experimental.constrained.rint.f64(double 42.1,
305 metadata !"round.dynamic",
306 metadata !"fpexcept.strict") #0
310 ; Verify that nearbyint(42.1) isn't simplified when the rounding mode is
313 ; CHECK: call double @llvm.experimental.constrained.nearbyint
314 define double @f16() #0 {
316 %result = call double @llvm.experimental.constrained.nearbyint.f64(
318 metadata !"round.dynamic",
319 metadata !"fpexcept.strict") #0
323 ; Verify that fma(42.1) isn't simplified when the rounding mode is
326 ; CHECK: call double @llvm.experimental.constrained.fma
327 define double @f17() #0 {
329 %result = call double @llvm.experimental.constrained.fma.f64(double 42.1, double 42.1, double 42.1,
330 metadata !"round.dynamic",
331 metadata !"fpexcept.strict") #0
335 ; Verify that fptoui(42.1) isn't simplified when the rounding mode is
338 ; CHECK: call zeroext i32 @llvm.experimental.constrained.fptoui
339 define zeroext i32 @f18() #0 {
341 %result = call zeroext i32 @llvm.experimental.constrained.fptoui.i32.f64(
343 metadata !"fpexcept.strict") #0
347 ; Verify that fptosi(42.1) isn't simplified when the rounding mode is
350 ; CHECK: call i32 @llvm.experimental.constrained.fptosi
351 define i32 @f19() #0 {
353 %result = call i32 @llvm.experimental.constrained.fptosi.i32.f64(double 42.1,
354 metadata !"fpexcept.strict") #0
358 ; Verify that fptrunc(42.1) isn't simplified when the rounding mode is
361 ; CHECK: call float @llvm.experimental.constrained.fptrunc
362 define float @f20() #0 {
364 %result = call float @llvm.experimental.constrained.fptrunc.f32.f64(
366 metadata !"round.dynamic",
367 metadata !"fpexcept.strict") #0
371 ; Verify that fpext(42.1) isn't simplified when the rounding mode is
374 ; CHECK: call double @llvm.experimental.constrained.fpext
375 define double @f21() #0 {
377 %result = call double @llvm.experimental.constrained.fpext.f64.f32(float 42.0,
378 metadata !"fpexcept.strict") #0
382 ; Verify that lrint(42.1) isn't simplified when the rounding mode is unknown.
384 ; CHECK: call i32 @llvm.experimental.constrained.lrint
385 define i32 @f22() #0 {
387 %result = call i32 @llvm.experimental.constrained.lrint.i32.f64(double 42.1,
388 metadata !"round.dynamic",
389 metadata !"fpexcept.strict") #0
393 ; Verify that lrintf(42.0) isn't simplified when the rounding mode is unknown.
395 ; CHECK: call i32 @llvm.experimental.constrained.lrint
396 define i32 @f23() #0 {
398 %result = call i32 @llvm.experimental.constrained.lrint.i32.f32(float 42.0,
399 metadata !"round.dynamic",
400 metadata !"fpexcept.strict") #0
404 ; Verify that llrint(42.1) isn't simplified when the rounding mode is unknown.
406 ; CHECK: call i64 @llvm.experimental.constrained.llrint
407 define i64 @f24() #0 {
409 %result = call i64 @llvm.experimental.constrained.llrint.i64.f64(double 42.1,
410 metadata !"round.dynamic",
411 metadata !"fpexcept.strict") #0
415 ; Verify that llrint(42.0) isn't simplified when the rounding mode is unknown.
417 ; CHECK: call i64 @llvm.experimental.constrained.llrint
418 define i64 @f25() #0 {
420 %result = call i64 @llvm.experimental.constrained.llrint.i64.f32(float 42.0,
421 metadata !"round.dynamic",
422 metadata !"fpexcept.strict") #0
426 ; Verify that lround(42.1) isn't simplified when the rounding mode is unknown.
428 ; CHECK: call i32 @llvm.experimental.constrained.lround
429 define i32 @f26() #0 {
431 %result = call i32 @llvm.experimental.constrained.lround.i32.f64(double 42.1,
432 metadata !"fpexcept.strict") #0
436 ; Verify that lround(42.0) isn't simplified when the rounding mode is unknown.
438 ; CHECK: call i32 @llvm.experimental.constrained.lround
439 define i32 @f27() #0 {
441 %result = call i32 @llvm.experimental.constrained.lround.i32.f32(float 42.0,
442 metadata !"fpexcept.strict") #0
446 ; Verify that llround(42.1) isn't simplified when the rounding mode is unknown.
448 ; CHECK: call i64 @llvm.experimental.constrained.llround
449 define i64 @f28() #0 {
451 %result = call i64 @llvm.experimental.constrained.llround.i64.f64(double 42.1,
452 metadata !"fpexcept.strict") #0
456 ; Verify that llround(42.0) isn't simplified when the rounding mode is unknown.
458 ; CHECK: call i64 @llvm.experimental.constrained.llround
459 define i64 @f29() #0 {
461 %result = call i64 @llvm.experimental.constrained.llround.i64.f32(float 42.0,
462 metadata !"fpexcept.strict") #0
466 ; Verify that sitofp(42) isn't simplified when the rounding mode is unknown.
468 ; CHECK: call double @llvm.experimental.constrained.sitofp
469 define double @f30() #0 {
471 %result = call double @llvm.experimental.constrained.sitofp.f64.i32(i32 42,
472 metadata !"round.dynamic",
473 metadata !"fpexcept.strict") #0
477 ; Verify that uitofp(42) isn't simplified when the rounding mode is unknown.
479 ; CHECK: call double @llvm.experimental.constrained.uitofp
480 define double @f31() #0 {
482 %result = call double @llvm.experimental.constrained.uitofp.f64.i32(i32 42,
483 metadata !"round.dynamic",
484 metadata !"fpexcept.strict") #0
488 attributes #0 = { strictfp }
490 @llvm.fp.env = thread_local global i8 zeroinitializer, section "llvm.metadata"
491 declare double @llvm.experimental.constrained.fdiv.f64(double, double, metadata, metadata)
492 declare double @llvm.experimental.constrained.fmul.f64(double, double, metadata, metadata)
493 declare double @llvm.experimental.constrained.fadd.f64(double, double, metadata, metadata)
494 declare double @llvm.experimental.constrained.fsub.f64(double, double, metadata, metadata)
495 declare double @llvm.experimental.constrained.sqrt.f64(double, metadata, metadata)
496 declare double @llvm.experimental.constrained.pow.f64(double, double, metadata, metadata)
497 declare double @llvm.experimental.constrained.powi.f64(double, i32, metadata, metadata)
498 declare double @llvm.experimental.constrained.sin.f64(double, metadata, metadata)
499 declare double @llvm.experimental.constrained.cos.f64(double, metadata, metadata)
500 declare double @llvm.experimental.constrained.tan.f64(double, metadata, metadata)
501 declare double @llvm.experimental.constrained.exp.f64(double, metadata, metadata)
502 declare double @llvm.experimental.constrained.exp2.f64(double, metadata, metadata)
503 declare double @llvm.experimental.constrained.log.f64(double, metadata, metadata)
504 declare double @llvm.experimental.constrained.log10.f64(double, metadata, metadata)
505 declare double @llvm.experimental.constrained.log2.f64(double, metadata, metadata)
506 declare double @llvm.experimental.constrained.rint.f64(double, metadata, metadata)
507 declare double @llvm.experimental.constrained.nearbyint.f64(double, metadata, metadata)
508 declare double @llvm.experimental.constrained.fma.f64(double, double, double, metadata, metadata)
509 declare i32 @llvm.experimental.constrained.fptosi.i32.f64(double, metadata)
510 declare i32 @llvm.experimental.constrained.fptoui.i32.f64(double, metadata)
511 declare float @llvm.experimental.constrained.fptrunc.f32.f64(double, metadata, metadata)
512 declare double @llvm.experimental.constrained.fpext.f64.f32(float, metadata)
513 declare i32 @llvm.experimental.constrained.lrint.i32.f64(double, metadata, metadata)
514 declare i32 @llvm.experimental.constrained.lrint.i32.f32(float, metadata, metadata)
515 declare i64 @llvm.experimental.constrained.llrint.i64.f64(double, metadata, metadata)
516 declare i64 @llvm.experimental.constrained.llrint.i64.f32(float, metadata, metadata)
517 declare i32 @llvm.experimental.constrained.lround.i32.f64(double, metadata)
518 declare i32 @llvm.experimental.constrained.lround.i32.f32(float, metadata)
519 declare i64 @llvm.experimental.constrained.llround.i64.f64(double, metadata)
520 declare i64 @llvm.experimental.constrained.llround.i64.f32(float, metadata)
521 declare double @llvm.experimental.constrained.sitofp.f64.i32(i32, metadata, metadata)
522 declare double @llvm.experimental.constrained.uitofp.f64.i32(i32, metadata, metadata)