diff options
author | Sergey Dmitrouk <sdmitrouk@accesssoftek.com> | 2015-04-06 11:54:51 +0000 |
---|---|---|
committer | Sergey Dmitrouk <sdmitrouk@accesssoftek.com> | 2015-04-06 11:54:51 +0000 |
commit | f3206d62781509f6e7089bee292cab6ea5a85f8c (patch) | |
tree | 9a5dc67bbf31862b0dd7de5b913ec617097ec415 /compiler-rt/lib/builtins/fixsfdi.c | |
parent | d403b292544b699ee3b98a40302886ce1176c55e (diff) | |
download | bcm5719-llvm-f3206d62781509f6e7089bee292cab6ea5a85f8c.tar.gz bcm5719-llvm-f3206d62781509f6e7089bee292cab6ea5a85f8c.zip |
Add hard float versions of FP to LL conversions
This adds hard-float implementation for the following builtins:
* __fixdfdi()
* __fixsfdi()
* __fixunsdfdi()
* __fixunssfdi()
The soft-float implementation does never raise floating point
exceptions, which doesn't allow clients to detect floating point
conversion errors.
I must mention that I had to refer to libgcc's implementation to
write these functions.
Related unit-tests of compiler-rt passed with these changes.
Patch was somewhat out-dated, so was updated locally without any
functional changes.
Differential Revision: http://reviews.llvm.org/D5376
llvm-svn: 234148
Diffstat (limited to 'compiler-rt/lib/builtins/fixsfdi.c')
-rw-r--r-- | compiler-rt/lib/builtins/fixsfdi.c | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/compiler-rt/lib/builtins/fixsfdi.c b/compiler-rt/lib/builtins/fixsfdi.c index 835ff852d3e..fab47e272a2 100644 --- a/compiler-rt/lib/builtins/fixsfdi.c +++ b/compiler-rt/lib/builtins/fixsfdi.c @@ -13,6 +13,28 @@ ARM_EABI_FNALIAS(f2lz, fixsfdi) +#ifndef __SOFT_FP__ +/* Support for systems that have hardware floating-point; can set the invalid + * flag as a side-effect of computation. + */ + +COMPILER_RT_ABI du_int __fixunssfdi(float a); + +COMPILER_RT_ABI di_int +__fixsfdi(float a) +{ + if (a < 0.0f) { + return -__fixunssfdi(-a); + } + return __fixunssfdi(a); +} + +#else +/* Support for systems that don't have hardware floating-point; there are no + * flags to set, and we don't want to code-gen to an unknown soft-float + * implementation. + */ + typedef di_int fixint_t; typedef du_int fixuint_t; #include "fp_fixint_impl.inc" @@ -21,3 +43,5 @@ COMPILER_RT_ABI di_int __fixsfdi(fp_t a) { return __fixint(a); } + +#endif |