1 /* Prototypes for alpha.c functions used in the md file & elsewhere.
2 Copyright (C) 1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
4 This file is part of GNU CC.
6 GNU CC is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2, or (at your option)
11 GNU CC is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with GNU CC; see the file COPYING. If not, write to
18 the Free Software Foundation, 59 Temple Place - Suite 330,
19 Boston, MA 02111-1307, USA. */
21 extern int alpha_next_sequence_number
;
23 extern void literal_section
PARAMS ((void));
24 extern void override_options
PARAMS ((void));
25 extern int zap_mask
PARAMS ((HOST_WIDE_INT
));
26 extern int direct_return
PARAMS ((void));
28 extern int alpha_sa_size
PARAMS ((void));
29 extern HOST_WIDE_INT alpha_initial_elimination_offset
PARAMS ((unsigned int,
31 extern int alpha_pv_save_size
PARAMS ((void));
32 extern int alpha_using_fp
PARAMS ((void));
33 extern void alpha_write_verstamp
PARAMS ((FILE *));
34 extern void alpha_expand_prologue
PARAMS ((void));
35 extern void alpha_expand_epilogue
PARAMS ((void));
36 extern void alpha_output_filename
PARAMS ((FILE *, const char *));
37 extern void alpha_output_lineno
PARAMS ((FILE *, int));
39 extern int reg_or_0_operand
PARAMS ((rtx
, enum machine_mode
));
40 extern int reg_or_6bit_operand
PARAMS ((rtx
, enum machine_mode
));
41 extern int reg_or_8bit_operand
PARAMS ((rtx
, enum machine_mode
));
42 extern int reg_or_const_int_operand
PARAMS ((rtx
, enum machine_mode
));
43 extern int cint8_operand
PARAMS ((rtx
, enum machine_mode
));
44 extern int add_operand
PARAMS ((rtx
, enum machine_mode
));
45 extern int sext_add_operand
PARAMS ((rtx
, enum machine_mode
));
46 extern int const48_operand
PARAMS ((rtx
, enum machine_mode
));
47 extern int and_operand
PARAMS ((rtx
, enum machine_mode
));
48 extern int or_operand
PARAMS ((rtx
, enum machine_mode
));
49 extern int mode_width_operand
PARAMS ((rtx
, enum machine_mode
));
50 extern int mode_mask_operand
PARAMS ((rtx
, enum machine_mode
));
51 extern int mul8_operand
PARAMS ((rtx
, enum machine_mode
));
52 extern int const0_operand
PARAMS ((rtx
, enum machine_mode
));
53 extern int hard_fp_register_operand
PARAMS ((rtx
, enum machine_mode
));
54 extern int hard_int_register_operand
PARAMS ((rtx
, enum machine_mode
));
55 extern int reg_or_cint_operand
PARAMS ((rtx
, enum machine_mode
));
56 extern int some_operand
PARAMS ((rtx
, enum machine_mode
));
57 extern int some_ni_operand
PARAMS ((rtx
, enum machine_mode
));
58 extern int input_operand
PARAMS ((rtx
, enum machine_mode
));
59 extern int samegp_function_operand
PARAMS ((rtx
, enum machine_mode
));
60 extern int direct_call_operand
PARAMS ((rtx
, enum machine_mode
));
61 extern int local_symbolic_operand
PARAMS ((rtx
, enum machine_mode
));
62 extern int small_symbolic_operand
PARAMS ((rtx
, enum machine_mode
));
63 extern int some_small_symbolic_operand
PARAMS ((rtx
, enum machine_mode
));
64 extern int global_symbolic_operand
PARAMS ((rtx
, enum machine_mode
));
65 extern int dtp16_symbolic_operand
PARAMS ((rtx
, enum machine_mode
));
66 extern int dtp32_symbolic_operand
PARAMS ((rtx
, enum machine_mode
));
67 extern int gotdtp_symbolic_operand
PARAMS ((rtx
, enum machine_mode
));
68 extern int tp16_symbolic_operand
PARAMS ((rtx
, enum machine_mode
));
69 extern int tp32_symbolic_operand
PARAMS ((rtx
, enum machine_mode
));
70 extern int gottp_symbolic_operand
PARAMS ((rtx
, enum machine_mode
));
71 extern int call_operand
PARAMS ((rtx
, enum machine_mode
));
72 extern int symbolic_operand
PARAMS ((rtx
, enum machine_mode
));
73 extern int alpha_comparison_operator
PARAMS ((rtx
, enum machine_mode
));
74 extern int alpha_zero_comparison_operator
PARAMS ((rtx
, enum machine_mode
));
75 extern int alpha_swapped_comparison_operator
PARAMS ((rtx
, enum machine_mode
));
76 extern int signed_comparison_operator
PARAMS ((rtx
, enum machine_mode
));
77 extern int alpha_fp_comparison_operator
PARAMS ((rtx
, enum machine_mode
));
78 extern int divmod_operator
PARAMS ((rtx
, enum machine_mode
));
79 extern int aligned_memory_operand
PARAMS ((rtx
, enum machine_mode
));
80 extern int unaligned_memory_operand
PARAMS ((rtx
, enum machine_mode
));
81 extern int reg_or_unaligned_mem_operand
PARAMS ((rtx
, enum machine_mode
));
82 extern int any_memory_operand
PARAMS ((rtx
, enum machine_mode
));
83 extern int reg_not_elim_operand
PARAMS ((rtx
, enum machine_mode
));
84 extern int normal_memory_operand
PARAMS ((rtx
, enum machine_mode
));
85 extern int reg_no_subreg_operand
PARAMS ((rtx
, enum machine_mode
));
86 extern int addition_operation
PARAMS ((rtx
, enum machine_mode
));
88 extern bool alpha_const_ok_for_letter_p
PARAMS ((HOST_WIDE_INT
, int));
89 extern bool alpha_const_double_ok_for_letter_p
PARAMS ((rtx
, int));
90 extern bool alpha_extra_constraint
PARAMS ((rtx
, int));
92 extern rtx alpha_tablejump_addr_vec
PARAMS ((rtx
));
93 extern rtx alpha_tablejump_best_label
PARAMS ((rtx
));
95 extern bool alpha_legitimate_address_p
PARAMS ((enum machine_mode
, rtx
, int));
96 extern rtx alpha_legitimize_address
PARAMS ((rtx
, rtx
, enum machine_mode
));
97 extern rtx alpha_legitimize_reload_address
PARAMS ((rtx
, enum machine_mode
,
100 extern rtx split_small_symbolic_operand
PARAMS ((rtx
));
102 extern void get_aligned_mem
PARAMS ((rtx
, rtx
*, rtx
*));
103 extern rtx get_unaligned_address
PARAMS ((rtx
, int));
104 extern enum reg_class alpha_preferred_reload_class
PARAMS ((rtx
,
106 extern enum reg_class secondary_reload_class
PARAMS ((enum reg_class
,
110 extern void alpha_set_memflags
PARAMS ((rtx
, rtx
));
111 extern rtx alpha_emit_set_const
PARAMS ((rtx
, enum machine_mode
,
112 HOST_WIDE_INT
, int));
113 extern rtx alpha_emit_set_long_const
PARAMS ((rtx
, HOST_WIDE_INT
,
115 extern bool alpha_expand_mov
PARAMS ((enum machine_mode
, rtx
*));
116 extern bool alpha_expand_mov_nobwx
PARAMS ((enum machine_mode
, rtx
*));
117 extern void alpha_emit_floatuns
PARAMS ((rtx
[]));
118 extern rtx alpha_emit_conditional_move
PARAMS ((rtx
, enum machine_mode
));
119 extern void alpha_split_tfmode_pair
PARAMS ((rtx
[]));
120 extern void alpha_split_tfmode_frobsign
PARAMS ((rtx
[],
121 rtx (*)(rtx
, rtx
, rtx
)));
122 extern void alpha_expand_unaligned_load
PARAMS ((rtx
, rtx
, HOST_WIDE_INT
,
123 HOST_WIDE_INT
, int));
124 extern void alpha_expand_unaligned_store
PARAMS ((rtx
, rtx
, HOST_WIDE_INT
,
126 extern int alpha_expand_block_move
PARAMS ((rtx
[]));
127 extern int alpha_expand_block_clear
PARAMS ((rtx
[]));
128 extern rtx alpha_expand_zap_mask
PARAMS ((HOST_WIDE_INT
));
129 extern void alpha_expand_builtin_vector_binop
PARAMS ((rtx (*)(rtx
, rtx
, rtx
),
132 extern rtx alpha_return_addr
PARAMS ((int, rtx
));
133 extern rtx alpha_gp_save_rtx
PARAMS ((void));
134 extern void print_operand
PARAMS ((FILE *, rtx
, int));
135 extern void print_operand_address
PARAMS ((FILE *, rtx
));
136 extern void alpha_initialize_trampoline
PARAMS ((rtx
, rtx
, rtx
, int, int, int));
137 extern void alpha_reorg
PARAMS ((rtx
));
139 extern tree alpha_build_va_list
PARAMS ((void));
140 extern void alpha_setup_incoming_varargs
141 PARAMS ((CUMULATIVE_ARGS
, enum machine_mode
, tree
, int *, int));
142 extern void alpha_va_start
PARAMS ((tree
, rtx
));
143 extern rtx alpha_va_arg
PARAMS ((tree
, tree
));
144 extern rtx function_arg
PARAMS ((CUMULATIVE_ARGS
, enum machine_mode
,
146 extern void alpha_start_function
PARAMS ((FILE *, const char *, tree
));
147 extern void alpha_end_function
PARAMS ((FILE *, const char *, tree
));
149 extern int alpha_find_lo_sum_using_gp
PARAMS ((rtx
));
151 #ifdef REAL_VALUE_TYPE
152 extern int check_float_value
PARAMS ((enum machine_mode
,
153 REAL_VALUE_TYPE
*, int));
157 extern rtx alpha_emit_conditional_branch
PARAMS ((enum rtx_code
));
158 extern rtx alpha_emit_setcc
PARAMS ((enum rtx_code
));
159 extern int alpha_split_conditional_move
PARAMS ((enum rtx_code
, rtx
, rtx
,
161 extern void alpha_emit_xfloating_arith
PARAMS ((enum rtx_code
, rtx
[]));
162 extern void alpha_emit_xfloating_cvt
PARAMS ((enum rtx_code
, rtx
[]));
165 extern rtx alpha_need_linkage
PARAMS ((const char *, int));
166 extern rtx alpha_use_linkage
PARAMS ((rtx
, tree
, int, int));
168 #if TARGET_ABI_OPEN_VMS
169 #ifdef HAVE_MACHINE_MODES
170 extern enum avms_arg_type alpha_arg_type
PARAMS ((enum machine_mode
));
172 extern rtx alpha_arg_info_reg_val
PARAMS ((CUMULATIVE_ARGS
));
173 #endif /* TARGET_ABI_OPEN_VMS */
175 extern rtx unicosmk_add_call_info_word
PARAMS ((rtx
));
177 #if TARGET_ABI_UNICOSMK
178 extern void unicosmk_defer_case_vector
PARAMS ((rtx
, rtx
));
179 extern void unicosmk_add_extern
PARAMS ((const char *));
180 extern void unicosmk_output_align
PARAMS ((FILE *, int));
181 extern char * unicosmk_text_section
PARAMS ((void));
182 extern char * unicosmk_data_section
PARAMS ((void));
183 extern void unicosmk_asm_file_start
PARAMS ((FILE *));
184 extern void unicosmk_asm_file_end
PARAMS ((FILE *));
185 extern void unicosmk_output_common
PARAMS ((FILE *, const char *, int, int));
186 #endif /* TARGET_ABI_UNICOSMK */