aboutsummaryrefslogtreecommitdiff
path: root/test/Unit/eqdf2vfp_test.c
diff options
context:
space:
mode:
authorEd Schouten <ed@FreeBSD.org>2010-10-21 19:02:02 +0000
committerEd Schouten <ed@FreeBSD.org>2010-10-21 19:02:02 +0000
commit217b614317dad692116a3a06fe94ea8f61a59edb (patch)
tree4cfe2eee875a959effca0881df14c079103447fa /test/Unit/eqdf2vfp_test.c
downloadsrc-217b614317dad692116a3a06fe94ea8f61a59edb.tar.gz
src-217b614317dad692116a3a06fe94ea8f61a59edb.zip
Import compiler-rt r117047.vendor/compiler-rt/compiler-rt-r117047
Notes
Notes: svn path=/vendor/compiler-rt/dist/; revision=214152 svn path=/vendor/compiler-rt/compiler-rt-r117047/; revision=214153; tag=vendor/compiler-rt/compiler-rt-r117047
Diffstat (limited to 'test/Unit/eqdf2vfp_test.c')
-rw-r--r--test/Unit/eqdf2vfp_test.c53
1 files changed, 53 insertions, 0 deletions
diff --git a/test/Unit/eqdf2vfp_test.c b/test/Unit/eqdf2vfp_test.c
new file mode 100644
index 000000000000..36b77ad783eb
--- /dev/null
+++ b/test/Unit/eqdf2vfp_test.c
@@ -0,0 +1,53 @@
+//===-- eqdf2vfp_test.c - Test __eqdf2vfp ---------------------------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// This file tests __eqdf2vfp for the compiler_rt library.
+//
+//===----------------------------------------------------------------------===//
+
+#include <stdlib.h>
+#include <stdint.h>
+#include <stdio.h>
+#include <math.h>
+
+
+extern int __eqdf2vfp(double a, double b);
+
+#if __arm__
+int test__eqdf2vfp(double a, double b)
+{
+ int actual = __eqdf2vfp(a, b);
+ int expected = (a == b) ? 1 : 0;
+ if (actual != expected)
+ printf("error in __eqdf2vfp(%f, %f) = %d, expected %d\n",
+ a, b, actual, expected);
+ return actual != expected;
+}
+#endif
+
+int main()
+{
+#if __arm__
+ if (test__eqdf2vfp(0.0, 0.0))
+ return 1;
+ if (test__eqdf2vfp(1.0, 1.0))
+ return 1;
+ if (test__eqdf2vfp(0.0, 1.0))
+ return 1;
+ if (test__eqdf2vfp(-1.0, -1.0))
+ return 1;
+ if (test__eqdf2vfp(-1.0, 0.0))
+ return 1;
+ if (test__eqdf2vfp(HUGE_VAL, 1.0))
+ return 1;
+ if (test__eqdf2vfp(1.0, HUGE_VAL))
+ return 1;
+#endif
+ return 0;
+}