From: jakub Date: Thu, 1 Jan 2004 13:21:18 +0000 (+0000) Subject: PR optimization/13521 X-Git-Tag: upstream/4.9.2~74357 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=5670d8d0244fcd852f7953d877d576117ce2d192;p=platform%2Fupstream%2Flinaro-gcc.git PR optimization/13521 * gcc.c-torture/compile/20031231-1.c: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@75301 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index af9fabf..17e5580 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2004-01-01 Jakub Jelinek + + PR optimization/13521 + * gcc.c-torture/compile/20031231-1.c: New test. + 2003-12-30 Kazu Hirata * gcc.dg/sibcall-4.c: Replace mn10?00 with mn10300. diff --git a/gcc/testsuite/gcc.c-torture/compile/20031231-1.c b/gcc/testsuite/gcc.c-torture/compile/20031231-1.c new file mode 100644 index 0000000..bbd8e7c --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/compile/20031231-1.c @@ -0,0 +1,51 @@ +extern int f1 (int, void *); +extern int *f2 (void) __attribute__ ((__const__)); +extern int f3 (int, void *); + +int +test (int x, char *y, int z) +{ + int b = 0; + + if (x < 1024) + { + y[0] = '\0'; + + do + { + switch (f1 (x, y + b)) + { + case -1: + if (b == 0) + return -1; + else + return b; + + default: + b++; + } + } + while (y[b - 1] != '\0' && y[b - 1] != '\n' && b < z); + } + else + { + do + { + switch (f3 (x, y + b)) + { + case -1: + if ((*f2 ()) == 4) + continue; + if (b == 0) + return -1; + else + return b; + + default: + b++; + } + } + while (y[b - 1] != '\0' && y[b - 1] != '\n' && b < z); + } + return b; +}