mirror of
https://github.com/byteworksinc/ORCA-C.git
synced 2025-01-17 12:32:07 +00:00
6ead1d4caf
These are currently only run by the new DOIT3 test-running script. Note that these tests are designed to be applicable to most implementations of C95/C99/C11, not just ORCA/C. They do make certain assumptions not guaranteed by the standards (e.g. power of 2 types and some properties of IEEE-like FP), but in general those assumptions should be true for most 'normal' systems.
108 lines
3.0 KiB
C
108 lines
3.0 KiB
C
/*
|
|
* Test floating-point environment access with <fenv.h> (C99).
|
|
*/
|
|
|
|
#pragma STDC FENV_ACCESS ON
|
|
|
|
#include <fenv.h>
|
|
#include <float.h>
|
|
#include <stdio.h>
|
|
|
|
int main(void) {
|
|
double d;
|
|
int i;
|
|
fexcept_t excepts, excepts2 = {0};
|
|
fenv_t env, env2;
|
|
|
|
feholdexcept(&env);
|
|
|
|
i = feclearexcept(0);
|
|
if (i != 0) goto Fail;
|
|
i = feclearexcept(FE_INEXACT);
|
|
if (i != 0) goto Fail;
|
|
i = feclearexcept(FE_ALL_EXCEPT);
|
|
if (i != 0) goto Fail;
|
|
|
|
d = 1.0;
|
|
d /= 0.0;
|
|
if (fetestexcept(FE_DIVBYZERO) != FE_DIVBYZERO)
|
|
goto Fail;
|
|
i = fegetexceptflag(&excepts, FE_ALL_EXCEPT);
|
|
if (i != 0) goto Fail;
|
|
excepts2 = excepts;
|
|
|
|
i = feclearexcept(FE_ALL_EXCEPT);
|
|
if (i != 0) goto Fail;
|
|
if (fetestexcept(FE_ALL_EXCEPT) != 0)
|
|
goto Fail;
|
|
|
|
i = feraiseexcept(FE_INVALID | FE_UNDERFLOW);
|
|
if (i != 0) goto Fail;
|
|
|
|
i = fegetexceptflag(&excepts, FE_ALL_EXCEPT);
|
|
if (i != 0) goto Fail;
|
|
if (fetestexcept(FE_ALL_EXCEPT - FE_INEXACT)
|
|
!= (FE_INVALID | FE_UNDERFLOW))
|
|
goto Fail;
|
|
|
|
i = fesetexceptflag(&excepts2, FE_DIVBYZERO);
|
|
if (fetestexcept(FE_ALL_EXCEPT - FE_INEXACT)
|
|
!= (FE_INVALID | FE_UNDERFLOW | FE_DIVBYZERO))
|
|
goto Fail;
|
|
|
|
i = fesetexceptflag(&excepts2, FE_ALL_EXCEPT);
|
|
if (fetestexcept(FE_ALL_EXCEPT) != FE_DIVBYZERO)
|
|
goto Fail;
|
|
|
|
i = fetestexcept(0);
|
|
if (i != 0) goto Fail;
|
|
|
|
i = fesetround(FE_UPWARD);
|
|
if (i != 0) goto Fail;
|
|
i = fegetround();
|
|
if (i != FE_UPWARD) goto Fail;
|
|
if (FLT_ROUNDS != 2) goto Fail;
|
|
|
|
i = fegetenv(&env);
|
|
if (i != 0) goto Fail;
|
|
|
|
i = fesetround(FE_DOWNWARD);
|
|
if (i != 0) goto Fail;
|
|
i = fegetround();
|
|
if (i != FE_DOWNWARD) goto Fail;
|
|
if (FLT_ROUNDS != 3) goto Fail;
|
|
|
|
i = feclearexcept(FE_ALL_EXCEPT);
|
|
if (i != 0) goto Fail;
|
|
i = feholdexcept(&env2);
|
|
if (i != 0) goto Fail;
|
|
|
|
fesetenv(&env);
|
|
if (i != 0) goto Fail;
|
|
if (fegetround() != FE_UPWARD) goto Fail;
|
|
if (fetestexcept(FE_ALL_EXCEPT) != FE_DIVBYZERO)
|
|
goto Fail;
|
|
|
|
fesetenv(&env2);
|
|
if (i != 0) goto Fail;
|
|
if (fegetround() != FE_DOWNWARD) goto Fail;
|
|
|
|
i = feraiseexcept(FE_INVALID | FE_INEXACT);
|
|
if (i != 0) goto Fail;
|
|
|
|
feupdateenv(&env2);
|
|
if (i != 0) goto Fail;
|
|
if (fegetround() != FE_DOWNWARD) goto Fail;
|
|
if (fetestexcept(FE_ALL_EXCEPT) != (FE_INVALID | FE_INEXACT))
|
|
goto Fail;
|
|
|
|
fesetenv(FE_DFL_ENV);
|
|
if (i != 0) goto Fail;
|
|
|
|
printf ("Passed Conformance Test c99fenv\n");
|
|
return 0;
|
|
|
|
Fail:
|
|
printf ("Failed Conformance Test c99fenv\n");
|
|
}
|