From: Jakub Jelinek Date: Fri, 9 Mar 2018 19:12:29 +0000 (+0100) Subject: re PR c++/84767 (ICE with pointer to VLA) X-Git-Tag: basepoints/gcc-9~768 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=9d9a9a90ce25d3b2748df78e4ae05e0c74d0b671;p=thirdparty%2Fgcc.git re PR c++/84767 (ICE with pointer to VLA) PR c++/84767 * tree-inline.c (copy_tree_body_r): For INDIRECT_REF of a remapped decl, use remap_type if we want to use the type. * g++.dg/ext/vla18.C: New test. From-SVN: r258395 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 346262eec23f..7d7ece875a4c 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2018-03-09 Jakub Jelinek + + PR c++/84767 + * tree-inline.c (copy_tree_body_r): For INDIRECT_REF of a remapped + decl, use remap_type if we want to use the type. + 2018-03-09 Martin Sebor PR tree-optimization/84526 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index ecd0fb83f371..3b3f44f6605e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2018-03-09 Jakub Jelinek + + PR c++/84767 + * g++.dg/ext/vla18.C: New test. + 2018-03-09 Martin Sebor PR tree-optimization/84526 diff --git a/gcc/testsuite/g++.dg/ext/vla18.C b/gcc/testsuite/g++.dg/ext/vla18.C new file mode 100644 index 000000000000..31a1bb32f1af --- /dev/null +++ b/gcc/testsuite/g++.dg/ext/vla18.C @@ -0,0 +1,19 @@ +// PR c++/84767 +// { dg-do compile } +// { dg-options "" } + +int v[1][10]; + +struct A +{ + A (int); +}; + +A::A (int i) +{ + typedef int T[1][i]; + T *x = (T *) v; + (*x)[0][0] = 0; +} + +A a = 10; diff --git a/gcc/tree-inline.c b/gcc/tree-inline.c index 811829e85299..5a0a2525c0ca 100644 --- a/gcc/tree-inline.c +++ b/gcc/tree-inline.c @@ -1192,6 +1192,7 @@ copy_tree_body_r (tree *tp, int *walk_subtrees, void *data) *tp = gimple_fold_indirect_ref (ptr); if (! *tp) { + type = remap_type (type, id); if (TREE_CODE (ptr) == ADDR_EXPR) { *tp