1 1.1 joerg //===-- negdf2vfp_test.c - Test __negdf2vfp -------------------------------===// 2 1.1 joerg // 3 1.1 joerg // The LLVM Compiler Infrastructure 4 1.1 joerg // 5 1.1 joerg // This file is dual licensed under the MIT and the University of Illinois Open 6 1.1 joerg // Source Licenses. See LICENSE.TXT for details. 7 1.1 joerg // 8 1.1 joerg //===----------------------------------------------------------------------===// 9 1.1 joerg // 10 1.1 joerg // This file tests __negdf2vfp for the compiler_rt library. 11 1.1 joerg // 12 1.1 joerg //===----------------------------------------------------------------------===// 13 1.1 joerg 14 1.1 joerg #include <stdio.h> 15 1.1 joerg #include <stdlib.h> 16 1.1 joerg #include <math.h> 17 1.1 joerg 18 1.1 joerg 19 1.1 joerg extern double __negdf2vfp(double a); 20 1.1 joerg 21 1.1 joerg #if __arm__ 22 1.1 joerg int test__negdf2vfp(double a) 23 1.1 joerg { 24 1.1 joerg double actual = __negdf2vfp(a); 25 1.1 joerg double expected = -a; 26 1.1 joerg if (actual != expected) 27 1.1 joerg printf("error in test__negdf2vfp(%f) = %f, expected %f\n", 28 1.1 joerg a, actual, expected); 29 1.1 joerg return actual != expected; 30 1.1 joerg } 31 1.1 joerg #endif 32 1.1 joerg 33 1.1 joerg int main() 34 1.1 joerg { 35 1.1 joerg #if __arm__ 36 1.1 joerg if (test__negdf2vfp(1.0)) 37 1.1 joerg return 1; 38 1.1 joerg if (test__negdf2vfp(HUGE_VALF)) 39 1.1 joerg return 1; 40 1.1 joerg if (test__negdf2vfp(0.0)) 41 1.1 joerg return 1; 42 1.1 joerg if (test__negdf2vfp(-1.0)) 43 1.1 joerg return 1; 44 1.1 joerg #else 45 1.1 joerg printf("skipped\n"); 46 1.1 joerg #endif 47 1.1 joerg return 0; 48 1.1 joerg } 49