X-Git-Url: http://nsz.repo.hu/git/?p=libc-test;a=blobdiff_plain;f=src%2Fmath%2Fllroundl.c;h=de46e7e1cd9f0882634916d6b803f9aa48822be3;hp=04917fefb37e1a28ba9c76dd5cfdca6ddcbd0ba6;hb=b55b931794bff9e88a3443daa8404c74f7f1d17c;hpb=125fb69ba64c0064de25eb1a23217b00aa393051 diff --git a/src/math/llroundl.c b/src/math/llroundl.c index 04917fe..de46e7e 100644 --- a/src/math/llroundl.c +++ b/src/math/llroundl.c @@ -1,13 +1,15 @@ #include #include -#include "util.h" +#include "mtest.h" static struct l_i t[] = { #if LDBL_MANT_DIG == 53 #include "sanity/llround.h" +#include "special/llround.h" #elif LDBL_MANT_DIG == 64 #include "sanity/llroundl.h" +#include "special/llroundl.h" #endif }; @@ -29,13 +31,13 @@ int main(void) yi = llroundl(p->x); e = fetestexcept(INEXACT|INVALID|DIVBYZERO|UNDERFLOW|OVERFLOW); - if (!checkexcept(e, p->e, p->r)) { + if (!checkexcept(e, p->e, p->r) && (e|INEXACT) != p->e) { printf("%s:%d: bad fp exception: %s llroundl(%La)=%lld, want %s", p->file, p->line, rstr(p->r), p->x, p->i, estr(p->e)); printf(" got %s\n", estr(e)); err++; } - if (yi != p->i) { + if (!(p->e&INVALID) && yi != p->i) { printf("%s:%d: %s llroundl(%La) want %lld got %lld\n", p->file, p->line, rstr(p->r), p->x, p->i, yi); err++;