/* Prototypes for Blackfin functions used in the md file & elsewhere. Copyright (C) 2005-2022 Free Software Foundation, Inc. This file is part of GNU CC. GNU CC is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version. GNU CC is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with GCC; see the file COPYING3. If not see . */ /* Function prototypes that cannot exist in bfin.h due to dependency complications. */ #ifndef GCC_BFIN_PROTOS_H #define GCC_BFIN_PROTOS_H /* For the anomaly 05-00-0245 */ #define WA_SPECULATIVE_LOADS 0x00000001 #define ENABLE_WA_SPECULATIVE_LOADS \ (bfin_workarounds & WA_SPECULATIVE_LOADS) /* For the anomaly 05-00-0244 */ #define WA_SPECULATIVE_SYNCS 0x00000002 #define ENABLE_WA_SPECULATIVE_SYNCS \ (bfin_workarounds & WA_SPECULATIVE_SYNCS) /* For the anomaly 05-00-0371 */ #define WA_RETS 0x00000004 #define ENABLE_WA_RETS \ (bfin_workarounds & WA_RETS) /* For the anomaly 05-00-0426 */ #define WA_INDIRECT_CALLS 0x00000008 #define ENABLE_WA_INDIRECT_CALLS \ ((bfin_workarounds & WA_INDIRECT_CALLS) && !TARGET_ICPLB) #define WA_05000257 0x00000010 #define ENABLE_WA_05000257 \ (bfin_workarounds & WA_05000257) #define WA_05000283 0x00000020 #define ENABLE_WA_05000283 \ (bfin_workarounds & WA_05000283) #define WA_05000315 0x00000040 #define ENABLE_WA_05000315 \ (bfin_workarounds & WA_05000315) /* For the anomaly 05-00-0312 */ #define WA_LOAD_LCREGS 0x00000080 #define ENABLE_WA_LOAD_LCREGS \ (bfin_workarounds & WA_LOAD_LCREGS) #define WA_05000074 0x00000100 #define ENABLE_WA_05000074 \ (bfin_workarounds & WA_05000074) extern bool function_arg_regno_p (int); extern const char *output_load_immediate (rtx *); extern const char *output_casesi_internal (rtx *); extern char *bfin_asm_long (void); extern char *bfin_asm_short (void); extern int log2constp (unsigned HOST_WIDE_INT); extern void init_cumulative_args (CUMULATIVE_ARGS *, tree, rtx); extern HOST_WIDE_INT bfin_initial_elimination_offset (int, int); extern int effective_address_32bit_p (rtx, machine_mode); extern int symbolic_reference_mentioned_p (rtx); extern rtx bfin_gen_compare (rtx, machine_mode); extern bool expand_move (rtx *, machine_mode); extern void bfin_expand_call (rtx, rtx, rtx, rtx, int); extern bool bfin_longcall_p (rtx, int); extern bool bfin_dsp_memref_p (rtx); extern bool bfin_expand_cpymem (rtx, rtx, rtx, rtx); extern enum reg_class secondary_input_reload_class (enum reg_class, machine_mode, rtx); extern enum reg_class secondary_output_reload_class (enum reg_class, machine_mode, rtx); extern char *section_asm_op_1 (SECT_ENUM_T); extern char *section_asm_op (SECT_ENUM_T); extern void print_operand (FILE *, rtx, char); extern void print_address_operand (FILE *, rtx); extern void split_di (rtx [], int, rtx [], rtx []); extern int split_load_immediate (rtx []); extern void emit_pic_move (rtx *, machine_mode); extern void asm_conditional_branch (rtx_insn *, rtx *, int, int); extern rtx bfin_gen_compare (rtx, machine_mode); extern unsigned bfin_local_alignment (tree, unsigned); extern rtx bfin_va_arg (tree, tree); extern void bfin_expand_prologue (void); extern void bfin_expand_epilogue (int, int, bool); extern int analyze_push_multiple_operation (rtx); extern int analyze_pop_multiple_operation (rtx); extern void output_push_multiple (rtx, rtx *); extern void output_pop_multiple (rtx, rtx *); extern int bfin_hard_regno_rename_ok (unsigned int, unsigned int); extern rtx bfin_return_addr_rtx (int); extern void bfin_hardware_loop (void); #endif