From 82ec9e78291b497ce00d671fe515ba7542df0552 Mon Sep 17 00:00:00 2001 From: Hans-Peter Nilsson Date: Sat, 18 Mar 2000 03:26:47 +0000 Subject: [PATCH] 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 --- gcc/testsuite/gcc.c-torture/ChangeLog | 5 +++ .../gcc.c-torture/execute/divconst-2.c | 31 +++++++++++++++++-- 2 files changed, 34 insertions(+), 2 deletions(-) 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); } -- 2.30.2