aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite
diff options
context:
space:
mode:
authorRichard Henderson <rth@gcc.gnu.org>2001-11-27 00:02:21 -0800
committerRichard Henderson <rth@gcc.gnu.org>2001-11-27 00:02:21 -0800
commit08884e66575e07544cf5bba20d19e07d62b67a52 (patch)
tree4411a328cedb9c767fa8aacdb737cf70b1e388ff /gcc/testsuite
parent07e96fc688ba9fcc49c0e71ce8a3b484feacac52 (diff)
downloadgcc-08884e66575e07544cf5bba20d19e07d62b67a52.zip
gcc-08884e66575e07544cf5bba20d19e07d62b67a52.tar.gz
gcc-08884e66575e07544cf5bba20d19e07d62b67a52.tar.bz2
New test.
From-SVN: r47370
Diffstat (limited to 'gcc/testsuite')
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/20011126-2.c43
1 files changed, 43 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.c-torture/execute/20011126-2.c b/gcc/testsuite/gcc.c-torture/execute/20011126-2.c
new file mode 100644
index 0000000..f662505
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/execute/20011126-2.c
@@ -0,0 +1,43 @@
+/* Problem originally visible on ia64.
+
+ There is a partial redundancy of "in + 1" that makes GCSE want to
+ transform the final while loop to
+
+ p = in + 1;
+ tmp = p;
+ ...
+ goto start;
+ top:
+ tmp = tmp + 1;
+ start:
+ in = tmp;
+ if (in < p) goto top;
+
+ We miscalculate the number of loop iterations as (p - tmp) = 0
+ instead of (p - in) = 1, which results in overflow in the doloop
+ optimization. */
+
+static const char *
+test (const char *in, char *out)
+{
+ while (1)
+ {
+ if (*in == 'a')
+ {
+ const char *p = in + 1;
+ while (*p == 'x')
+ ++p;
+ if (*p == 'b')
+ return p;
+ while (in < p)
+ *out++ = *in++;
+ }
+ }
+}
+
+int main ()
+{
+ char out[4];
+ test ("aab", out);
+ return 0;
+}