aboutsummaryrefslogtreecommitdiff
path: root/gcc/reg-stack.c
diff options
context:
space:
mode:
authorRichard Guenther <rguenther@suse.de>2005-07-14 07:39:56 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2005-07-14 07:39:56 +0000
commit1d636cc69fa14e7f7daa4eef6ecb6a6a1413cfda (patch)
treedb222e8988c1c3f0439e84b38f6bc6ae99babae0 /gcc/reg-stack.c
parent94b00ee4e1126901db295a7223b3c6d7c5b1868d (diff)
downloadgcc-1d636cc69fa14e7f7daa4eef6ecb6a6a1413cfda.zip
gcc-1d636cc69fa14e7f7daa4eef6ecb6a6a1413cfda.tar.gz
gcc-1d636cc69fa14e7f7daa4eef6ecb6a6a1413cfda.tar.bz2
Makefile.in (explow.o, [...]): Depend on target.h.
2005-07-14 Richard Guenther <rguenther@suse.de> * Makefile.in (explow.o, reg-stack.o): Depend on target.h. * calls.c (expand_call): Pass fntype to hard_function_value. (emit_library_call_value_1): Likewise. * explow.c: Include target.h. (hard_function_value): Take extra argument, the fntype. Use new target hook for function_value. * expr.h (hard_function_value): Change prototype. * function.c (aggregate_value_p): Pass 0 as fntype to hard_function_value. (assign_parms): Use new target hook for function_value. Pass 0 as fntype to hard_function_value. (expand_function_end): Likewise. * reg-stack.c: Include target.h. (stack_result): Use new target hook for function_value. * target-def.h: New target hook function_value. * target.h: Likewise. * targhooks.c (default_function_value): New function. * targhooks.h (default_function_value): Declare. From-SVN: r102013
Diffstat (limited to 'gcc/reg-stack.c')
-rw-r--r--gcc/reg-stack.c11
1 files changed, 3 insertions, 8 deletions
diff --git a/gcc/reg-stack.c b/gcc/reg-stack.c
index d1d8b98..9f44f51 100644
--- a/gcc/reg-stack.c
+++ b/gcc/reg-stack.c
@@ -172,6 +172,7 @@
#include "ggc.h"
#include "timevar.h"
#include "tree-pass.h"
+#include "target.h"
/* We use this array to cache info about insns, because otherwise we
spend too much time in stack_regs_mentioned_p.
@@ -667,14 +668,8 @@ stack_result (tree decl)
result = DECL_RTL_IF_SET (DECL_RESULT (decl));
if (result != 0)
- {
-#ifdef FUNCTION_OUTGOING_VALUE
- result
- = FUNCTION_OUTGOING_VALUE (TREE_TYPE (DECL_RESULT (decl)), decl);
-#else
- result = FUNCTION_VALUE (TREE_TYPE (DECL_RESULT (decl)), decl);
-#endif
- }
+ result = targetm.calls.function_value (TREE_TYPE (DECL_RESULT (decl)),
+ decl, true);
return result != 0 && STACK_REG_P (result) ? result : 0;
}