From: Richard Guenther Date: Fri, 11 Jul 2008 12:44:26 +0000 (+0000) Subject: re PR tree-optimization/36765 (Revision 137573 miscompiles 464.h264ref in SPEC CPU... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=941a9479d0a4d5fb26182ee6c485c4bf210a6499;p=gcc.git re PR tree-optimization/36765 (Revision 137573 miscompiles 464.h264ref in SPEC CPU 2006) 2008-07-11 Richard Guenther PR tree-optimization/36765 * tree-ssa-alias.c (compute_flow_insensitive_aliasing): Add aliases from HEAP vars to SMTs. * gcc.c-torture/execute/pr36765.c: New testcase. From-SVN: r137715 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index e5d68ed6ef8..04004fa76df 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2008-07-11 Richard Guenther + + PR tree-optimization/36765 + * tree-ssa-alias.c (compute_flow_insensitive_aliasing): Add + aliases from HEAP vars to SMTs. + 2008-07-10 Kaveh R. Ghazi * Makefile.in (LOOSE_WARN, STRICT_WARN): Update comments. diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 0b83fa5c37f..f26bcbf46e6 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2008-07-11 Richard Guenther + + PR tree-optimization/36765 + * gcc.c-torture/execute/pr36765.c: New testcase. + 2008-07-10 Joseph Myers PR middle-end/29056 diff --git a/gcc/testsuite/gcc.c-torture/execute/pr36765.c b/gcc/testsuite/gcc.c-torture/execute/pr36765.c new file mode 100644 index 00000000000..6883b0cfd75 --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/pr36765.c @@ -0,0 +1,15 @@ +int __attribute__((noinline)) +foo(int i) +{ + int *p = __builtin_malloc (4 * sizeof(int)); + *p = 0; + p[i] = 1; + return *p; +} +extern void abort (void); +int main() +{ + if (foo(0) != 1) + abort (); + return 0; +} diff --git a/gcc/tree-ssa-alias.c b/gcc/tree-ssa-alias.c index d4a1e219a0c..3aa79feddd6 100644 --- a/gcc/tree-ssa-alias.c +++ b/gcc/tree-ssa-alias.c @@ -2370,6 +2370,8 @@ have_common_aliases_p (bitmap tag1aliases, bitmap tag2aliases) static void compute_flow_insensitive_aliasing (struct alias_info *ai) { + referenced_var_iterator rvi; + tree var; size_t i; timevar_push (TV_FLOW_INSENSITIVE); @@ -2460,6 +2462,24 @@ compute_flow_insensitive_aliasing (struct alias_info *ai) add_may_alias (tag1, tag2); } } + + /* We have to add all HEAP variables to all SMTs aliases bitmaps. + As we don't know which effective type the HEAP will have we cannot + do better here and we need the conflicts with obfuscated pointers + (a simple (*(int[n] *)ptr)[i] will do, with ptr from a VLA array + allocation). */ + for (i = 0; i < ai->num_pointers; i++) + { + struct alias_map_d *p_map = ai->pointers[i]; + tree tag = symbol_mem_tag (p_map->var); + + FOR_EACH_REFERENCED_VAR (var, rvi) + { + if (var_ann (var)->is_heapvar) + add_may_alias (tag, var); + } + } + timevar_pop (TV_FLOW_INSENSITIVE); }