summaryrefslogtreecommitdiff
path: root/compat/djgpp/math.c
diff options
context:
space:
mode:
Diffstat (limited to 'compat/djgpp/math.c')
-rw-r--r--compat/djgpp/math.c47
1 files changed, 47 insertions, 0 deletions
diff --git a/compat/djgpp/math.c b/compat/djgpp/math.c
new file mode 100644
index 0000000000..777b879e01
--- /dev/null
+++ b/compat/djgpp/math.c
@@ -0,0 +1,47 @@
+/*
+ * This file is part of FFmpeg.
+ *
+ * FFmpeg is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * FFmpeg is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with FFmpeg; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#include <math.h>
+
+#define FUN(name, type, op) \
+type name(type x, type y) \
+{ \
+ if (fpclassify(x) == FP_NAN) return y; \
+ if (fpclassify(y) == FP_NAN) return x; \
+ return x op y ? x : y; \
+}
+
+FUN(fmin, double, <)
+FUN(fmax, double, >)
+FUN(fminf, float, <)
+FUN(fmaxf, float, >)
+
+long double fmodl(long double x, long double y)
+{
+ return fmod(x, y);
+}
+
+long double scalbnl(long double x, int exp)
+{
+ return scalbn(x, exp);
+}
+
+long double copysignl(long double x, long double y)
+{
+ return copysign(x, y);
+}