Add some tests from PR 166463. Also make sure that all of the tests,

old and new, check the sign bits of both the remainder and the
quotient.
This commit is contained in:
David Schultz 2012-04-07 04:00:30 +00:00
parent 1cbd288942
commit afbcb86218

View File

@ -55,7 +55,7 @@ int
main(int argc, char *argv[]) main(int argc, char *argv[])
{ {
printf("1..2\n"); printf("1..3\n");
test_invalid(0.0, 0.0); test_invalid(0.0, 0.0);
test_invalid(1.0, 0.0); test_invalid(1.0, 0.0);
@ -96,6 +96,14 @@ main(int argc, char *argv[])
printf("ok 2 - rem\n"); printf("ok 2 - rem\n");
test(0x1.66666cp+120, 0x1p+71, 0.0, 1476395008);
testd(-0x1.0000000000003p+0, 0x1.0000000000003p+0, -0.0, -1);
testl(-0x1.0000000000003p+0, 0x1.0000000000003p+0, -0.0, -1);
testd(-0x1.0000000000001p-749, 0x1.4p-1072, 0x1p-1074, -1288490189);
testl(-0x1.0000000000001p-749, 0x1.4p-1072, 0x1p-1074, -1288490189);
printf("ok 3 - rem\n");
return (0); return (0);
} }
@ -136,10 +144,16 @@ static void
testl(long double x, long double y, long double expected_rem, int expected_quo) testl(long double x, long double y, long double expected_rem, int expected_quo)
{ {
int q; int q;
long double rem;
q = random(); q = random();
assert(remainderl(x, y) == expected_rem); rem = remainderl(x, y);
assert(remquol(x, y, &q) == expected_rem); assert(rem == expected_rem);
assert(!signbit(rem) == !signbit(expected_rem));
rem = remquol(x, y, &q);
assert(rem == expected_rem);
assert(!signbit(rem) == !signbit(expected_rem));
assert((q ^ expected_quo) >= 0); /* sign(q) == sign(expected_quo) */
assert((q & 0x7) == (expected_quo & 0x7)); assert((q & 0x7) == (expected_quo & 0x7));
if (q != 0) { if (q != 0) {
assert((q > 0) ^ !(expected_quo > 0)); assert((q > 0) ^ !(expected_quo > 0));
@ -152,10 +166,16 @@ static void
testd(double x, double y, double expected_rem, int expected_quo) testd(double x, double y, double expected_rem, int expected_quo)
{ {
int q; int q;
double rem;
q = random(); q = random();
assert(remainder(x, y) == expected_rem); rem = remainder(x, y);
assert(remquo(x, y, &q) == expected_rem); assert(rem == expected_rem);
assert(!signbit(rem) == !signbit(expected_rem));
rem = remquo(x, y, &q);
assert(rem == expected_rem);
assert(!signbit(rem) == !signbit(expected_rem));
assert((q ^ expected_quo) >= 0); /* sign(q) == sign(expected_quo) */
assert((q & 0x7) == (expected_quo & 0x7)); assert((q & 0x7) == (expected_quo & 0x7));
if (q != 0) { if (q != 0) {
assert((q > 0) ^ !(expected_quo > 0)); assert((q > 0) ^ !(expected_quo > 0));
@ -168,10 +188,16 @@ static void
testf(float x, float y, float expected_rem, int expected_quo) testf(float x, float y, float expected_rem, int expected_quo)
{ {
int q; int q;
float rem;
q = random(); q = random();
assert(remainderf(x, y) == expected_rem); rem = remainderf(x, y);
assert(remquof(x, y, &q) == expected_rem); assert(rem == expected_rem);
assert(!signbit(rem) == !signbit(expected_rem));
rem = remquof(x, y, &q);
assert(rem == expected_rem);
assert(!signbit(rem) == !signbit(expected_rem));
assert((q ^ expected_quo) >= 0); /* sign(q) == sign(expected_quo) */
assert((q & 0x7) == (expected_quo & 0x7)); assert((q & 0x7) == (expected_quo & 0x7));
if (q != 0) { if (q != 0) {
assert((q > 0) ^ !(expected_quo > 0)); assert((q > 0) ^ !(expected_quo > 0));