float.carbon 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. // Part of the Carbon Language project, under the Apache License v2.0 with LLVM
  2. // Exceptions. See /LICENSE for license information.
  3. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  4. //
  5. // AUTOUPDATE
  6. fn Negate(a: f64) -> f64 = "float.negate";
  7. fn TestNegate(a: f64) -> f64 { return Negate(a); }
  8. fn Add(a: f64, b: f64) -> f64 = "float.add";
  9. fn TestAdd(a: f64, b: f64) -> f64 { return Add(a, b); }
  10. fn Sub(a: f64, b: f64) -> f64 = "float.sub";
  11. fn TestSub(a: f64, b: f64) -> f64 { return Sub(a, b); }
  12. fn Mul(a: f64, b: f64) -> f64 = "float.mul";
  13. fn TestMul(a: f64, b: f64) -> f64 { return Mul(a, b); }
  14. fn Div(a: f64, b: f64) -> f64 = "float.div";
  15. fn TestDiv(a: f64, b: f64) -> f64 { return Div(a, b); }
  16. fn Eq(a: f64, b: f64) -> bool = "float.eq";
  17. fn TestEq(a: f64, b: f64) -> bool { return Eq(a, b); }
  18. fn Neq(a: f64, b: f64) -> bool = "float.neq";
  19. fn TestNeq(a: f64, b: f64) -> bool { return Neq(a, b); }
  20. fn Less(a: f64, b: f64) -> bool = "float.less";
  21. fn TestLess(a: f64, b: f64) -> bool { return Less(a, b); }
  22. fn LessEq(a: f64, b: f64) -> bool = "float.less_eq";
  23. fn TestLessEq(a: f64, b: f64) -> bool { return LessEq(a, b); }
  24. fn Greater(a: f64, b: f64) -> bool = "float.greater";
  25. fn TestGreater(a: f64, b: f64) -> bool { return Greater(a, b); }
  26. fn GreaterEq(a: f64, b: f64) -> bool = "float.greater_eq";
  27. fn TestGreaterEq(a: f64, b: f64) -> bool { return GreaterEq(a, b); }
  28. // CHECK:STDOUT: ; ModuleID = 'float.carbon'
  29. // CHECK:STDOUT: source_filename = "float.carbon"
  30. // CHECK:STDOUT:
  31. // CHECK:STDOUT: define double @TestNegate(double %a) {
  32. // CHECK:STDOUT: entry:
  33. // CHECK:STDOUT: %float.negate = fneg double %a
  34. // CHECK:STDOUT: ret double %float.negate
  35. // CHECK:STDOUT: }
  36. // CHECK:STDOUT:
  37. // CHECK:STDOUT: define double @TestAdd(double %a, double %b) {
  38. // CHECK:STDOUT: entry:
  39. // CHECK:STDOUT: %float.add = fadd double %a, %b
  40. // CHECK:STDOUT: ret double %float.add
  41. // CHECK:STDOUT: }
  42. // CHECK:STDOUT:
  43. // CHECK:STDOUT: define double @TestSub(double %a, double %b) {
  44. // CHECK:STDOUT: entry:
  45. // CHECK:STDOUT: %float.sub = fsub double %a, %b
  46. // CHECK:STDOUT: ret double %float.sub
  47. // CHECK:STDOUT: }
  48. // CHECK:STDOUT:
  49. // CHECK:STDOUT: define double @TestMul(double %a, double %b) {
  50. // CHECK:STDOUT: entry:
  51. // CHECK:STDOUT: %float.mul = fmul double %a, %b
  52. // CHECK:STDOUT: ret double %float.mul
  53. // CHECK:STDOUT: }
  54. // CHECK:STDOUT:
  55. // CHECK:STDOUT: define double @TestDiv(double %a, double %b) {
  56. // CHECK:STDOUT: entry:
  57. // CHECK:STDOUT: %float.div = fdiv double %a, %b
  58. // CHECK:STDOUT: ret double %float.div
  59. // CHECK:STDOUT: }
  60. // CHECK:STDOUT:
  61. // CHECK:STDOUT: define i1 @TestEq(double %a, double %b) {
  62. // CHECK:STDOUT: entry:
  63. // CHECK:STDOUT: %float.eq = fcmp oeq double %a, %b
  64. // CHECK:STDOUT: ret i1 %float.eq
  65. // CHECK:STDOUT: }
  66. // CHECK:STDOUT:
  67. // CHECK:STDOUT: define i1 @TestNeq(double %a, double %b) {
  68. // CHECK:STDOUT: entry:
  69. // CHECK:STDOUT: %float.neq = fcmp one double %a, %b
  70. // CHECK:STDOUT: ret i1 %float.neq
  71. // CHECK:STDOUT: }
  72. // CHECK:STDOUT:
  73. // CHECK:STDOUT: define i1 @TestLess(double %a, double %b) {
  74. // CHECK:STDOUT: entry:
  75. // CHECK:STDOUT: %float.less = fcmp olt double %a, %b
  76. // CHECK:STDOUT: ret i1 %float.less
  77. // CHECK:STDOUT: }
  78. // CHECK:STDOUT:
  79. // CHECK:STDOUT: define i1 @TestLessEq(double %a, double %b) {
  80. // CHECK:STDOUT: entry:
  81. // CHECK:STDOUT: %float.less_eq = fcmp ole double %a, %b
  82. // CHECK:STDOUT: ret i1 %float.less_eq
  83. // CHECK:STDOUT: }
  84. // CHECK:STDOUT:
  85. // CHECK:STDOUT: define i1 @TestGreater(double %a, double %b) {
  86. // CHECK:STDOUT: entry:
  87. // CHECK:STDOUT: %float.greater = fcmp ogt double %a, %b
  88. // CHECK:STDOUT: ret i1 %float.greater
  89. // CHECK:STDOUT: }
  90. // CHECK:STDOUT:
  91. // CHECK:STDOUT: define i1 @TestGreaterEq(double %a, double %b) {
  92. // CHECK:STDOUT: entry:
  93. // CHECK:STDOUT: %float.greater_eq = fcmp oge double %a, %b
  94. // CHECK:STDOUT: ret i1 %float.greater_eq
  95. // CHECK:STDOUT: }