1 1.1 joerg //===-- addsf3vfp_test.c - Test __addsf3vfp -------------------------------===// 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 __addsf3vfp 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 float __addsf3vfp(float a, float b); 20 1.1 joerg 21 1.1 joerg #if __arm__ 22 1.1 joerg int test__addsf3vfp(float a, float b) 23 1.1 joerg { 24 1.1 joerg float actual = __addsf3vfp(a, b); 25 1.1 joerg float expected = a + b; 26 1.1 joerg if (actual != expected) 27 1.1 joerg printf("error in test__addsf3vfp(%f, %f) = %f, expected %f\n", 28 1.1 joerg a, b, 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__addsf3vfp(1.0, 1.0)) 37 1.1 joerg return 1; 38 1.1 joerg if (test__addsf3vfp(HUGE_VALF, HUGE_VALF)) 39 1.1 joerg return 1; 40 1.1 joerg if (test__addsf3vfp(0.0, HUGE_VALF)) 41 1.1 joerg return 1; 42 1.1 joerg if (test__addsf3vfp(0.0, -0.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