diff options
author | zack <zack@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-12-16 18:23:00 +0000 |
---|---|---|
committer | zack <zack@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-12-16 18:23:00 +0000 |
commit | 805e22b2051e9c6a75377ea6599654d7415da483 (patch) | |
tree | c259697c448b0c6f548f153c48c46a8d7a75970f /gcc/langhooks.c | |
parent | 2c27ce73ee2229b0871c4ccad2342d8a4be85eff (diff) | |
download | gcc-805e22b2051e9c6a75377ea6599654d7415da483.tar.gz |
Merge basic-improvements-branch to trunk
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@60174 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/langhooks.c')
-rw-r--r-- | gcc/langhooks.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/gcc/langhooks.c b/gcc/langhooks.c index ccbb53485aa..912d5db7455 100644 --- a/gcc/langhooks.c +++ b/gcc/langhooks.c @@ -21,6 +21,8 @@ Boston, MA 02111-1307, USA. */ #include "config.h" #include "system.h" +#include "coretypes.h" +#include "tm.h" #include "toplev.h" #include "tree.h" #include "c-tree.h" @@ -354,13 +356,17 @@ lhd_tree_inlining_auto_var_in_fn_p (var, fn) tree lhd_tree_inlining_copy_res_decl_for_inlining (res, fn, caller, - dm, ndp, texps) + dm, ndp, return_slot_addr) tree res, fn, caller; void *dm ATTRIBUTE_UNUSED; int *ndp ATTRIBUTE_UNUSED; - void *texps ATTRIBUTE_UNUSED; + tree return_slot_addr ATTRIBUTE_UNUSED; { - return copy_decl_for_inlining (res, fn, caller); + if (return_slot_addr) + return build1 (INDIRECT_REF, TREE_TYPE (TREE_TYPE (return_slot_addr)), + return_slot_addr); + else + return copy_decl_for_inlining (res, fn, caller); } /* lang_hooks.tree_inlining.anon_aggr_type_p determines whether T is a |