X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fbe%2Fbeabi.h;h=9b612ce9f9d223b91f9fafdbca7eca0c3ea59b0e;hb=5d25ba11e212c06fafd016748059bac7eda79d14;hp=b927a2facf73b020d22fe84aa06c6b603043ca46;hpb=b53410a0e9548f99c2b37699f01766f50f1055ff;p=libfirm diff --git a/ir/be/beabi.h b/ir/be/beabi.h index b927a2fac..9b612ce9f 100644 --- a/ir/be/beabi.h +++ b/ir/be/beabi.h @@ -21,7 +21,6 @@ * @file * @brief Backend ABI implementation. * @author Sebastian Hack - * @version $Id$ */ #ifndef FIRM_BE_BEABI_H #define FIRM_BE_BEABI_H @@ -36,20 +35,12 @@ #include "beirg.h" #include "bearch.h" #include "beabi.h" +#include "beabihelper.h" -struct be_abi_call_flags_bits_t { - unsigned left_to_right : 1; /**< Arguments are from left to right. */ - unsigned store_args_sequential : 1; /**< Use sequential stores for arguments. */ - unsigned try_omit_fp : 1; /**< Try to omit the frame pointer. */ - unsigned fp_free : 1; /**< The function can use any register as frame pointer. */ - unsigned call_has_imm : 1; /**< A call can take the callee's address as an immediate. */ - unsigned irg_is_leaf : 1; /**< 1, if the IRG is a leaf function. */ - unsigned frame_is_setup_on_call : 1; /**< Set to one, if there is already enough room on the stack for call args. */ -}; - -union be_abi_call_flags_t { - be_abi_call_flags_bits_t bits; - unsigned val; +struct be_abi_call_flags_t { + bool try_omit_fp : 1; /**< Try to omit the frame pointer. */ + bool call_has_imm : 1; /**< A call can take the callee's address as an + immediate. */ }; struct be_abi_callbacks_t { @@ -144,27 +135,6 @@ be_abi_call_flags_t be_abi_call_get_flags(const be_abi_call_t *call); */ ir_type *be_abi_call_get_method_type(const be_abi_call_t *call); -be_abi_irg_t *be_abi_introduce(ir_graph *irg); - -/** - * should be called by betranshlp.c while the graph is transformed - */ -void be_abi_transform_fixup(ir_graph *irg); - -void be_abi_free(ir_graph *irg); - -ir_node *be_abi_get_callee_save_irn(ir_graph *irg, const arch_register_t *reg); -ir_node *be_abi_get_ignore_irn(ir_graph *irg, const arch_register_t *reg); - -static inline ir_node *be_abi_reg_map_get(pmap *map, const arch_register_t *reg) -{ - return (ir_node*)pmap_get(map, reg); -} - -static inline void be_abi_reg_map_set(pmap *map, const arch_register_t* reg, - ir_node *node) -{ - pmap_insert(map, reg, node); -} +void be_abi_introduce(ir_graph *irg); #endif