X-Git-Url: http://git.sourceforge.jp/view?p=pf3gnuchains%2Fgcc-fork.git;a=blobdiff_plain;f=gcc%2Fconfig%2Farm%2Farm-protos.h;h=99c79231d78e53692fb5f2f8dfb51d9560c3b9d1;hp=ce3ff6aff69d3764f73bac0e137ae146e248e7a7;hb=afe27f3bd875ba812e294cc77b01777b654a03f4;hpb=b981d932962c8e9f6744359ef47d255a2c6b3be8 diff --git a/gcc/config/arm/arm-protos.h b/gcc/config/arm/arm-protos.h index ce3ff6aff69..99c79231d78 100644 --- a/gcc/config/arm/arm-protos.h +++ b/gcc/config/arm/arm-protos.h @@ -1,5 +1,5 @@ /* Prototypes for exported functions defined in arm.c and pe.c - Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004 + Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc. Contributed by Richard Earnshaw (rearnsha@arm.com) Minor hacks by Nick Clifton (nickc@cygnus.com) @@ -27,15 +27,15 @@ extern void arm_override_options (void); extern int use_return_insn (int, rtx); extern int arm_regno_class (int); -extern void arm_finalize_pic (int); +extern void arm_load_pic_register (unsigned int); extern int arm_volatile_func (void); extern const char *arm_output_epilogue (rtx); extern void arm_expand_prologue (void); extern const char *arm_strip_name_encoding (const char *); extern void arm_asm_output_labelref (FILE *, const char *); extern unsigned long arm_current_func_type (void); -extern unsigned int arm_compute_initial_elimination_offset (unsigned int, - unsigned int); +extern HOST_WIDE_INT arm_compute_initial_elimination_offset (unsigned int, + unsigned int); extern HOST_WIDE_INT thumb_compute_initial_elimination_offset (unsigned int, unsigned int); @@ -44,6 +44,7 @@ extern int arm_return_in_memory (tree); extern void arm_encode_call_attribute (tree, int); #endif #ifdef RTX_CODE +extern bool arm_vector_mode_supported_p (enum machine_mode); extern int arm_hard_regno_mode_ok (unsigned int, enum machine_mode); extern int const_ok_for_arm (HOST_WIDE_INT); extern int arm_split_constant (RTX_CODE, enum machine_mode, rtx, @@ -60,49 +61,8 @@ extern int arm_const_double_rtx (rtx); extern int neg_const_double_rtx_ok_for_fpa (rtx); extern enum reg_class vfp_secondary_reload_class (enum machine_mode, rtx); -/* Predicates. */ -extern int s_register_operand (rtx, enum machine_mode); -extern int arm_hard_register_operand (rtx, enum machine_mode); -extern int arm_general_register_operand (rtx, enum machine_mode); -extern int f_register_operand (rtx, enum machine_mode); -extern int reg_or_int_operand (rtx, enum machine_mode); -extern int arm_reload_memory_operand (rtx, enum machine_mode); -extern int arm_rhs_operand (rtx, enum machine_mode); -extern int arm_rhsm_operand (rtx, enum machine_mode); -extern int arm_add_operand (rtx, enum machine_mode); -extern int arm_addimm_operand (rtx, enum machine_mode); -extern int arm_not_operand (rtx, enum machine_mode); -extern int arm_extendqisi_mem_op (rtx, enum machine_mode); -extern int offsettable_memory_operand (rtx, enum machine_mode); -extern int alignable_memory_operand (rtx, enum machine_mode); -extern int arm_float_rhs_operand (rtx, enum machine_mode); -extern int arm_float_add_operand (rtx, enum machine_mode); -extern int power_of_two_operand (rtx, enum machine_mode); -extern int nonimmediate_di_operand (rtx, enum machine_mode); -extern int di_operand (rtx, enum machine_mode); -extern int nonimmediate_soft_df_operand (rtx, enum machine_mode); -extern int soft_df_operand (rtx, enum machine_mode); -extern int index_operand (rtx, enum machine_mode); -extern int const_shift_operand (rtx, enum machine_mode); -extern int arm_comparison_operator (rtx, enum machine_mode); -extern int shiftable_operator (rtx, enum machine_mode); -extern int shift_operator (rtx, enum machine_mode); -extern int equality_operator (rtx, enum machine_mode); -extern int minmax_operator (rtx, enum machine_mode); -extern int cc_register (rtx, enum machine_mode); -extern int dominant_cc_register (rtx, enum machine_mode); -extern int logical_binary_operator (rtx, enum machine_mode); -extern int multi_register_push (rtx, enum machine_mode); -extern int load_multiple_operation (rtx, enum machine_mode); -extern int store_multiple_operation (rtx, enum machine_mode); -extern int cirrus_fp_register (rtx, enum machine_mode); -extern int cirrus_general_operand (rtx, enum machine_mode); -extern int cirrus_register_operand (rtx, enum machine_mode); -extern int cirrus_shift_const (rtx, enum machine_mode); extern int cirrus_memory_offset (rtx); extern int arm_coproc_mem_operand (rtx, bool); -extern int vfp_compare_operand (rtx, enum machine_mode); -extern int arm_float_compare_operand (rtx, enum machine_mode); extern int arm_no_early_store_addr_dep (rtx, rtx); extern int arm_no_early_alu_shift_dep (rtx, rtx); extern int arm_no_early_alu_shift_value_dep (rtx, rtx); @@ -116,8 +76,10 @@ extern int load_multiple_sequence (rtx *, int, int *, int *, HOST_WIDE_INT *); extern const char *emit_ldm_seq (rtx *, int); extern int store_multiple_sequence (rtx *, int, int *, int *, HOST_WIDE_INT *); extern const char * emit_stm_seq (rtx *, int); -extern rtx arm_gen_load_multiple (int, int, rtx, int, int, int, int, int); -extern rtx arm_gen_store_multiple (int, int, rtx, int, int, int, int, int); +extern rtx arm_gen_load_multiple (int, int, rtx, int, int, + rtx, HOST_WIDE_INT *); +extern rtx arm_gen_store_multiple (int, int, rtx, int, int, + rtx, HOST_WIDE_INT *); extern int arm_gen_movmemqi (rtx *); extern rtx arm_gen_rotated_half_load (rtx); extern enum machine_mode arm_select_cc_mode (RTX_CODE, rtx, rtx); @@ -127,6 +89,7 @@ extern rtx arm_gen_compare_reg (RTX_CODE, rtx, rtx); extern rtx arm_gen_return_addr_mask (void); extern void arm_reload_in_hi (rtx *); extern void arm_reload_out_hi (rtx *); +extern int arm_const_double_inline_cost (rtx); extern const char *fp_immediate_constant (rtx); extern const char *output_call (rtx *); extern const char *output_call_mem (rtx *); @@ -151,16 +114,16 @@ extern int arm_is_longcall_p (rtx, int, int); extern int arm_emit_vector_const (FILE *, rtx); extern const char * arm_output_load_gr (rtx *); extern const char *vfp_output_fstmx (rtx *); +extern void arm_set_return_address (rtx, rtx); #if defined TREE_CODE extern rtx arm_function_arg (CUMULATIVE_ARGS *, enum machine_mode, tree, int); extern void arm_init_cumulative_args (CUMULATIVE_ARGS *, tree, rtx, tree); -extern rtx arm_va_arg (tree, tree); extern bool arm_needs_doubleword_align (enum machine_mode, tree); extern rtx arm_function_value(tree, tree); #endif -#if defined AOF_ASSEMBLER +#if defined AOF_ASSEMBLER extern rtx aof_pic_entry (rtx); extern char *aof_text_section (void); extern char *aof_data_section (void); @@ -187,14 +150,14 @@ extern int thumb_shiftable_const (unsigned HOST_WIDE_INT); extern void thumb_final_prescan_insn (rtx); extern const char *thumb_load_double_from_address (rtx *); extern const char *thumb_output_move_mem_multiple (int, rtx *); +extern const char *thumb_call_via_reg (rtx); extern void thumb_expand_movmemqi (rtx *); -extern int thumb_cmp_operand (rtx, enum machine_mode); -extern int thumb_cbrch_target_operand (rtx, enum machine_mode); extern rtx *thumb_legitimize_pic_address (rtx, enum machine_mode, rtx); extern int thumb_go_if_legitimate_address (enum machine_mode, rtx); extern rtx arm_return_addr (int, rtx); extern void thumb_reload_out_hi (rtx *); extern void thumb_reload_in_hi (rtx *); +extern void thumb_set_return_address (rtx, rtx); #endif /* Defined in pe.c. */