11debfc3dSmrg /* Prototypes for exported functions defined in avr.c
21debfc3dSmrg
3*8feb0f0bSmrg Copyright (C) 2000-2020 Free Software Foundation, Inc.
41debfc3dSmrg Contributed by Denis Chertykov (chertykov@gmail.com)
51debfc3dSmrg
61debfc3dSmrg This file is part of GCC.
71debfc3dSmrg
81debfc3dSmrg GCC is free software; you can redistribute it and/or modify
91debfc3dSmrg it under the terms of the GNU General Public License as published by
101debfc3dSmrg the Free Software Foundation; either version 3, or (at your option)
111debfc3dSmrg any later version.
121debfc3dSmrg
131debfc3dSmrg GCC is distributed in the hope that it will be useful,
141debfc3dSmrg but WITHOUT ANY WARRANTY; without even the implied warranty of
151debfc3dSmrg MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
161debfc3dSmrg GNU General Public License for more details.
171debfc3dSmrg
181debfc3dSmrg You should have received a copy of the GNU General Public License
191debfc3dSmrg along with GCC; see the file COPYING3. If not see
201debfc3dSmrg <http://www.gnu.org/licenses/>. */
211debfc3dSmrg
221debfc3dSmrg
231debfc3dSmrg extern int avr_function_arg_regno_p (int r);
241debfc3dSmrg extern void avr_cpu_cpp_builtins (struct cpp_reader * pfile);
251debfc3dSmrg extern enum reg_class avr_regno_reg_class (int r);
261debfc3dSmrg extern void asm_globalize_label (FILE *file, const char *name);
271debfc3dSmrg extern void avr_adjust_reg_alloc_order (void);
281debfc3dSmrg extern int avr_initial_elimination_offset (int from, int to);
291debfc3dSmrg extern int avr_simple_epilogue (void);
301debfc3dSmrg extern int avr_hard_regno_rename_ok (unsigned int, unsigned int);
311debfc3dSmrg extern rtx avr_return_addr_rtx (int count, rtx tem);
321debfc3dSmrg extern void avr_register_target_pragmas (void);
331debfc3dSmrg extern void avr_init_expanders (void);
341debfc3dSmrg
351debfc3dSmrg #ifdef TREE_CODE
361debfc3dSmrg extern void avr_asm_output_aligned_decl_common (FILE*, tree, const char*, unsigned HOST_WIDE_INT, unsigned int, bool);
371debfc3dSmrg extern void avr_asm_asm_output_aligned_bss (FILE *, tree, const char *, unsigned HOST_WIDE_INT, int, void (*) (FILE *, tree, const char *, unsigned HOST_WIDE_INT, int));
381debfc3dSmrg extern void asm_output_external (FILE *file, tree decl, char *name);
391debfc3dSmrg extern int avr_progmem_p (tree decl, tree attributes);
401debfc3dSmrg extern bool avr_addr_space_supported_p (addr_space_t, location_t loc = UNKNOWN_LOCATION);
411debfc3dSmrg
421debfc3dSmrg #ifdef RTX_CODE /* inside TREE_CODE */
431debfc3dSmrg extern void avr_init_cumulative_args (CUMULATIVE_ARGS*, tree, rtx, tree);
441debfc3dSmrg #endif /* RTX_CODE inside TREE_CODE */
451debfc3dSmrg
461debfc3dSmrg #endif /* TREE_CODE */
471debfc3dSmrg
481debfc3dSmrg #ifdef RTX_CODE
491debfc3dSmrg extern const char *output_movqi (rtx_insn *insn, rtx operands[], int *l);
501debfc3dSmrg extern const char *output_movhi (rtx_insn *insn, rtx operands[], int *l);
511debfc3dSmrg extern const char *output_movsisf (rtx_insn *insn, rtx operands[], int *l);
521debfc3dSmrg extern const char *avr_out_tstsi (rtx_insn *, rtx*, int*);
531debfc3dSmrg extern const char *avr_out_tsthi (rtx_insn *, rtx*, int*);
541debfc3dSmrg extern const char *avr_out_tstpsi (rtx_insn *, rtx*, int*);
551debfc3dSmrg extern const char *avr_out_compare (rtx_insn *, rtx*, int*);
561debfc3dSmrg extern const char *avr_out_compare64 (rtx_insn *, rtx*, int*);
571debfc3dSmrg extern const char *ret_cond_branch (rtx x, int len, int reverse);
581debfc3dSmrg extern const char *avr_out_movpsi (rtx_insn *, rtx*, int*);
591debfc3dSmrg extern const char *avr_out_sign_extend (rtx_insn *, rtx*, int*);
601debfc3dSmrg extern const char *avr_out_insert_notbit (rtx_insn *, rtx*, rtx, int*);
611debfc3dSmrg
621debfc3dSmrg extern const char *ashlqi3_out (rtx_insn *insn, rtx operands[], int *len);
631debfc3dSmrg extern const char *ashlhi3_out (rtx_insn *insn, rtx operands[], int *len);
641debfc3dSmrg extern const char *ashlsi3_out (rtx_insn *insn, rtx operands[], int *len);
651debfc3dSmrg
661debfc3dSmrg extern const char *ashrqi3_out (rtx_insn *insn, rtx operands[], int *len);
671debfc3dSmrg extern const char *ashrhi3_out (rtx_insn *insn, rtx operands[], int *len);
681debfc3dSmrg extern const char *ashrsi3_out (rtx_insn *insn, rtx operands[], int *len);
691debfc3dSmrg
701debfc3dSmrg extern const char *lshrqi3_out (rtx_insn *insn, rtx operands[], int *len);
711debfc3dSmrg extern const char *lshrhi3_out (rtx_insn *insn, rtx operands[], int *len);
721debfc3dSmrg extern const char *lshrsi3_out (rtx_insn *insn, rtx operands[], int *len);
731debfc3dSmrg
741debfc3dSmrg extern const char *avr_out_ashlpsi3 (rtx_insn *, rtx*, int*);
751debfc3dSmrg extern const char *avr_out_ashrpsi3 (rtx_insn *, rtx*, int*);
761debfc3dSmrg extern const char *avr_out_lshrpsi3 (rtx_insn *, rtx*, int*);
771debfc3dSmrg
781debfc3dSmrg extern bool avr_rotate_bytes (rtx operands[]);
791debfc3dSmrg
801debfc3dSmrg extern const char* avr_out_fract (rtx_insn *, rtx[], bool, int*);
811debfc3dSmrg extern rtx avr_to_int_mode (rtx);
821debfc3dSmrg
831debfc3dSmrg extern void avr_expand_prologue (void);
841debfc3dSmrg extern void avr_expand_epilogue (bool);
85*8feb0f0bSmrg extern bool avr_emit_cpymemhi (rtx*);
861debfc3dSmrg extern int avr_epilogue_uses (int regno);
871debfc3dSmrg
88a2dc1f3fSmrg extern void avr_output_addr_vec (rtx_insn*, rtx);
891debfc3dSmrg extern const char *avr_out_sbxx_branch (rtx_insn *insn, rtx operands[]);
901debfc3dSmrg extern const char* avr_out_bitop (rtx, rtx*, int*);
911debfc3dSmrg extern const char* avr_out_plus (rtx, rtx*, int* =NULL, int* =NULL, bool =true);
921debfc3dSmrg extern const char* avr_out_round (rtx_insn *, rtx*, int* =NULL);
931debfc3dSmrg extern const char* avr_out_addto_sp (rtx*, int*);
941debfc3dSmrg extern const char* avr_out_xload (rtx_insn *, rtx*, int*);
95*8feb0f0bSmrg extern const char* avr_out_cpymem (rtx_insn *, rtx*, int*);
961debfc3dSmrg extern const char* avr_out_insert_bits (rtx*, int*);
971debfc3dSmrg extern bool avr_popcount_each_byte (rtx, int, int);
981debfc3dSmrg extern bool avr_has_nibble_0xf (rtx);
991debfc3dSmrg
1001debfc3dSmrg extern int extra_constraint_Q (rtx x);
1011debfc3dSmrg extern int avr_adjust_insn_length (rtx_insn *insn, int len);
1021debfc3dSmrg extern const char* output_reload_inhi (rtx*, rtx, int*);
1031debfc3dSmrg extern const char* output_reload_insisf (rtx*, rtx, int*);
1041debfc3dSmrg extern const char* avr_out_reload_inpsi (rtx*, rtx, int*);
1051debfc3dSmrg extern const char* avr_out_lpm (rtx_insn *, rtx*, int*);
1061debfc3dSmrg extern void avr_notice_update_cc (rtx body, rtx_insn *insn);
1071debfc3dSmrg extern int reg_unused_after (rtx_insn *insn, rtx reg);
1081debfc3dSmrg extern int _reg_unused_after (rtx_insn *insn, rtx reg);
1091debfc3dSmrg extern int avr_jump_mode (rtx x, rtx_insn *insn);
1101debfc3dSmrg extern int test_hard_reg_class (enum reg_class rclass, rtx x);
1111debfc3dSmrg extern int jump_over_one_insn_p (rtx_insn *insn, rtx dest);
1121debfc3dSmrg
1131debfc3dSmrg extern void avr_final_prescan_insn (rtx_insn *insn, rtx *operand,
1141debfc3dSmrg int num_operands);
1151debfc3dSmrg extern int avr_simplify_comparison_p (machine_mode mode,
1161debfc3dSmrg RTX_CODE op, rtx x);
1171debfc3dSmrg extern RTX_CODE avr_normalize_condition (RTX_CODE condition);
1181debfc3dSmrg extern void out_shift_with_cnt (const char *templ, rtx_insn *insn,
1191debfc3dSmrg rtx operands[], int *len, int t_len);
1201debfc3dSmrg extern enum reg_class avr_mode_code_base_reg_class (machine_mode, addr_space_t, RTX_CODE, RTX_CODE);
1211debfc3dSmrg extern bool avr_regno_mode_code_ok_for_base_p (int, machine_mode, addr_space_t, RTX_CODE, RTX_CODE);
1221debfc3dSmrg extern rtx avr_incoming_return_addr_rtx (void);
1231debfc3dSmrg extern rtx avr_legitimize_reload_address (rtx*, machine_mode, int, int, int, int, rtx (*)(rtx,int));
1241debfc3dSmrg extern bool avr_mem_flash_p (rtx);
1251debfc3dSmrg extern bool avr_mem_memx_p (rtx);
1261debfc3dSmrg extern bool avr_load_libgcc_p (rtx);
1271debfc3dSmrg extern bool avr_xload_libgcc_p (machine_mode);
1281debfc3dSmrg extern rtx avr_eval_addr_attrib (rtx x);
1291debfc3dSmrg extern bool avr_casei_sequence_check_operands (rtx *xop);
1301debfc3dSmrg
131*8feb0f0bSmrg extern bool avr_float_lib_compare_returns_bool (machine_mode, enum rtx_code);
132*8feb0f0bSmrg
1331debfc3dSmrg static inline unsigned
regmask(machine_mode mode,unsigned regno)1341debfc3dSmrg regmask (machine_mode mode, unsigned regno)
1351debfc3dSmrg {
136a2dc1f3fSmrg return ((1u << GET_MODE_SIZE (as_a <fixed_size_mode> (mode))) - 1) << regno;
1371debfc3dSmrg }
1381debfc3dSmrg
1391debfc3dSmrg extern void avr_fix_inputs (rtx*, unsigned, unsigned);
1401debfc3dSmrg extern bool avr_emit3_fix_outputs (rtx (*)(rtx,rtx,rtx), rtx*, unsigned, unsigned);
1411debfc3dSmrg
1421debfc3dSmrg extern rtx lpm_reg_rtx;
1431debfc3dSmrg extern rtx lpm_addr_reg_rtx;
1441debfc3dSmrg extern rtx tmp_reg_rtx;
1451debfc3dSmrg extern rtx zero_reg_rtx;
1461debfc3dSmrg extern rtx all_regs_rtx[32];
1471debfc3dSmrg extern rtx rampz_rtx;
1481debfc3dSmrg
1491debfc3dSmrg #endif /* RTX_CODE */
1501debfc3dSmrg
1511debfc3dSmrg #ifdef REAL_VALUE_TYPE
1521debfc3dSmrg extern void asm_output_float (FILE *file, REAL_VALUE_TYPE n);
1531debfc3dSmrg #endif
1541debfc3dSmrg
1551debfc3dSmrg extern bool avr_have_dimode;
1561debfc3dSmrg
1571debfc3dSmrg namespace gcc { class context; }
1581debfc3dSmrg class rtl_opt_pass;
1591debfc3dSmrg
160a2dc1f3fSmrg extern rtl_opt_pass *make_avr_pass_pre_proep (gcc::context *);
1611debfc3dSmrg extern rtl_opt_pass *make_avr_pass_recompute_notes (gcc::context *);
1621debfc3dSmrg extern rtl_opt_pass *make_avr_pass_casesi (gcc::context *);
1631debfc3dSmrg
1641debfc3dSmrg /* From avr-log.c */
1651debfc3dSmrg
1661debfc3dSmrg #define avr_dump(...) avr_vdump (NULL, __FUNCTION__, __VA_ARGS__)
1671debfc3dSmrg #define avr_edump(...) avr_vdump (stderr, __FUNCTION__, __VA_ARGS__)
1681debfc3dSmrg #define avr_fdump(FIL, ...) avr_vdump (FIL, __FUNCTION__, __VA_ARGS__)
1691debfc3dSmrg
1701debfc3dSmrg extern int avr_vdump (FILE*, const char*, ...);
1711debfc3dSmrg extern void avr_log_set_avr_log (void);
1721debfc3dSmrg
1731debfc3dSmrg typedef struct
1741debfc3dSmrg {
1751debfc3dSmrg unsigned address_cost :1;
1761debfc3dSmrg unsigned builtin :1;
1771debfc3dSmrg unsigned constraints :1;
178a2dc1f3fSmrg unsigned insn_addresses :1;
1791debfc3dSmrg unsigned legitimate_address_p :1;
1801debfc3dSmrg unsigned legitimize_address :1;
1811debfc3dSmrg unsigned legitimize_reload_address :1;
1821debfc3dSmrg unsigned progmem :1;
1831debfc3dSmrg unsigned rtx_costs :1;
1841debfc3dSmrg } avr_log_t;
1851debfc3dSmrg
1861debfc3dSmrg extern avr_log_t avr_log;
187