diff options
author | rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-11-27 08:02:21 +0000 |
---|---|---|
committer | rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-11-27 08:02:21 +0000 |
commit | b260145896aeb1878a3f92815e70523504bb5691 (patch) | |
tree | 4411a328cedb9c767fa8aacdb737cf70b1e388ff /gcc | |
parent | de27a4735751b94d7822a3bb977eb410a4dc98e0 (diff) | |
download | gcc-b260145896aeb1878a3f92815e70523504bb5691.tar.gz |
New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@47370 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/testsuite/gcc.c-torture/execute/20011126-2.c | 43 |
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 00000000000..f6625058afb --- /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; +} |