f6565cd1a6
directly, rather than via scabnl.
20 lines
314 B
C
20 lines
314 B
C
#include <math.h>
|
|
#include <errno.h>
|
|
|
|
long double ldexpl(long double x, int expn)
|
|
{
|
|
long double res;
|
|
if (!isfinite (x) || x == 0.0L)
|
|
return x;
|
|
|
|
__asm__ ("fscale"
|
|
: "=t" (res)
|
|
: "0" (x), "u" ((long double) expn));
|
|
|
|
if (!isfinite (res) || res == 0.0L)
|
|
errno = ERANGE;
|
|
|
|
return res;
|
|
}
|
|
|