CFLAGS+=-g -pipe -std=c99 -D_POSIX_C_SOURCE=200809L -Wall -Wno-unused-function -Wno-missing-braces
-CFLAGS+=-fno-builtin -D_GNU_SOURCE
+CFLAGS+=-Wno-unknown-pragmas -fno-builtin -ffloat-store -frounding-math -D_GNU_SOURCE
LDFLAGS+=-g -lm
SRC=$(sort $(wildcard *.c))
$(BIN): util.o
-%.o: %.c sanity/%.h ucb/%.h crlibm/%.h
+%.o: %.c sanity/%.h ucb/%.h crlibm/%.h util.h
$(CC) $(CFLAGS) -c -o $@ $<
%: %.c
%: %.o
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = acos(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s acos(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = acosf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s acosf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = acosh(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s acosh(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = acoshf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s acoshf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = acoshl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s acoshl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = acosl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s acosl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = asin(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s asin(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = asinf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s asinf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = asinh(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s asinh(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = asinhf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s asinhf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = asinhl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s asinhl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = asinl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s asinl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = atan(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s atan(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = atan2(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s atan2(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = atan2f(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s atan2f(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = atan2l(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s atan2l(%La,%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = atanf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s atanf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = atanh(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s atanh(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = atanhf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s atanhf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = atanhl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s atanhl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = atanl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s atanl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = cbrt(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s cbrt(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = cbrtf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s cbrtf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = cbrtl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s cbrtl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ceil(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ceil(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ceilf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ceilf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ceill(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ceill(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = copysign(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s copysign(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = copysignf(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s copysignf(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = copysignl(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s copysignl(%La,%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = cos(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s cos(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = cosf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s cosf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = cosh(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s cosh(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = coshf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s coshf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = coshl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s coshl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = cosl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s cosl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = erf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s erf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = erfc(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s erfc(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = erfcf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s erfcf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = erfcl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s erfcl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = erff(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s erff(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = erfl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s erfl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = exp(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s exp(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = exp10(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s exp10(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = exp10f(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s exp10f(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = exp10l(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s exp10l(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = exp2(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s exp2(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = exp2f(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s exp2f(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = exp2l(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s exp2l(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = expf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s expf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = expl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s expl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = expm1(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s expm1(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = expm1f(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s expm1f(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = expm1l(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s expm1l(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fabs(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fabs(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fabsf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fabsf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fabsl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fabsl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fdim(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fdim(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fdimf(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fdimf(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fdiml(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fdiml(%La,%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = floor(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s floor(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = floorf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s floorf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = floorl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s floorl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fmax(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fmax(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fmaxf(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fmaxf(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fmaxl(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fmaxl(%La,%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fmin(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fmin(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fminf(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fminf(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fminl(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fminl(%La,%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fmod(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fmod(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fmodf(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fmodf(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = fmodl(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s fmodl(%La,%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
int yi;
double y;
float d;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = frexp(p->x, &yi);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s frexp(%a)=%a,%lld, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, p->i, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
int yi;
double y;
float d;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = frexpf(p->x, &yi);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s frexpf(%a)=%a,%lld, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, p->i, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
int yi;
long double y;
float d;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = frexpl(p->x, &yi);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s frexpl(%La)=%La,%lld, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, p->i, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ___(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ___(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
int yi;
double y;
float d;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ___(p->x, &yi);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ___(%a)=%a,%lld, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, p->i, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ___(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ___(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ___(p->x, p->i);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ___(%a, %lld)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->i, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ___(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ___(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
int yi;
double y;
float d;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ___(p->x, &yi);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ___(%a)=%a,%lld, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, p->i, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ___(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ___(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ___(p->x, p->i);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ___(%a, %lld)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->i, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ___(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ___(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
int yi;
long double y;
float d;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ___(p->x, &yi);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ___(%La)=%La,%lld, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, p->i, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ___(p->x, p->i);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ___(%La, %lld)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->i, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ___(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ___(%La,%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = hypot(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s hypot(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = hypotf(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s hypotf(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = hypotl(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s hypotl(%La,%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = j0(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s j0(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = j0f(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s j0f(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = j1(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s j1(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = j1f(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s j1f(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ldexp(p->x, p->i);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ldexp(%a, %lld)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->i, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ldexpf(p->x, p->i);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ldexpf(%a, %lld)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->i, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = ldexpl(p->x, p->i);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s ldexpl(%La, %lld)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->i, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
int yi;
double y;
float d;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = lgamma(p->x);
yi = signgam;
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s lgamma(%a)=%a,%lld, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, p->i, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
int yi;
double y;
float d;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = lgamma_r(p->x, &yi);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s lgamma_r(%a)=%a,%lld, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, p->i, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
int yi;
double y;
float d;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = lgammaf(p->x);
yi = signgam;
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s lgammaf(%a)=%a,%lld, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, p->i, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
int yi;
double y;
float d;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = lgammaf_r(p->x, &yi);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s lgammaf_r(%a)=%a,%lld, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, p->i, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
int yi;
long double y;
float d;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = lgammal(p->x);
yi = signgam;
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s lgammal(%La)=%La,%lld, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, p->i, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
int yi;
long double y;
float d;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = lgammal_r(p->x, &yi);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s lgammal_r(%La)=%La,%lld, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, p->i, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = log(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s log(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = log10(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s log10(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = log10f(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s log10f(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = log10l(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s log10l(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = log1p(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s log1p(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = log1pf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s log1pf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = log1pl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s log1pl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = log2(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s log2(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = log2f(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s log2f(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = log2l(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s log2l(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = logb(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s logb(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = logbf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s logbf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = logbl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s logbl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = logf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s logf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = logl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s logl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = nearbyint(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s nearbyint(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = nearbyintf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s nearbyintf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = nearbyintl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s nearbyintl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = nextafter(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s nextafter(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = nextafterf(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s nextafterf(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = nextafterl(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s nextafterl(%La,%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = nexttowardl(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s nexttowardl(%La,%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = pow(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s pow(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = pow10(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s pow10(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = pow10f(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s pow10f(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = pow10l(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s pow10l(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = powf(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s powf(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = powl(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s powl(%La,%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = remainder(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s remainder(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = remainderf(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s remainderf(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = remainderl(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s remainderl(%La,%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = rint(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s rint(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = rintf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s rintf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = rintl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s rintl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = round(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s round(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = roundf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s roundf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = roundl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s roundl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = scalb(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s scalb(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = scalbf(p->x, p->x2);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s scalbf(%a,%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->x2, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = scalbln(p->x, p->i);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s scalbln(%a, %lld)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->i, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = scalblnf(p->x, p->i);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s scalblnf(%a, %lld)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->i, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = scalblnl(p->x, p->i);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s scalblnl(%La, %lld)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->i, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = scalbn(p->x, p->i);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s scalbn(%a, %lld)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->i, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = scalbnf(p->x, p->i);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s scalbnf(%a, %lld)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->i, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = scalbnl(p->x, p->i);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s scalbnl(%La, %lld)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->i, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = sin(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s sin(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = sinf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s sinf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = sinh(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s sinh(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = sinhf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s sinhf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = sinhl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s sinhl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = sinl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s sinl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = sqrt(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s sqrt(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = sqrtf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s sqrtf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = sqrtl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s sqrtl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = tan(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s tan(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = tanf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s tanf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = tanh(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s tanh(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = tanhf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s tanhf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = tanhl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s tanhl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = tanl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s tanl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = tgamma(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s tgamma(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = tgammaf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s tgammaf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = tgammal(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s tgammal(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = trunc(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s trunc(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = truncf(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s truncf(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
long double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = truncl(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s truncl(%La)=%La, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
}
return "R?";
}
-
-void setupfenv(int r)
-{
- fesetround(r);
- feclearexcept(FE_ALL_EXCEPT);
-}
-
-int getexcept(void)
-{
- return fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
-}
-
char *estr(int);
char *rstr(int);
-int rconv(int *, char *);
-int econv(int *, char *);
-
-int eulp(double);
-int eulpf(float);
-int eulpl(long double);
float ulperr(double got, double want, float dwant);
float ulperrf(float got, float want, float dwant);
float ulperrl(long double got, long double want, float dwant);
-void setupfenv(int);
-int getexcept(void);
-
static int checkexcept(int got, int want, int r)
{
+ // TODO: we dont checkunderflow and inexact for now
if (r == RN)
- return got == want || got == (want|INEXACT);
- return 1; //(got|INEXACT|UNDERFLOW) == (want|INEXACT|UNDERFLOW);
+ return (got|INEXACT|UNDERFLOW) == (want|INEXACT|UNDERFLOW);
+// return got == want || got == (want|INEXACT);
+ return 1;
}
static int checkulp(float d, int r)
{
+ // TODO: we only care about >=1.5 ulp errors for now, should be 1.0
if (r == RN)
- return fabsf(d) <= 1.0;
- return 1; //fabsf(d) <= 2.0;
+ return fabsf(d) < 1.5;
+ return 1;
}
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = y0(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s y0(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = y0f(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s y0f(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
double y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = y1(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s y1(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));
int main(void)
{
+ #pragma STDC FENV_ACCESS ON
float y;
float d;
int e, i, err = 0;
for (i = 0; i < sizeof t/sizeof *t; i++) {
p = t + i;
- setupfenv(p->r);
+
+ if (p->r < 0)
+ continue;
+ fesetround(p->r);
+ feclearexcept(FE_ALL_EXCEPT);
y = y1f(p->x);
- e = getexcept();
+ e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW);
+
if (!checkexcept(e, p->e, p->r)) {
printf("%s:%d: bad fp exception: %s y1f(%a)=%a, want %s",
p->file, p->line, rstr(p->r), p->x, p->y, estr(p->e));