1b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar//===-- fixunsdfti_test.c - Test __fixunsdfti -----------------------------===// 2b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// 3b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// The LLVM Compiler Infrastructure 4b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// 59ad441ffec97db647fee3725b3424284fb913e14Howard Hinnant// This file is dual licensed under the MIT and the University of Illinois Open 69ad441ffec97db647fee3725b3424284fb913e14Howard Hinnant// Source Licenses. See LICENSE.TXT for details. 7b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// 8b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar//===----------------------------------------------------------------------===// 9b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// 10b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// This file tests __fixunsdfti for the compiler_rt library. 11b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// 12b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar//===----------------------------------------------------------------------===// 13b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 14b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar#include "int_lib.h" 15b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar#include <stdio.h> 16b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 17b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// Returns: convert a to a unsigned long long, rounding toward zero. 18b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// Negative values all become zero. 19b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 20b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// Assumption: double is a IEEE 64 bit floating point type 21b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// tu_int is a 64 bit integral type 22b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// value in double is representable in tu_int or is negative 23b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// (no range checking performed) 24b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 25b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar// seee eeee eeee mmmm mmmm mmmm mmmm mmmm | mmmm mmmm mmmm mmmm mmmm mmmm mmmm mmmm 26b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 272d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines#ifdef CRT_HAS_128BIT 28b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 29b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbartu_int __fixunsdfti(double a); 30b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 31b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbarint test__fixunsdfti(double a, tu_int expected) 32b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar{ 33b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar tu_int x = __fixunsdfti(a); 34b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (x != expected) 35b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar { 36b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar utwords xt; 37b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar xt.all = x; 38b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar utwords expectedt; 39b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar expectedt.all = expected; 40b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar printf("error in __fixunsdfti(%A) = 0x%.16llX%.16llX, expected 0x%.16llX%.16llX\n", 41cff5248a12a36a7225b707b23ac088f5ba214f8aDaniel Dunbar a, xt.s.high, xt.s.low, expectedt.s.high, expectedt.s.low); 42b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar } 43b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return x != expected; 44b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar} 45b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 46b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbarchar assumption_1[sizeof(tu_int) == 2*sizeof(du_int)] = {0}; 47b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbarchar assumption_2[sizeof(su_int)*CHAR_BIT == 32] = {0}; 48b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbarchar assumption_3[sizeof(double)*CHAR_BIT == 64] = {0}; 49b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 50b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar#endif 51b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 52b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbarint main() 53b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar{ 542d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines#ifdef CRT_HAS_128BIT 55b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(0.0, 0)) 56b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 57b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 58b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(0.5, 0)) 59b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 60b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(0.99, 0)) 61b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 62b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(1.0, 1)) 63b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 64b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(1.5, 1)) 65b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 66b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(1.99, 1)) 67b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 68b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(2.0, 2)) 69b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 70b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(2.01, 2)) 71b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 72b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(-0.5, 0)) 73b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 74b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(-0.99, 0)) 75b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 76b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar#if !TARGET_LIBGCC 77b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(-1.0, 0)) // libgcc ignores "returns 0 for negative input" spec 78b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 79b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(-1.5, 0)) 80b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 81b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(-1.99, 0)) 82b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 83b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(-2.0, 0)) 84b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 85b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(-2.01, 0)) 86b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 87b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar#endif 88b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 89b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(0x1.FFFFFEp+62, 0x7FFFFF8000000000LL)) 90b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 91b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(0x1.FFFFFCp+62, 0x7FFFFF0000000000LL)) 92b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 93b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 94b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar#if !TARGET_LIBGCC 95b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(-0x1.FFFFFEp+62, 0)) 96b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 97b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(-0x1.FFFFFCp+62, 0)) 98b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 99b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar#endif 100b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 101b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(0x1.FFFFFFFFFFFFFp+63, 0xFFFFFFFFFFFFF800LL)) 102b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 103b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(0x1.0000000000000p+63, 0x8000000000000000LL)) 104b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 105b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(0x1.FFFFFFFFFFFFFp+62, 0x7FFFFFFFFFFFFC00LL)) 106b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 107b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(0x1.FFFFFFFFFFFFEp+62, 0x7FFFFFFFFFFFF800LL)) 108b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 109b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 110b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(0x1.FFFFFFFFFFFFFp+127, make_ti(0xFFFFFFFFFFFFF800LL, 0))) 111b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 112b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(0x1.0000000000000p+127, make_ti(0x8000000000000000LL, 0))) 113b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 114b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(0x1.FFFFFFFFFFFFFp+126, make_ti(0x7FFFFFFFFFFFFC00LL, 0))) 115b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 116b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(0x1.FFFFFFFFFFFFEp+126, make_ti(0x7FFFFFFFFFFFF800LL, 0))) 117b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 118b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 119b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar#if !TARGET_LIBGCC 120b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(-0x1.FFFFFFFFFFFFFp+62, 0)) 121b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 122b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar if (test__fixunsdfti(-0x1.FFFFFFFFFFFFEp+62, 0)) 123b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 1; 124b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar#endif 125b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar 126b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar#endif 127b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar return 0; 128b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar} 129