From: Jakub Jelinek Date: Tue, 24 Jun 2008 10:06:17 +0000 (+0200) Subject: re PR tree-optimization/36504 (ICE when building xorg-server with -O3 -fprefetch... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a80a27015e7a09109ace946db74b780532267f66;p=gcc.git re PR tree-optimization/36504 (ICE when building xorg-server with -O3 -fprefetch-loop-arrays) PR tree-optimization/36504 * tree-ssa-loop-prefetch.c (gather_memory_references_ref): Skip references without base address. * gcc.dg/pr36504.c: New test. From-SVN: r137061 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 9ab80e03a9f..4a88491c3f8 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2008-06-24 Jakub Jelinek + + PR tree-optimization/36504 + * tree-ssa-loop-prefetch.c (gather_memory_references_ref): Skip + references without base address. + 2008-06-23 Uros Bizjak PR middle-end/PR36584 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index a377829b674..c7a7cd26fb4 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2008-06-24 Jakub Jelinek + + PR tree-optimization/36504 + * gcc.dg/pr36504.c: New test. + 2008-06-23 Uros Bizjak PR middle-end/PR36584 diff --git a/gcc/testsuite/gcc.dg/pr36504.c b/gcc/testsuite/gcc.dg/pr36504.c new file mode 100644 index 00000000000..0db6ebced8d --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr36504.c @@ -0,0 +1,25 @@ +/* PR tree-optimization/36504 */ +/* { dg-do compile } */ +/* { dg-options "-O3 -fprefetch-loop-arrays" } */ + +struct A { struct { int a; } b[8]; }; +struct B { int c; int d; }; +struct C { struct B d; }; + +void bar (struct C *, int); + +struct B +foo (struct C *p, struct A *e, int b) +{ + struct B q; + bar (p, e->b[b].a); + return q; +} + +void +baz (int b, struct A *e) +{ + struct C p; + for (; b; ++b) + p.d = foo (&p, e, b); +} diff --git a/gcc/tree-ssa-loop-prefetch.c b/gcc/tree-ssa-loop-prefetch.c index 651ccbb5227..14044c407d7 100644 --- a/gcc/tree-ssa-loop-prefetch.c +++ b/gcc/tree-ssa-loop-prefetch.c @@ -457,6 +457,9 @@ gather_memory_references_ref (struct loop *loop, struct mem_ref_group **refs, HOST_WIDE_INT step, delta; struct mem_ref_group *agrp; + if (get_base_address (ref) == NULL) + return false; + if (!analyze_ref (loop, &ref, &base, &step, &delta, stmt)) return false;