about summary refs log tree commit diff
path: root/src/math/fmax.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/math/fmax.c')
-rw-r--r--src/math/fmax.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/src/math/fmax.c b/src/math/fmax.c
new file mode 100644
index 00000000..0b6bf6f3
--- /dev/null
+++ b/src/math/fmax.c
@@ -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;
+}