Izaron added inline comments.

================
Comment at: clang/lib/AST/ExprConstant.cpp:14033-14034
+        !EvaluateFloat(E->getArg(1), RHS, Info))
+      return false;
+    if (Result.isNaN() || RHS > Result)
+      Result = RHS;
----------------
jcranmer-intel wrote:
> If I'm reading APFloat's source correctly, this doesn't suffice to 
> consistently make __builtin_fmax(±0.0, ±0.0) return +0.0 if one of the zeroes 
> is positive. (We're not required to return +0.0 in this case, but most libm 
> implementations seem to endeavor to return +0.0 in this situation, even if 
> the LLVM intrinsic we lower to doesn't).
These cases are covered in tests (in a wrong manner though as I see), I was 
"checking" that we have `+0.0` if one of the zeroes is positive


================
Comment at: clang/test/Sema/constant-builtins-fmax.cpp:35-39
+#define FMAX_TEST_BOTH_ZERO(T, FUNC)       \
+    static_assert(0.0 == FUNC(0.0, 0.0));  \
+    static_assert(0.0 == FUNC(-0.0, 0.0)); \
+    static_assert(0.0 == FUNC(0.0, -0.0)); \
+    static_assert(0.0 == FUNC(-0.0, -0.0));
----------------
jcranmer-intel wrote:
> These tests aren't covering what the sign of zero is in these cases.
Cool! Thank you, today I learned that this compiles:
```
static_assert(0.0 == 0.0);
static_assert(0.0 == -0.0);
static_assert(0.0 == +0.0);
```

So I think I need to test the `+0.0` cases with the `__builtin_signbit` (I 
didn't find another way), BUT this function is not constexpr yet. So I need to 
implement a constexpr `__builtin_signbit` first... In a new pull request.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D134369/new/

https://reviews.llvm.org/D134369

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to