1 /* Prototypes of target machine for GNU compiler. MIPS version.
2 Copyright (C) 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3 1999, 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
4 Contributed by A. Lichnewsky (lich@inria.inria.fr).
5 Changed by Michael Meissner (meissner@osf.org).
6 64 bit r4000 support by Ian Lance Taylor (ian@cygnus.com) and
7 Brendan Eich (brendan@microunity.com).
9 This file is part of GCC.
11 GCC is free software; you can redistribute it and/or modify
12 it under the terms of the GNU General Public License as published by
13 the Free Software Foundation; either version 2, or (at your option)
16 GCC is distributed in the hope that it will be useful,
17 but WITHOUT ANY WARRANTY; without even the implied warranty of
18 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 GNU General Public License for more details.
21 You should have received a copy of the GNU General Public License
22 along with GCC; see the file COPYING. If not, write to
23 the Free Software Foundation, 59 Temple Place - Suite 330,
24 Boston, MA 02111-1307, USA. */
26 #ifndef GCC_MIPS_PROTOS_H
27 #define GCC_MIPS_PROTOS_H
29 /* Classifies a SYMBOL_REF, LABEL_REF or UNSPEC address.
32 Used when none of the below apply.
35 The symbol refers to something in a small data section.
38 The symbol refers to something in the mips16 constant pool.
41 The symbol refers to local data that will be found using
42 the global offset table.
45 Likewise non-local data.
48 An UNSPEC wrapper around a SYMBOL_GOT_LOCAL. It represents the
49 offset from _gp of a GOT page entry.
52 An UNSPEC wrapper around a SYMBOL_GOT_GLOBAL. It represents the
53 the offset from _gp of the symbol's GOT entry.
56 Like SYMBOL_GOTOFF_GLOBAL, but used when calling a global function.
57 The GOT entry is allowed to point to a stub rather than to the
61 An UNSPEC wrapper around a function's address. It represents the
62 offset of _gp from the start of the function.
65 For a 64-bit symbolic address X, this is the value of
66 (%highest(X) << 16) + %higher(X).
69 For a 64-bit symbolic address X, this is the value of
70 (%higher(X) << 16) + %hi(X).
73 For a 64-bit symbolic address X, this is the value of
74 (%hi(X) << 16) + %lo(X). */
75 enum mips_symbol_type
{
89 #define NUM_SYMBOL_TYPES (SYMBOL_64_LOW + 1)
91 extern int mips_regno_mode_ok_for_base_p (int, enum machine_mode
, int);
92 extern int mips_address_insns (rtx
, enum machine_mode
);
93 extern int mips_const_insns (rtx
);
94 extern int mips_fetch_insns (rtx
);
95 extern int mips_idiv_insns (void);
96 extern int fp_register_operand (rtx
, enum machine_mode
);
97 extern int lo_operand (rtx
, enum machine_mode
);
98 extern bool mips_legitimate_address_p (enum machine_mode
, rtx
, int);
99 extern rtx
mips_unspec_address (rtx
, enum mips_symbol_type
);
100 extern bool mips_legitimize_address (rtx
*, enum machine_mode
);
101 extern bool mips_legitimize_move (enum machine_mode
, rtx
, rtx
);
103 extern int m16_uimm3_b (rtx
, enum machine_mode
);
104 extern int m16_simm4_1 (rtx
, enum machine_mode
);
105 extern int m16_nsimm4_1 (rtx
, enum machine_mode
);
106 extern int m16_simm5_1 (rtx
, enum machine_mode
);
107 extern int m16_nsimm5_1 (rtx
, enum machine_mode
);
108 extern int m16_uimm5_4 (rtx
, enum machine_mode
);
109 extern int m16_nuimm5_4 (rtx
, enum machine_mode
);
110 extern int m16_simm8_1 (rtx
, enum machine_mode
);
111 extern int m16_nsimm8_1 (rtx
, enum machine_mode
);
112 extern int m16_uimm8_1 (rtx
, enum machine_mode
);
113 extern int m16_nuimm8_1 (rtx
, enum machine_mode
);
114 extern int m16_uimm8_m1_1 (rtx
, enum machine_mode
);
115 extern int m16_uimm8_4 (rtx
, enum machine_mode
);
116 extern int m16_nuimm8_4 (rtx
, enum machine_mode
);
117 extern int m16_simm8_8 (rtx
, enum machine_mode
);
118 extern int m16_nsimm8_8 (rtx
, enum machine_mode
);
120 extern rtx
mips_subword (rtx
, int);
121 extern bool mips_split_64bit_move_p (rtx
, rtx
);
122 extern void mips_split_64bit_move (rtx
, rtx
);
123 extern const char *mips_output_move (rtx
, rtx
);
124 extern rtx
mips_gp_save_slot (void);
126 extern rtx
gen_int_relational (enum rtx_code
, rtx
, rtx
, rtx
, int *);
127 extern void gen_conditional_branch (rtx
*, enum rtx_code
);
129 extern void gen_conditional_move (rtx
*);
130 extern void mips_gen_conditional_trap (rtx
*);
131 extern void mips_expand_call (rtx
, rtx
, rtx
, rtx
, int);
132 extern void mips_emit_fcc_reload (rtx
, rtx
, rtx
);
133 extern void mips_set_return_address (rtx
, rtx
);
134 extern bool mips_expand_block_move (rtx
, rtx
, rtx
);
136 extern void init_cumulative_args (CUMULATIVE_ARGS
*, tree
, rtx
);
137 extern void function_arg_advance (CUMULATIVE_ARGS
*, enum machine_mode
,
139 extern struct rtx_def
*function_arg (const CUMULATIVE_ARGS
*,
140 enum machine_mode
, tree
, int);
141 extern int function_arg_partial_nregs (const CUMULATIVE_ARGS
*,
142 enum machine_mode
, tree
, int);
143 extern bool mips_pad_arg_upward (enum machine_mode
, tree
);
144 extern bool mips_pad_reg_upward (enum machine_mode
, tree
);
145 extern void mips_va_start (tree
, rtx
);
146 extern struct rtx_def
*mips_va_arg (tree
, tree
);
148 extern bool mips_expand_unaligned_load (rtx
, rtx
, unsigned int, int);
149 extern bool mips_expand_unaligned_store (rtx
, rtx
, unsigned int, int);
150 extern void override_options (void);
151 extern void mips_conditional_register_usage (void);
152 extern void mips_order_regs_for_local_alloc (void);
153 extern HOST_WIDE_INT
mips_debugger_offset (rtx
, HOST_WIDE_INT
);
155 extern void print_operand (FILE *, rtx
, int);
156 extern void print_operand_address (FILE *, rtx
);
157 extern int mips_output_external (FILE *, tree
, const char *);
159 extern void irix_output_external_libcall (rtx
);
161 extern void mips_output_filename (FILE *, const char *);
162 extern void mips_output_lineno (FILE *, int);
163 extern void mips_output_ascii (FILE *, const char *, size_t, const char *);
164 extern void mips_output_aligned_bss (FILE *, tree
, const char *,
165 unsigned HOST_WIDE_INT
, int);
166 extern void mips_output_aligned_decl_common (FILE *, tree
, const char *,
167 unsigned HOST_WIDE_INT
,
169 extern void mips_declare_common_object (FILE *, const char *,
170 const char *, unsigned HOST_WIDE_INT
,
172 extern void mips_declare_object (FILE *, const char *, const char *,
174 extern void mips_declare_object_name (FILE *, const char *, tree
);
175 extern void mips_finish_declare_object (FILE *, tree
, int, int);
177 extern rtx
mips_rewrite_small_data (rtx
);
178 extern HOST_WIDE_INT
compute_frame_size (HOST_WIDE_INT
);
179 extern HOST_WIDE_INT
mips_initial_elimination_offset (int, int);
180 extern rtx
mips_return_addr (int, rtx
);
181 extern void mips_expand_prologue (void);
182 extern void mips_expand_epilogue (int);
183 extern int mips_can_use_return_insn (void);
184 extern struct rtx_def
*mips_function_value (tree
, tree
, enum machine_mode
);
185 extern int function_arg_pass_by_reference (const CUMULATIVE_ARGS
*,
186 enum machine_mode
, tree
, int);
188 extern bool mips_cannot_change_mode_class (enum machine_mode
,
189 enum machine_mode
, enum reg_class
);
190 extern bool mips_dangerous_for_la25_p (rtx
);
191 extern enum reg_class
mips_preferred_reload_class (rtx
, enum reg_class
);
192 extern enum reg_class
mips_secondary_reload_class (enum reg_class
,
195 extern int mips_class_max_nregs (enum reg_class
, enum machine_mode
);
196 extern bool mips_valid_pointer_mode (enum machine_mode
);
197 extern int build_mips16_call_stub (rtx
, rtx
, rtx
, int);
198 extern int mips_register_move_cost (enum machine_mode
, enum reg_class
,
201 extern int mips_adjust_insn_length (rtx
, int);
202 extern const char *mips_output_load_label (void);
203 extern const char *mips_output_conditional_branch (rtx
, rtx
*, int, int,
205 extern const char *mips_output_division (const char *, rtx
*);
206 extern unsigned int mips_hard_regno_nregs (int, enum machine_mode
);
207 extern bool mips_linked_madd_p (rtx
, rtx
);
208 extern const char *mips_emit_prefetch (rtx
*);
210 extern void irix_asm_output_align (FILE *, unsigned);
211 extern const char *current_section_name (void);
212 extern unsigned int current_section_flags (void);
214 #endif /* ! GCC_MIPS_PROTOS_H */