first commit of the new libm!
[musl] / src / math / fmax.c
diff --git a/src/math/fmax.c b/src/math/fmax.c
new file mode 100644 (file)
index 0000000..0b6bf6f
--- /dev/null
@@ -0,0 +1,13 @@
+#include "libm.h"
+
+double fmax(double x, double y)
+{
+       if (isnan(x))
+               return y;
+       if (isnan(y))
+               return x;
+       /* handle signed zeros, see C99 Annex F.9.9.2 */
+       if (signbit(x) != signbit(y))
+               return signbit(x) ? y : x;
+       return x < y ? y : x;
+}