Commit 4dc07bd7 by Jakub Jelinek Committed by Richard Henderson

explow.c (hard_function_value): Add outgoing argument.

        * explow.c (hard_function_value): Add outgoing argument.
        * expr.h (hard_function_value): Declare it.
        * calls.c (expand_call, emit_library_call_value): Update callers.
        * function.c (aggregate_value_p): Ditto.
        (diddle_return_value): Must look at the outgoing registers
        on archs with register windows.

From-SVN: r30550
parent 95a7b554
1999-11-16 Jakub Jelinek <jakub@redhat.com>
* explow.c (hard_function_value): Add outgoing argument.
* expr.h (hard_function_value): Declare it.
* calls.c (expand_call, emit_library_call_value): Update callers.
* function.c (aggregate_value_p): Ditto.
(diddle_return_value): Must look at the outgoing registers
on archs with register windows.
Mon Nov 15 20:46:45 1999 Richard Henderson <rth@cygnus.com> Mon Nov 15 20:46:45 1999 Richard Henderson <rth@cygnus.com>
* alpha.c (alpha_build_va_list): Use make_lang_type and * alpha.c (alpha_build_va_list): Use make_lang_type and
...@@ -35,7 +44,7 @@ Mon Nov 15 15:33:18 1999 Richard Henderson <rth@cygnus.com> ...@@ -35,7 +44,7 @@ Mon Nov 15 15:33:18 1999 Richard Henderson <rth@cygnus.com>
Based on proposed addition from David Edelsohn. Based on proposed addition from David Edelsohn.
1999-11-15 Robert Lipe <RobertLipe@usa.net> 1999-11-15 Robert Lipe <RobertLipe@usa.net>
Bruce Korb <autogen@linuxbox.com> Bruce Korb <autogen@linuxbox.com>
* fixinc/inclhack.def * fixinc/inclhack.def
(AAB_svr4_replace_byteorder): added. Takes advantage of GCC features (AAB_svr4_replace_byteorder): added. Takes advantage of GCC features
...@@ -150,7 +159,7 @@ Fri Nov 12 08:54:22 1999 Mark Mitchell <mark@codesourcery.com> ...@@ -150,7 +159,7 @@ Fri Nov 12 08:54:22 1999 Mark Mitchell <mark@codesourcery.com>
Fri Nov 12 08:04:45 1999 Catherine Moore <clm@cygnus.com> Fri Nov 12 08:04:45 1999 Catherine Moore <clm@cygnus.com>
* defaults.h (ASM_OUTPUT_ALTERNATE_LABEL_NAME): Use * defaults.h (ASM_OUTPUT_ALTERNATE_LABEL_NAME): Use
ASM_OUTPUT_LABEL. ASM_OUTPUT_LABEL.
Fri Nov 12 13:31:54 1999 Bernd Schmidt <bernds@cygnus.co.uk> Fri Nov 12 13:31:54 1999 Bernd Schmidt <bernds@cygnus.co.uk>
...@@ -222,15 +231,15 @@ Wed Nov 10 15:56:16 1999 Jeffrey A Law (law@cygnus.com) ...@@ -222,15 +231,15 @@ Wed Nov 10 15:56:16 1999 Jeffrey A Law (law@cygnus.com)
worklists. Fix boundary cases. Compute maximal solutions. worklists. Fix boundary cases. Compute maximal solutions.
(compute_laterin, compute_nearerout): Similarly. (compute_laterin, compute_nearerout): Similarly.
* dwarf2out.c (add_AT_location_description): Allow * dwarf2out.c (add_AT_location_description): Allow
(mem (plus (pseudo) (...)) too. (mem (plus (pseudo) (...)) too.
Wed Nov 10 10:52:42 1999 Tom Tromey <tromey@cygnus.com> Wed Nov 10 10:52:42 1999 Tom Tromey <tromey@cygnus.com>
* gcc.c (do_spec_1): Support text between `%u' and `%O'. * gcc.c (do_spec_1): Support text between `%u' and `%O'.
Wed Nov 10 12:43:21 1999 Philippe De Muyter <phdm@macqel.be> Wed Nov 10 12:43:21 1999 Philippe De Muyter <phdm@macqel.be>
Kaveh R. Ghazi <ghazi@caip.rutgers.edu> Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
* cppinit.c: Test `GCC_VERSION', not `HAVE_GCC_VERSION'. * cppinit.c: Test `GCC_VERSION', not `HAVE_GCC_VERSION'.
...@@ -279,9 +288,9 @@ Wed Nov 10 04:58:09 1999 Alexandre Oliva <oliva@lsd.ic.unicamp.br> ...@@ -279,9 +288,9 @@ Wed Nov 10 04:58:09 1999 Alexandre Oliva <oliva@lsd.ic.unicamp.br>
Wed Nov 10 00:02:53 1999 Jeffrey A Law (law@cygnus.com) Wed Nov 10 00:02:53 1999 Jeffrey A Law (law@cygnus.com)
* flow.c (compute_flow_dominators): No longer treat basic block 0 * flow.c (compute_flow_dominators): No longer treat basic block 0
or (n_basic_blocks - 1) specially. Clear the AUX field before or (n_basic_blocks - 1) specially. Clear the AUX field before
starting computation of doms/pdoms. Fix initial state for pdoms. starting computation of doms/pdoms. Fix initial state for pdoms.
Wed Nov 10 03:58:08 1999 Alexandre Oliva <oliva@lsd.ic.unicamp.br> Wed Nov 10 03:58:08 1999 Alexandre Oliva <oliva@lsd.ic.unicamp.br>
...@@ -445,8 +454,8 @@ Sun Nov 7 20:55:14 1999 Mark Mitchell <mark@codesourcery.com> ...@@ -445,8 +454,8 @@ Sun Nov 7 20:55:14 1999 Mark Mitchell <mark@codesourcery.com>
Sun Nov 7 19:41:17 1999 Catherine Moore <clm@cygnus.com> Sun Nov 7 19:41:17 1999 Catherine Moore <clm@cygnus.com>
* config/elfos.h (ASM_DECLARE_FUNCTION_NAME): Conditionally define. * config/elfos.h (ASM_DECLARE_FUNCTION_NAME): Conditionally define.
(ASM_DECLARE_FUNCTION_SIZE): Conditionally define. (ASM_DECLARE_FUNCTION_SIZE): Conditionally define.
Sun Nov 7 10:23:28 1999 Mark P. Mitchell <mark@codesourcery.com> Sun Nov 7 10:23:28 1999 Mark P. Mitchell <mark@codesourcery.com>
...@@ -512,9 +521,9 @@ Sat Nov 6 09:52:09 1999 Richard Henderson <rth@cygnus.com> ...@@ -512,9 +521,9 @@ Sat Nov 6 09:52:09 1999 Richard Henderson <rth@cygnus.com>
Sat Nov 6 07:48:59 1999 Catherine Moore <clm@cygnus.com> Sat Nov 6 07:48:59 1999 Catherine Moore <clm@cygnus.com>
* config/svr4.h (ASM_DECLARE_FUNCTION): Check if already * config/svr4.h (ASM_DECLARE_FUNCTION): Check if already
defined. defined.
(ASM_DECLARE_FUNCTION_SIZE): Likewise. (ASM_DECLARE_FUNCTION_SIZE): Likewise.
Fri Nov 5 18:33:39 1999 J"orn Rennecke <amylaar@cygnus.co.uk> Fri Nov 5 18:33:39 1999 J"orn Rennecke <amylaar@cygnus.co.uk>
......
...@@ -2211,9 +2211,9 @@ expand_call (exp, target, ignore) ...@@ -2211,9 +2211,9 @@ expand_call (exp, target, ignore)
{ {
if (pcc_struct_value) if (pcc_struct_value)
valreg = hard_function_value (build_pointer_type (TREE_TYPE (exp)), valreg = hard_function_value (build_pointer_type (TREE_TYPE (exp)),
fndecl); fndecl, 0);
else else
valreg = hard_function_value (TREE_TYPE (exp), fndecl); valreg = hard_function_value (TREE_TYPE (exp), fndecl, 0);
} }
/* Precompute all register parameters. It isn't safe to compute anything /* Precompute all register parameters. It isn't safe to compute anything
...@@ -3138,7 +3138,7 @@ emit_library_call_value VPROTO((rtx orgfun, rtx value, int no_queue, ...@@ -3138,7 +3138,7 @@ emit_library_call_value VPROTO((rtx orgfun, rtx value, int no_queue,
#ifdef PCC_STATIC_STRUCT_RETURN #ifdef PCC_STATIC_STRUCT_RETURN
rtx pointer_reg rtx pointer_reg
= hard_function_value (build_pointer_type (type_for_mode (outmode, 0)), = hard_function_value (build_pointer_type (type_for_mode (outmode, 0)),
0); 0, 0);
mem_value = gen_rtx_MEM (outmode, pointer_reg); mem_value = gen_rtx_MEM (outmode, pointer_reg);
pcc_struct_value = 1; pcc_struct_value = 1;
if (value == 0) if (value == 0)
......
...@@ -1541,14 +1541,24 @@ probe_stack_range (first, size) ...@@ -1541,14 +1541,24 @@ probe_stack_range (first, size)
in which a scalar value of data type VALTYPE in which a scalar value of data type VALTYPE
was returned by a function call to function FUNC. was returned by a function call to function FUNC.
FUNC is a FUNCTION_DECL node if the precise function is known, FUNC is a FUNCTION_DECL node if the precise function is known,
otherwise 0. */ otherwise 0.
OUTGOING is 1 if on a machine with register windows this function
should return the register in which the function will put its result
and 0 otherwise. */
rtx rtx
hard_function_value (valtype, func) hard_function_value (valtype, func, outgoing)
tree valtype; tree valtype;
tree func ATTRIBUTE_UNUSED; tree func ATTRIBUTE_UNUSED;
int outgoing ATTRIBUTE_UNUSED;
{ {
rtx val = FUNCTION_VALUE (valtype, func); rtx val;
#ifdef FUNCTION_OUTGOING_VALUE
if (outgoing)
val = FUNCTION_OUTGOING_VALUE (valtype, func);
else
#endif
val = FUNCTION_VALUE (valtype, func);
if (GET_CODE (val) == REG if (GET_CODE (val) == REG
&& GET_MODE (val) == BLKmode) && GET_MODE (val) == BLKmode)
{ {
......
...@@ -1067,7 +1067,7 @@ extern rtx trampoline_address PROTO((tree)); ...@@ -1067,7 +1067,7 @@ extern rtx trampoline_address PROTO((tree));
/* Return an rtx that refers to the value returned by a function /* Return an rtx that refers to the value returned by a function
in its original home. This becomes invalid if any more code is emitted. */ in its original home. This becomes invalid if any more code is emitted. */
extern rtx hard_function_value PROTO((tree, tree)); extern rtx hard_function_value PROTO((tree, tree, int));
extern rtx prepare_call_address PROTO((rtx, tree, rtx *, int)); extern rtx prepare_call_address PROTO((rtx, tree, rtx *, int));
......
...@@ -3992,7 +3992,7 @@ aggregate_value_p (exp) ...@@ -3992,7 +3992,7 @@ aggregate_value_p (exp)
return 1; return 1;
/* Make sure we have suitable call-clobbered regs to return /* Make sure we have suitable call-clobbered regs to return
the value in; if not, we must return it in memory. */ the value in; if not, we must return it in memory. */
reg = hard_function_value (type, 0); reg = hard_function_value (type, 0, 0);
/* If we have something other than a REG (e.g. a PARALLEL), then assume /* If we have something other than a REG (e.g. a PARALLEL), then assume
it is OK. */ it is OK. */
...@@ -6211,7 +6211,7 @@ diddle_return_value (code) ...@@ -6211,7 +6211,7 @@ diddle_return_value (code)
/* Use hard_function_value to avoid creating a reference to a BLKmode /* Use hard_function_value to avoid creating a reference to a BLKmode
register in the USE/CLOBBER insn. */ register in the USE/CLOBBER insn. */
return_reg = hard_function_value (TREE_TYPE (decl_result), return_reg = hard_function_value (TREE_TYPE (decl_result),
current_function_decl); current_function_decl, 1);
REG_FUNCTION_VALUE_P (return_reg) = 1; REG_FUNCTION_VALUE_P (return_reg) = 1;
emit_insn (gen_rtx_fmt_e (code, VOIDmode, return_reg)); emit_insn (gen_rtx_fmt_e (code, VOIDmode, return_reg));
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment