Commit 82ec9e78 by Hans-Peter Nilsson Committed by Hans-Peter Nilsson

divconst-2.c: Rewrite to check for standards-compliant result rather than specific constants.

	* execute/divconst-2.c: Rewrite to check for standards-compliant
	result rather than specific constants.  Put test-values in array.

From-SVN: r32615
parent 787ccee0
Fri Mar 10 01:15:19 2000 Hans-Peter Nilsson <hp@bitrange.com>
* execute/divconst-2.c: Rewrite to check for standards-compliant
result rather than specific constants. Put test-values in array.
Sun Mar 5 23:25:12 2000 Hans-Peter Nilsson <hp@bitrange.com> Sun Mar 5 23:25:12 2000 Hans-Peter Nilsson <hp@bitrange.com>
* execute/20000224-1.c (main): Expected return-value is 1, not * execute/20000224-1.c (main): Expected return-value is 1, not
......
...@@ -4,9 +4,36 @@ f (long x) ...@@ -4,9 +4,36 @@ f (long x)
return x / (-0x7fffffffL - 1L); return x / (-0x7fffffffL - 1L);
} }
long
r (long x)
{
return x % (-0x7fffffffL - 1L);
}
/* Since we have a negative divisor, this equation must hold for the
results of / and %; no specific results are guaranteed. */
long
std_eqn (long num, long denom, long quot, long rem)
{
/* For completeness, a check for "ABS (rem) < ABS (denom)" belongs here,
but causes trouble on 32-bit machines and isn't worthwhile. */
return quot * (-0x7fffffffL - 1L) + rem == num;
}
long nums[] =
{
-1L, 0x7fffffffL, -0x7fffffffL - 1L
};
main () main ()
{ {
if (f (-1L) != 0L || f (0x7fffffffL) != 0L || f (-0x7fffffffL - 1L) != 1l) int i;
abort ();
for (i = 0;
i < sizeof (nums) / sizeof (nums[0]);
i++)
if (std_eqn (nums[i], -0x7fffffffL - 1L, f (nums[i]), r (nums[i])) == 0)
abort ();
exit (0); exit (0);
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment