diff options
author | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-01-27 15:09:23 +0000 |
---|---|---|
committer | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-01-27 15:09:23 +0000 |
commit | efcca74af93b05fe0ab84263de63c8e66b6a86e3 (patch) | |
tree | a360ac6bb7bb20f7bf2e6d6f8310b464cb87507a /gcc | |
parent | e92d3ba85f9ce77e62348d3b6592fbc7b05e72d2 (diff) | |
download | gcc-efcca74af93b05fe0ab84263de63c8e66b6a86e3.tar.gz |
PR middle-end/42874
* tree-inline.c (cannot_copy_type_1): Removed.
(copy_forbidden): Don't forbid copying of functions containing
records/unions with variable length fields.
* gcc.dg/vla-22.c: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@156287 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/vla-22.c | 22 | ||||
-rw-r--r-- | gcc/tree-inline.c | 43 |
4 files changed, 34 insertions, 43 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 0edb3c88cbe..10a9bc9debf 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2010-01-27 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/42874 + * tree-inline.c (cannot_copy_type_1): Removed. + (copy_forbidden): Don't forbid copying of functions containing + records/unions with variable length fields. + 2010-01-27 Christian Bruel <christian.bruel@st.com> Revert: diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 492cba88f12..fd63e1b5f3c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-01-27 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/42874 + * gcc.dg/vla-22.c: New test. + 2010-01-26 Jakub Jelinek <jakub@redhat.com> * ada/acats/run_all.sh: Make sure norun.lst is sorted using the diff --git a/gcc/testsuite/gcc.dg/vla-22.c b/gcc/testsuite/gcc.dg/vla-22.c new file mode 100644 index 00000000000..f924650af03 --- /dev/null +++ b/gcc/testsuite/gcc.dg/vla-22.c @@ -0,0 +1,22 @@ +/* { dg-do compile } */ +/* { dg-options "-O2" } */ + +extern void bar (int *); + +static inline __attribute__((always_inline)) +int +foo (int i) +{ + struct S { + int ar[1][i]; + } s; + + s.ar[0][0] = 0; + bar (&s.ar[0][0]); +} + +void +baz (int i) +{ + foo (i + 2); +} diff --git a/gcc/tree-inline.c b/gcc/tree-inline.c index e08842ca829..815d88af066 100644 --- a/gcc/tree-inline.c +++ b/gcc/tree-inline.c @@ -2730,39 +2730,6 @@ has_label_address_in_static_1 (tree *nodep, int *walk_subtrees, void *fnp) return NULL_TREE; } -/* Callback through walk_tree. Determine if we've got an aggregate - type that we can't support; return non-null if so. */ - -static tree -cannot_copy_type_1 (tree *nodep, int *walk_subtrees ATTRIBUTE_UNUSED, - void *data ATTRIBUTE_UNUSED) -{ - tree t, node = *nodep; - - if (TREE_CODE (node) == RECORD_TYPE || TREE_CODE (node) == UNION_TYPE) - { - /* We cannot inline a function of the form - - void F (int i) { struct S { int ar[i]; } s; } - - Attempting to do so produces a catch-22. - If walk_tree examines the TYPE_FIELDS chain of RECORD_TYPE/ - UNION_TYPE nodes, then it goes into infinite recursion on a - structure containing a pointer to its own type. If it doesn't, - then the type node for S doesn't get adjusted properly when - F is inlined. - - ??? This is likely no longer true, but it's too late in the 4.0 - cycle to try to find out. This should be checked for 4.1. */ - for (t = TYPE_FIELDS (node); t; t = TREE_CHAIN (t)) - if (variably_modified_type_p (TREE_TYPE (t), NULL)) - return node; - } - - return NULL_TREE; -} - - /* Determine if the function can be copied. If so return NULL. If not return a string describng the reason for failure. */ @@ -2805,16 +2772,6 @@ copy_forbidden (struct function *fun, tree fndecl) "address of local label in a static variable"); goto fail; } - - if (!TREE_STATIC (decl) && !DECL_EXTERNAL (decl) - && variably_modified_type_p (TREE_TYPE (decl), NULL) - && walk_tree_without_duplicates (&TREE_TYPE (decl), - cannot_copy_type_1, NULL)) - { - reason = G_("function %q+F can never be copied " - "because it uses variable sized variables"); - goto fail; - } } fail: |