diff options
| author | Joerg Sonnenberger <joerg@bec.de> | 2014-06-19 20:24:49 +0000 |
|---|---|---|
| committer | Joerg Sonnenberger <joerg@bec.de> | 2014-06-19 20:24:49 +0000 |
| commit | 361519f409705c5f5907f036475ee3f5ff89d66c (patch) | |
| tree | abc60caa534bd900bc6951357e3767f09898c98a /compiler-rt | |
| parent | 5165b37c6328249affdb9b96a997beeac6e0dc38 (diff) | |
| download | bcm5719-llvm-361519f409705c5f5907f036475ee3f5ff89d66c.tar.gz bcm5719-llvm-361519f409705c5f5907f036475ee3f5ff89d66c.zip | |
Provide add and sub for IEEE quad. From GuanHong Liu.
Differential Revision: http://reviews.llvm.org/D2798
llvm-svn: 211312
Diffstat (limited to 'compiler-rt')
| -rw-r--r-- | compiler-rt/lib/builtins/CMakeLists.txt | 3 | ||||
| -rw-r--r-- | compiler-rt/lib/builtins/addtf3.c | 25 | ||||
| -rw-r--r-- | compiler-rt/lib/builtins/subtf3.c | 27 | ||||
| -rw-r--r-- | compiler-rt/test/builtins/Unit/addtf3_test.c | 81 | ||||
| -rw-r--r-- | compiler-rt/test/builtins/Unit/subtf3_test.c | 74 |
5 files changed, 210 insertions, 0 deletions
diff --git a/compiler-rt/lib/builtins/CMakeLists.txt b/compiler-rt/lib/builtins/CMakeLists.txt index f2cdb04f61b..7e279f23ade 100644 --- a/compiler-rt/lib/builtins/CMakeLists.txt +++ b/compiler-rt/lib/builtins/CMakeLists.txt @@ -8,6 +8,7 @@ set(GENERIC_SOURCES absvti2.c adddf3.c addsf3.c + addtf3.c addvdi3.c addvsi3.c addvti3.c @@ -38,6 +39,7 @@ set(GENERIC_SOURCES divsf3.c divsi3.c divti3.c + divtf3.c divxc3.c enable_execute_stack.c eprintf.c @@ -119,6 +121,7 @@ set(GENERIC_SOURCES subvdi3.c subvsi3.c subvti3.c + subtf3.c trampoline_setup.c truncdfsf2.c ucmpdi2.c diff --git a/compiler-rt/lib/builtins/addtf3.c b/compiler-rt/lib/builtins/addtf3.c new file mode 100644 index 00000000000..e4bbe0227ae --- /dev/null +++ b/compiler-rt/lib/builtins/addtf3.c @@ -0,0 +1,25 @@ +//===-- lib/addtf3.c - Quad-precision addition --------------------*- C -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file implements quad-precision soft-float addition with the IEEE-754 +// default rounding (to nearest, ties to even). +// +//===----------------------------------------------------------------------===// + +#define QUAD_PRECISION +#include "fp_lib.h" + +#if defined(CRT_HAS_128BIT) && defined(CRT_LDBL_128BIT) +#include "fp_add_impl.inc" + +COMPILER_RT_ABI long double __addtf3(long double a, long double b){ + return __addXf3__(a, b); +} + +#endif diff --git a/compiler-rt/lib/builtins/subtf3.c b/compiler-rt/lib/builtins/subtf3.c new file mode 100644 index 00000000000..609b816f41e --- /dev/null +++ b/compiler-rt/lib/builtins/subtf3.c @@ -0,0 +1,27 @@ +//===-- lib/subtf3.c - Quad-precision subtraction -----------------*- C -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file implements quad-precision soft-float subtraction with the +// IEEE-754 default rounding (to nearest, ties to even). +// +//===----------------------------------------------------------------------===// + +#define QUAD_PRECISION +#include "fp_lib.h" + +#if defined(CRT_HAS_128BIT) && defined(CRT_LDBL_128BIT) +COMPILER_RT_ABI fp_t __addtf3(fp_t a, fp_t b); + +// Subtraction; flip the sign bit of b and add. +COMPILER_RT_ABI fp_t +__subtf3(fp_t a, fp_t b) { + return __addtf3(a, fromRep(toRep(b) ^ signBit)); +} + +#endif diff --git a/compiler-rt/test/builtins/Unit/addtf3_test.c b/compiler-rt/test/builtins/Unit/addtf3_test.c new file mode 100644 index 00000000000..4a3aacd96e6 --- /dev/null +++ b/compiler-rt/test/builtins/Unit/addtf3_test.c @@ -0,0 +1,81 @@ +//===--------------- addtf3_test.c - Test __addtf3 ------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file tests __addtf3 for the compiler_rt library. +// +//===----------------------------------------------------------------------===// + +#include <stdio.h> + +#if __LDBL_MANT_DIG__ == 113 + +#include "fp_test.h" + +// Returns: a + b +long double __addtf3(long double a, long double b); + +int test__addtf3(long double a, long double b, + uint64_t expectedHi, uint64_t expectedLo) +{ + long double x = __addtf3(a, b); + int ret = compareResultLD(x, expectedHi, expectedLo); + + if (ret){ + printf("error in test__addtf3(%.20Lf, %.20Lf) = %.20Lf, " + "expected %.20Lf\n", a, b, x, + fromRep128(expectedHi, expectedLo)); + } + + return ret; +} + +char assumption_1[sizeof(long double) * CHAR_BIT == 128] = {0}; + +#endif + +int main() +{ +#if __LDBL_MANT_DIG__ == 113 + // qNaN + any = qNaN + if (test__addtf3(makeQNaN128(), + 0x1.23456789abcdefp+5L, + UINT64_C(0x7fff800000000000), + UINT64_C(0x0))) + return 1; + // NaN + any = NaN + if (test__addtf3(makeNaN128(UINT64_C(0x800030000000)), + 0x1.23456789abcdefp+5L, + UINT64_C(0x7fff800000000000), + UINT64_C(0x0))) + return 1; + // inf + inf = inf + if (test__addtf3(makeInf128(), + makeInf128(), + UINT64_C(0x7fff000000000000), + UINT64_C(0x0))) + return 1; + // inf + any = inf + if (test__addtf3(makeInf128(), + 0x1.2335653452436234723489432abcdefp+5L, + UINT64_C(0x7fff000000000000), + UINT64_C(0x0))) + return 1; + // any + any + if (test__addtf3(0x1.23456734245345543849abcdefp+5L, + 0x1.edcba52449872455634654321fp-1L, + UINT64_C(0x40042afc95c8b579), + UINT64_C(0x61e58dd6c51eb77c))) + return 1; + +#else + printf("skipped\n"); + +#endif + return 0; +} diff --git a/compiler-rt/test/builtins/Unit/subtf3_test.c b/compiler-rt/test/builtins/Unit/subtf3_test.c new file mode 100644 index 00000000000..2ab249a994c --- /dev/null +++ b/compiler-rt/test/builtins/Unit/subtf3_test.c @@ -0,0 +1,74 @@ +//===--------------- subtf3_test.c - Test __subtf3 ------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file tests __subtf3 for the compiler_rt library. +// +//===----------------------------------------------------------------------===// + +#include <stdio.h> + +#if __LDBL_MANT_DIG__ == 113 + +#include "fp_test.h" + +// Returns: a - b +long double __subtf3(long double a, long double b); + +int test__subtf3(long double a, long double b, + uint64_t expectedHi, uint64_t expectedLo) +{ + long double x = __subtf3(a, b); + int ret = compareResultLD(x, expectedHi, expectedLo); + + if (ret){ + printf("error in test__subtf3(%.20Lf, %.20Lf) = %.20Lf, " + "expected %.20Lf\n", a, b, x, + fromRep128(expectedHi, expectedLo)); + } + return ret; +} + +char assumption_1[sizeof(long double) * CHAR_BIT == 128] = {0}; + +#endif + +int main() +{ +#if __LDBL_MANT_DIG__ == 113 + // qNaN - any = qNaN + if (test__subtf3(makeQNaN128(), + 0x1.23456789abcdefp+5L, + UINT64_C(0x7fff800000000000), + UINT64_C(0x0))) + return 1; + // NaN - any = NaN + if (test__subtf3(makeNaN128(UINT64_C(0x800030000000)), + 0x1.23456789abcdefp+5L, + UINT64_C(0x7fff800000000000), + UINT64_C(0x0))) + return 1; + // inf - any = inf + if (test__subtf3(makeInf128(), + 0x1.23456789abcdefp+5L, + UINT64_C(0x7fff000000000000), + UINT64_C(0x0))) + return 1; + // any - any + if (test__subtf3(0x1.234567829a3bcdef5678ade36734p+5L, + 0x1.ee9d7c52354a6936ab8d7654321fp-1L, + UINT64_C(0x40041b8af1915166), + UINT64_C(0xa44a7bca780a166c))) + return 1; + +#else + printf("skipped\n"); + +#endif + return 0; +} |

