muldf3vfp_test.c revision 77ed6142daed1e068fbda64405d0de9845e40e1a
1//===-- muldf3vfp_test.c - Test __muldf3vfp -------------------------------===// 2// 3// The LLVM Compiler Infrastructure 4// 5// This file is distributed under the University of Illinois Open Source 6// License. See LICENSE.TXT for details. 7// 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; 46#endif 47 return 0; 48} 49