From: Hans-Peter Nilsson Date: Sat, 18 Mar 2000 03:26:47 +0000 (+0000) Subject: divconst-2.c: Rewrite to check for standards-compliant result rather than specific... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=82ec9e78291b497ce00d671fe515ba7542df0552;p=gcc.git 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 --- diff --git a/gcc/testsuite/gcc.c-torture/ChangeLog b/gcc/testsuite/gcc.c-torture/ChangeLog index 20499e867db..b1355290071 100644 --- a/gcc/testsuite/gcc.c-torture/ChangeLog +++ b/gcc/testsuite/gcc.c-torture/ChangeLog @@ -1,3 +1,8 @@ +Fri Mar 10 01:15:19 2000 Hans-Peter Nilsson + + * 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 * execute/20000224-1.c (main): Expected return-value is 1, not diff --git a/gcc/testsuite/gcc.c-torture/execute/divconst-2.c b/gcc/testsuite/gcc.c-torture/execute/divconst-2.c index d3adaf3a0af..b58f1bfddc4 100644 --- a/gcc/testsuite/gcc.c-torture/execute/divconst-2.c +++ b/gcc/testsuite/gcc.c-torture/execute/divconst-2.c @@ -4,9 +4,36 @@ f (long x) 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 () { - if (f (-1L) != 0L || f (0x7fffffffL) != 0L || f (-0x7fffffffL - 1L) != 1l) - abort (); + int i; + + 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); }