aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorMartin Jambor <mjambor@suse.cz>2008-11-05 17:06:38 +0100
committerMartin Jambor <jamborm@gcc.gnu.org>2008-11-05 17:06:38 +0100
commit5e9abf2ce4a4e1e380a1da8016eac24b22973dfd (patch)
tree519533d92b35a2c870dadff443e7d0905b988f61 /gcc
parent8df7b2b60e8d304998ae7b487e8981c9cc30040a (diff)
downloadgcc-5e9abf2ce4a4e1e380a1da8016eac24b22973dfd.zip
gcc-5e9abf2ce4a4e1e380a1da8016eac24b22973dfd.tar.gz
gcc-5e9abf2ce4a4e1e380a1da8016eac24b22973dfd.tar.bz2
re PR middle-end/37861 (Bogus array bounds warning)
2008-11-05 Martin Jambor <mjambor@suse.cz> PR middle-end/37861 * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Don't turn pointer arithmetics into array_ref if the array is accessed through an indirect_ref. * testsuite/gcc.dg/Warray-bounds-5.c: New file. * testsuite/gcc.dg/Warray-bounds-6.c: New file. From-SVN: r141613
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/testsuite/ChangeLog6
-rw-r--r--gcc/testsuite/gcc.dg/Warray-bounds-5.c24
-rw-r--r--gcc/testsuite/gcc.dg/Warray-bounds-6.c29
-rw-r--r--gcc/tree-ssa-forwprop.c3
5 files changed, 69 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 4a6b0c2..5511750 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2008-11-05 Martin Jambor <mjambor@suse.cz>
+
+ PR middle-end/37861
+ * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Don't turn
+ pointer arithmetics into array_ref if the array is accessed
+ through an indirect_ref.
+
2008-11-05 Richard Guenther <rguenther@suse.de>
PR middle-end/37742
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 1049f5f..fa5e732 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,9 @@
+2008-11-05 Martin Jambor <mjambor@suse.cz>
+
+ PR middle-end/37861
+ * gcc.dg/Warray-bounds-5.c: New test.
+ * gcc.dg/Warray-bounds-6.c: New test.
+
2008-11-05 Fabien Chene <fabien.chene@gmail.com>
PR c++/32519
diff --git a/gcc/testsuite/gcc.dg/Warray-bounds-5.c b/gcc/testsuite/gcc.dg/Warray-bounds-5.c
new file mode 100644
index 0000000..ba9cd2a
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/Warray-bounds-5.c
@@ -0,0 +1,24 @@
+/* { dg-do compile } */
+/* { dg-options "-O3 -Wall" } */
+/* based on PR 37861 */
+
+extern int printf (__const char *__restrict __format, ...);
+
+static int f2(char formatstr[10][100])
+{
+ int anz;
+ for( anz = 0; anz < 10; ++anz ) {
+ printf( "%d %s\n", anz, formatstr[anz] );
+ }
+ return anz;
+}
+
+
+static char formatstr[10][100];
+int main( void )
+{
+ int anz;
+ anz = f2(formatstr);
+ printf( " %d\n",anz);
+ return 0;
+}
diff --git a/gcc/testsuite/gcc.dg/Warray-bounds-6.c b/gcc/testsuite/gcc.dg/Warray-bounds-6.c
new file mode 100644
index 0000000..44a513b
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/Warray-bounds-6.c
@@ -0,0 +1,29 @@
+/* { dg-do compile } */
+/* { dg-options "-O3 -Wall" } */
+/* based on PR 37861 */
+
+extern int printf (__const char *__restrict __format, ...);
+
+static int f3(int v)
+{
+ int i,j = 0;
+ for (i = 0; i <= v; i++)
+ j++;
+ return j;
+}
+
+static int f2(char formatstr[10][100]) {
+ printf( "%d %s\n", 0, formatstr[f3(0)] );
+ printf( "%d %s\n", 1, formatstr[f3(1)] );
+ printf( "%d %s\n", 2, formatstr[f3(2)] );
+ printf( "%d %s\n", 3, formatstr[f3(3)] );
+ return 3;
+}
+
+static char formatstr[10][100];
+int main( void ) {
+ int anz;
+ anz = f2(formatstr);
+ printf( " %d\n",anz);
+ return 0;
+}
diff --git a/gcc/tree-ssa-forwprop.c b/gcc/tree-ssa-forwprop.c
index a04e7ca..5626b10 100644
--- a/gcc/tree-ssa-forwprop.c
+++ b/gcc/tree-ssa-forwprop.c
@@ -802,6 +802,9 @@ forward_propagate_addr_expr_1 (tree name, tree def_rhs,
array_ref = TREE_OPERAND (def_rhs, 0);
if (TREE_CODE (array_ref) != ARRAY_REF
|| TREE_CODE (TREE_TYPE (TREE_OPERAND (array_ref, 0))) != ARRAY_TYPE
+ /* Avoid accessing hidden multidimensional arrays in this way or VRP
+ might give out bogus warnings (see PR 37861) */
+ || TREE_CODE (TREE_OPERAND (array_ref, 0)) == INDIRECT_REF
|| !integer_zerop (TREE_OPERAND (array_ref, 1)))
return false;