aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2007-11-05 09:44:23 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2007-11-05 09:44:23 +0100
commit0976ffb63f5c2d03f1e58fd7e085799b0043d638 (patch)
tree3f7aac96f192e556316bc575c5abc7f7e3d41142 /gcc
parentf370e66bb8c7fe4b8fe694dd79f13e834b4e7575 (diff)
downloadgcc-0976ffb63f5c2d03f1e58fd7e085799b0043d638.zip
gcc-0976ffb63f5c2d03f1e58fd7e085799b0043d638.tar.gz
gcc-0976ffb63f5c2d03f1e58fd7e085799b0043d638.tar.bz2
re PR tree-optimization/33856 (Segfault in create_data_ref/compute_data_dependences_for_loop)
PR tree-optimization/33856 * tree-data-ref.c (get_references_in_stmt): Don't add REFERENCE_CLASS_P trees to references vector if get_base_address returns NULL on them. * gcc.c-torture/compile/20071027-1.c: New test. From-SVN: r129897
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/testsuite/ChangeLog3
-rw-r--r--gcc/testsuite/gcc.c-torture/compile/20071027-1.c25
-rw-r--r--gcc/tree-data-ref.c6
4 files changed, 38 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 42c79ff..0b546de 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2007-11-05 Jakub Jelinek <jakub@redhat.com>
+
+ PR tree-optimization/33856
+ * tree-data-ref.c (get_references_in_stmt): Don't add
+ REFERENCE_CLASS_P trees to references vector if get_base_address
+ returns NULL on them.
+
2007-11-05 Alexandre Oliva <aoliva@redhat.com>
* cfg.c (dump_cfg_bb_info): Update bb_bitnames to match enum.
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 69d30f9..f8f4ed1 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,8 @@
2007-11-05 Jakub Jelinek <jakub@redhat.com>
+ PR tree-optimization/33856
+ * gcc.c-torture/compile/20071027-1.c: New test.
+
PR c++/33836
* g++.dg/ext/label10.C: New test.
diff --git a/gcc/testsuite/gcc.c-torture/compile/20071027-1.c b/gcc/testsuite/gcc.c-torture/compile/20071027-1.c
new file mode 100644
index 0000000..c550406
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/compile/20071027-1.c
@@ -0,0 +1,25 @@
+/* PR tree-optimization/33856 */
+/* Testcase by Martin Michlmayr <tbm@cyrius.com> */
+
+typedef struct z_key
+{
+ int key;
+ int mask;
+} z_key;
+typedef struct picture_size
+{
+ z_key key;
+} picture_size;
+
+void picture_size_new (picture_size *ps)
+{
+ z_key key;
+ ps->key = key;
+}
+
+void picture_sizes_load_default (picture_size *ps)
+{
+ int i;
+ for (i = 0; i < 5; ++i)
+ picture_size_new (ps);
+}
diff --git a/gcc/tree-data-ref.c b/gcc/tree-data-ref.c
index 17851ee..bf7d2ab 100644
--- a/gcc/tree-data-ref.c
+++ b/gcc/tree-data-ref.c
@@ -3913,7 +3913,7 @@ get_references_in_stmt (tree stmt, VEC (data_ref_loc, heap) **references)
op1 = &GIMPLE_STMT_OPERAND (stmt, 1);
if (DECL_P (*op1)
- || REFERENCE_CLASS_P (*op1))
+ || (REFERENCE_CLASS_P (*op1) && get_base_address (*op1)))
{
ref = VEC_safe_push (data_ref_loc, heap, *references, NULL);
ref->pos = op1;
@@ -3921,7 +3921,7 @@ get_references_in_stmt (tree stmt, VEC (data_ref_loc, heap) **references)
}
if (DECL_P (*op0)
- || REFERENCE_CLASS_P (*op0))
+ || (REFERENCE_CLASS_P (*op0) && get_base_address (*op0)))
{
ref = VEC_safe_push (data_ref_loc, heap, *references, NULL);
ref->pos = op0;
@@ -3938,7 +3938,7 @@ get_references_in_stmt (tree stmt, VEC (data_ref_loc, heap) **references)
op0 = &CALL_EXPR_ARG (call, i);
if (DECL_P (*op0)
- || REFERENCE_CLASS_P (*op0))
+ || (REFERENCE_CLASS_P (*op0) && get_base_address (*op0)))
{
ref = VEC_safe_push (data_ref_loc, heap, *references, NULL);
ref->pos = op0;