constant-fold-math.ll 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. ; RUN: opt -S -instcombine < %s | FileCheck %s
  2. declare float @llvm.fma.f32(float, float, float) #0
  3. declare float @llvm.fmuladd.f32(float, float, float) #0
  4. declare <4 x float> @llvm.fma.v4f32(<4 x float>, <4 x float>, <4 x float>) #0
  5. declare double @llvm.fma.f64(double, double, double) #0
  6. declare double @llvm.fmuladd.f64(double, double, double) #0
  7. declare double @llvm.sqrt.f64(double) #0
  8. ; CHECK-LABEL: @constant_fold_fma_f32
  9. ; CHECK-NEXT: ret float 6.000000e+00
  10. define float @constant_fold_fma_f32() #0 {
  11. %x = call float @llvm.fma.f32(float 1.0, float 2.0, float 4.0) #0
  12. ret float %x
  13. }
  14. ; CHECK-LABEL: @constant_fold_fma_v4f32
  15. ; CHECK-NEXT: ret <4 x float> <float 1.200000e+01, float 1.400000e+01, float 1.600000e+01, float 1.800000e+01>
  16. define <4 x float> @constant_fold_fma_v4f32() #0 {
  17. %x = call <4 x float> @llvm.fma.v4f32(<4 x float> <float 1.0, float 2.0, float 3.0, float 4.0>, <4 x float> <float 2.0, float 2.0, float 2.0, float 2.0>, <4 x float> <float 10.0, float 10.0, float 10.0, float 10.0>)
  18. ret <4 x float> %x
  19. }
  20. ; CHECK-LABEL: @constant_fold_fmuladd_f32
  21. ; CHECK-NEXT: ret float 6.000000e+00
  22. define float @constant_fold_fmuladd_f32() #0 {
  23. %x = call float @llvm.fmuladd.f32(float 1.0, float 2.0, float 4.0) #0
  24. ret float %x
  25. }
  26. ; CHECK-LABEL: @constant_fold_fma_f64
  27. ; CHECK-NEXT: ret double 6.000000e+00
  28. define double @constant_fold_fma_f64() #0 {
  29. %x = call double @llvm.fma.f64(double 1.0, double 2.0, double 4.0) #0
  30. ret double %x
  31. }
  32. ; CHECK-LABEL: @constant_fold_fmuladd_f64
  33. ; CHECK-NEXT: ret double 6.000000e+00
  34. define double @constant_fold_fmuladd_f64() #0 {
  35. %x = call double @llvm.fmuladd.f64(double 1.0, double 2.0, double 4.0) #0
  36. ret double %x
  37. }
  38. ; The sqrt intrinsic is undefined for negative inputs besides -0.0.
  39. ; CHECK-LABEL: @bad_sqrt
  40. ; CHECK-NEXT: ret double undef
  41. define double @bad_sqrt() {
  42. %x = call double @llvm.sqrt.f64(double -2.000000e+00)
  43. ret double %x
  44. }
  45. attributes #0 = { nounwind readnone }