@@ -23,8 +23,9 @@
int
__fesetexceptflag (const fexcept_t *flagp, int excepts)
{
- /* This always fails unless nothing needs to be done. */
- return (excepts != 0);
+ /* This always succeeds, as all exceptions are always clear
+ (including in the saved state) so nothing needs to be done. */
+ return 0;
}
#if SHLIB_COMPAT (libm, GLIBC_2_1, GLIBC_2_2)
strong_alias (__fesetexceptflag, __old_fesetexceptflag)
@@ -61,7 +61,13 @@ test_set (int initial, const fexcept_t *saved, int mask, int expected)
if (ret != 0)
{
puts ("feraiseexcept failed");
- result = 1;
+ if (initial == 0 || EXCEPTION_TESTS (float))
+ {
+ puts ("failure of feraiseexcept was unexpected");
+ result = 1;
+ }
+ else
+ puts ("failure of feraiseexcept OK, skipping further tests");
return result;
}
ret = fesetexceptflag (saved, mask);