diff options
| -rw-r--r-- | gcc/ChangeLog | 7 | ||||
| -rw-r--r-- | gcc/tree-inline.c | 7 |
2 files changed, 11 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index b6bd762..095c6d6 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2006-02-11 Jason Merrill <jason@redhat.com> + + PR tree-opt/24365 + * tree-inline.c (declare_return_variable): Just don't use the + modify target if it's a gimple complex reg and the return slot + isn't. + 2006-02-11 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> * doc/contrib.texi: Update my entry. diff --git a/gcc/tree-inline.c b/gcc/tree-inline.c index 81682c8..8d258ff 100644 --- a/gcc/tree-inline.c +++ b/gcc/tree-inline.c @@ -1222,9 +1222,10 @@ declare_return_variable (copy_body_data *id, tree return_slot_addr, use_it = false; else if (is_global_var (base_m)) use_it = false; - else if (TREE_CODE (TREE_TYPE (base_m)) == COMPLEX_TYPE - && !DECL_COMPLEX_GIMPLE_REG_P (result)) - DECL_COMPLEX_GIMPLE_REG_P (base_m) = 0; + else if (TREE_CODE (TREE_TYPE (result)) == COMPLEX_TYPE + && !DECL_COMPLEX_GIMPLE_REG_P (result) + && DECL_COMPLEX_GIMPLE_REG_P (base_m)) + use_it = false; else if (!TREE_ADDRESSABLE (base_m)) use_it = true; } |
