Commit 0196fbb3 by Richard Henderson Committed by Richard Henderson

fr30-protos.h (fr30_va_arg): Remove.

        * config/fr30/fr30-protos.h (fr30_va_arg): Remove.
        * config/fr30/fr30.c (TARGET_GIMPLIFY_VA_ARG_EXPR): New.
        (fr30_gimplify_va_arg_expr): New.
        (fr30_pass_by_reference, fr30_pass_by_value, fr30_va_arg): Remove.
        * config/fr30/fr30.h (EXPAND_BUILTIN_VA_ARG): Remove.

From-SVN: r84322
parent 062fff1b
2004-07-08 Richard Henderson <rth@redhat.com>
* config/fr30/fr30-protos.h (fr30_va_arg): Remove.
* config/fr30/fr30.c (TARGET_GIMPLIFY_VA_ARG_EXPR): New.
(fr30_gimplify_va_arg_expr): New.
(fr30_pass_by_reference, fr30_pass_by_value, fr30_va_arg): Remove.
* config/fr30/fr30.h (EXPAND_BUILTIN_VA_ARG): Remove.
2004-07-08 Vladimir Makarov <vmakarov@redhat.com> 2004-07-08 Vladimir Makarov <vmakarov@redhat.com>
PR target/16414 PR target/16414
......
...@@ -28,7 +28,6 @@ extern void fr30_print_operand (FILE *, rtx, int); ...@@ -28,7 +28,6 @@ extern void fr30_print_operand (FILE *, rtx, int);
extern void fr30_print_operand_address (FILE *, rtx); extern void fr30_print_operand_address (FILE *, rtx);
extern rtx fr30_move_double (rtx *); extern rtx fr30_move_double (rtx *);
#ifdef TREE_CODE #ifdef TREE_CODE
extern rtx fr30_va_arg (tree, tree);
extern int fr30_num_arg_regs (enum machine_mode, tree); extern int fr30_num_arg_regs (enum machine_mode, tree);
extern int fr30_function_arg_partial_nregs (CUMULATIVE_ARGS, extern int fr30_function_arg_partial_nregs (CUMULATIVE_ARGS,
enum machine_mode, tree, int); enum machine_mode, tree, int);
......
...@@ -123,8 +123,7 @@ static struct fr30_frame_info zero_frame_info; ...@@ -123,8 +123,7 @@ static struct fr30_frame_info zero_frame_info;
static void fr30_setup_incoming_varargs (CUMULATIVE_ARGS *, enum machine_mode, static void fr30_setup_incoming_varargs (CUMULATIVE_ARGS *, enum machine_mode,
tree, int *, int); tree, int *, int);
static rtx fr30_pass_by_reference (tree, tree); static tree fr30_gimplify_va_arg_expr (tree, tree, tree *, tree *);
static rtx fr30_pass_by_value (tree, tree);
#define FRAME_POINTER_MASK (1 << (FRAME_POINTER_REGNUM)) #define FRAME_POINTER_MASK (1 << (FRAME_POINTER_REGNUM))
#define RETURN_POINTER_MASK (1 << (RETURN_POINTER_REGNUM)) #define RETURN_POINTER_MASK (1 << (RETURN_POINTER_REGNUM))
...@@ -156,6 +155,8 @@ static rtx fr30_pass_by_value (tree, tree); ...@@ -156,6 +155,8 @@ static rtx fr30_pass_by_value (tree, tree);
#undef TARGET_SETUP_INCOMING_VARARGS #undef TARGET_SETUP_INCOMING_VARARGS
#define TARGET_SETUP_INCOMING_VARARGS fr30_setup_incoming_varargs #define TARGET_SETUP_INCOMING_VARARGS fr30_setup_incoming_varargs
#undef TARGET_GIMPLIFY_VA_ARG_EXPR
#define TARGET_GIMPLIFY_VA_ARG_EXPR fr30_gimplify_va_arg_expr
struct gcc_target targetm = TARGET_INITIALIZER; struct gcc_target targetm = TARGET_INITIALIZER;
...@@ -712,74 +713,15 @@ fr30_function_arg_partial_nregs (CUMULATIVE_ARGS cum, enum machine_mode mode, ...@@ -712,74 +713,15 @@ fr30_function_arg_partial_nregs (CUMULATIVE_ARGS cum, enum machine_mode mode,
return FR30_NUM_ARG_REGS - cum; return FR30_NUM_ARG_REGS - cum;
} }
static rtx
fr30_pass_by_reference (tree valist, tree type)
{
tree type_ptr;
tree type_ptr_ptr;
tree t;
type_ptr = build_pointer_type (type);
type_ptr_ptr = build_pointer_type (type_ptr);
t = build (POSTINCREMENT_EXPR, va_list_type_node, valist, build_int_2 (UNITS_PER_WORD, 0));
TREE_SIDE_EFFECTS (t) = 1;
t = build1 (NOP_EXPR, type_ptr_ptr, t);
TREE_SIDE_EFFECTS (t) = 1;
t = build1 (INDIRECT_REF, type_ptr, t);
return expand_expr (t, NULL_RTX, Pmode, EXPAND_NORMAL);
}
static rtx
fr30_pass_by_value (tree valist, tree type)
{
HOST_WIDE_INT size = int_size_in_bytes (type);
HOST_WIDE_INT rsize;
rtx addr_rtx;
tree t;
if ((size % UNITS_PER_WORD) == 0)
{
t = build (POSTINCREMENT_EXPR, va_list_type_node, valist, build_int_2 (size, 0));
TREE_SIDE_EFFECTS (t) = 1;
return expand_expr (t, NULL_RTX, Pmode, EXPAND_NORMAL);
}
rsize = (size + UNITS_PER_WORD - 1) & - UNITS_PER_WORD;
/* Care for bigendian correction on the aligned address. */
t = build (PLUS_EXPR, ptr_type_node, valist, build_int_2 (rsize - size, 0));
addr_rtx = expand_expr (t, NULL_RTX, Pmode, EXPAND_NORMAL);
addr_rtx = copy_to_reg (addr_rtx);
/* Increment AP. */
t = build (PLUS_EXPR, va_list_type_node, valist, build_int_2 (rsize, 0));
t = build (MODIFY_EXPR, va_list_type_node, valist, t);
TREE_SIDE_EFFECTS (t) = 1;
expand_expr (t, const0_rtx, VOIDmode, EXPAND_NORMAL);
return addr_rtx;
}
/* Implement `va_arg'. */ /* Implement `va_arg'. */
rtx static tree
fr30_va_arg (tree valist, tree type) fr30_gimplify_va_arg_expr (tree valist, tree type, tree *pre_p, tree *post_p)
{ {
HOST_WIDE_INT size; if (FUNCTION_ARG_PASS_BY_REFERENCE (dummy, TYPE_MODE (type), type, dummy))
return ind_gimplify_va_arg_expr (valist, type, pre_p, post_p);
if (AGGREGATE_TYPE_P (type)) else
return fr30_pass_by_reference (valist, type); return std_gimplify_va_arg_expr (valist, type, pre_p, post_p);
size = int_size_in_bytes (type);
if ((size % sizeof (int)) == 0
|| size < 4)
return fr30_pass_by_value (valist, type);
return fr30_pass_by_reference (valist, type);
} }
/*}}}*/ /*}}}*/
......
...@@ -648,10 +648,6 @@ enum reg_class ...@@ -648,10 +648,6 @@ enum reg_class
takes a fixed number of arguments. */ takes a fixed number of arguments. */
#define RETURN_POPS_ARGS(FUNDECL, FUNTYPE, STACK_SIZE) 0 #define RETURN_POPS_ARGS(FUNDECL, FUNTYPE, STACK_SIZE) 0
/* Implement `va_arg'. */
#define EXPAND_BUILTIN_VA_ARG(valist, type) \
fr30_va_arg (valist, type)
/*}}}*/ /*}}}*/
/*{{{ Function Arguments in Registers. */ /*{{{ Function Arguments in Registers. */
......
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