aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJanis Johnson <janis187@us.ibm.com>2002-02-06 22:16:11 +0000
committerJanis Johnson <janis@gcc.gnu.org>2002-02-06 22:16:11 +0000
commite1e52c7e550bdbcf9c5a6f47a240d30f088bb236 (patch)
tree973339347788eb315aa3737748ed30d02424259e
parenta2cd028f5fd512c04e4fdce69d4398d13b51cfb9 (diff)
downloadgcc-e1e52c7e550bdbcf9c5a6f47a240d30f088bb236.zip
gcc-e1e52c7e550bdbcf9c5a6f47a240d30f088bb236.tar.gz
gcc-e1e52c7e550bdbcf9c5a6f47a240d30f088bb236.tar.bz2
* gcc.dg/20020206-1.c: New test.
From-SVN: r49557
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gcc.dg/20020206-1.c44
2 files changed, 48 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 5c8a027..759f06c 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2002-02-06 Janis Johnson <janis187@us.ibm.com>
+
+ * gcc.dg/20020206-1.c: New test.
+
2002-02-06 Jakub Jelinek <jakub@redhat.com>
* gcc.c-torture/execute/20020206-1.c: New test.
diff --git a/gcc/testsuite/gcc.dg/20020206-1.c b/gcc/testsuite/gcc.dg/20020206-1.c
new file mode 100644
index 0000000..c536761
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/20020206-1.c
@@ -0,0 +1,44 @@
+/* This code is from the beginning of combine_reloads in reload.c in
+ GCC 3.1-20020117, with simplifications. It compiled incorrectly
+ for -O2 -fprefetch-loop-arrays for ix86 targets. */
+
+/* { dg-do run } */
+/* { dg-options "-O2 -fprefetch-loop-arrays -w" } */
+/* { dg-options "-O2 -fprefetch-loop-arrays -mcpu=pentium3 -w" { target i?86-*-* } } */
+
+struct reload
+{
+ int first_member;
+ int out;
+ int final_member;
+};
+
+int n_reloads;
+struct reload rld[10];
+
+static int
+combine_reloads ()
+{
+ int i;
+ int output_reload = -1;
+ int secondary_out = -1;
+
+ for (i = 0; i < n_reloads; i++)
+ if (rld[i].out != 0)
+ {
+ if (output_reload >= 0)
+ return output_reload;
+ output_reload = i;
+ }
+ return output_reload;
+}
+
+int
+main ()
+{
+ n_reloads = 4;
+ rld[2].out = 2;
+ if (combine_reloads () != 2)
+ abort ();
+ exit (0);
+}