mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-06-28 07:18:30 +00:00
Get libc/tinymath/ compiling on aarch64
This commit is contained in:
parent
2b73e72d59
commit
135080fd3e
243 changed files with 7773 additions and 4027 deletions
|
@ -32,13 +32,15 @@ asm(".ident\t\"\\n\\n\
|
|||
Musl libc (MIT License)\\n\
|
||||
Copyright 2005-2014 Rich Felker, et. al.\"");
|
||||
asm(".include \"libc/disclaimer.inc\"");
|
||||
/* clang-format off */
|
||||
// clang-format off
|
||||
|
||||
/**
|
||||
* Computes remainder and part of quotient.
|
||||
*/
|
||||
long double remquol(long double x, long double y, int *quo)
|
||||
{
|
||||
long double remquol(long double x, long double y, int *quo) {
|
||||
#if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
|
||||
return remquo(x, y, quo);
|
||||
#elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
|
||||
union ldshape ux = {x}, uy = {y};
|
||||
int ex = ux.i.se & 0x7fff;
|
||||
int ey = uy.i.se & 0x7fff;
|
||||
|
@ -67,6 +69,7 @@ long double remquol(long double x, long double y, int *quo)
|
|||
q = 0;
|
||||
if (ex >= ey) {
|
||||
/* x mod y */
|
||||
#if LDBL_MANT_DIG == 64
|
||||
uint64_t i, mx, my;
|
||||
mx = ux.i.m;
|
||||
my = uy.i.m;
|
||||
|
@ -95,6 +98,43 @@ long double remquol(long double x, long double y, int *quo)
|
|||
else
|
||||
for (; mx >> 63 == 0; mx *= 2, ex--);
|
||||
ux.i.m = mx;
|
||||
#elif LDBL_MANT_DIG == 113
|
||||
uint64_t hi, lo, xhi, xlo, yhi, ylo;
|
||||
xhi = (ux.i2.hi & -1ULL>>16) | 1ULL<<48;
|
||||
yhi = (uy.i2.hi & -1ULL>>16) | 1ULL<<48;
|
||||
xlo = ux.i2.lo;
|
||||
ylo = ux.i2.lo;
|
||||
for (; ex > ey; ex--) {
|
||||
hi = xhi - yhi;
|
||||
lo = xlo - ylo;
|
||||
if (xlo < ylo)
|
||||
hi -= 1;
|
||||
if (hi >> 63 == 0) {
|
||||
xhi = 2*hi + (lo>>63);
|
||||
xlo = 2*lo;
|
||||
q++;
|
||||
} else {
|
||||
xhi = 2*xhi + (xlo>>63);
|
||||
xlo = 2*xlo;
|
||||
}
|
||||
q <<= 1;
|
||||
}
|
||||
hi = xhi - yhi;
|
||||
lo = xlo - ylo;
|
||||
if (xlo < ylo)
|
||||
hi -= 1;
|
||||
if (hi >> 63 == 0) {
|
||||
xhi = hi;
|
||||
xlo = lo;
|
||||
q++;
|
||||
}
|
||||
if ((xhi|xlo) == 0)
|
||||
ex = -120;
|
||||
else
|
||||
for (; xhi >> 48 == 0; xhi = 2*xhi + (xlo>>63), xlo = 2*xlo, ex--);
|
||||
ux.i2.hi = xhi;
|
||||
ux.i2.lo = xlo;
|
||||
#endif
|
||||
}
|
||||
|
||||
/* scale result and decide between |x| and |x|-|y| */
|
||||
|
@ -113,4 +153,5 @@ long double remquol(long double x, long double y, int *quo)
|
|||
q &= 0x7fffffff;
|
||||
*quo = sx^sy ? -(int)q : (int)q;
|
||||
return sx ? -x : x;
|
||||
#endif
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue