blob: 73454bf290aab8ede32c475214d57da6ce9f8a35 [file] [log] [blame]
Nick Kledzikad98c812009-09-11 20:13:32 +00001//===-- muldf3vfp_test.c - Test __muldf3vfp -------------------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
Howard Hinnant9ad441f2010-11-16 22:13:33 +00005// This file is dual licensed under the MIT and the University of Illinois Open
6// Source Licenses. See LICENSE.TXT for details.
Nick Kledzikad98c812009-09-11 20:13:32 +00007//
8//===----------------------------------------------------------------------===//
9//
10// This file tests __muldf3vfp for the compiler_rt library.
11//
12//===----------------------------------------------------------------------===//
13
14#include <stdio.h>
15#include <stdlib.h>
16#include <math.h>
17
18
19#if __arm__
20extern double __muldf3vfp(double a, double b);
21
22int test__muldf3vfp(double a, double b)
23{
24 double actual = __muldf3vfp(a, b);
25 double expected = a * b;
26 if (actual != expected)
27 printf("error in test__muldf3vfp(%f, %f) = %f, expected %f\n",
28 a, b, actual, expected);
29 return actual != expected;
30}
31#endif
32
33int main()
34{
35#if __arm__
36 if (test__muldf3vfp(0.5, 10.0))
37 return 1;
38 if (test__muldf3vfp(-0.5, -2.0))
39 return 1;
40 if (test__muldf3vfp(HUGE_VALF, 0.25))
41 return 1;
42 if (test__muldf3vfp(-0.125, HUGE_VALF))
43 return 1;
44 if (test__muldf3vfp(0.0, -0.0))
45 return 1;
Joerg Sonnenberger74828152011-05-29 21:43:29 +000046#else
47 printf("skipped\n");
Nick Kledzikad98c812009-09-11 20:13:32 +000048#endif
49 return 0;
50}