/**
* @file
* @brief attributes attached to all sparc nodes
+ * @author Hannes Rapp, Matthias Braun
* @version $Id$
*/
#ifndef FIRM_BE_SPARC_SPARC_NODES_ATTR_H
sparc_arch_irn_flag_modifies_flags = arch_irn_flags_backend << 0,
sparc_arch_irn_flag_modifies_fp_flags = arch_irn_flags_backend << 1,
sparc_arch_irn_flag_needs_64bit_spillslot = arch_irn_flags_backend << 2,
+ sparc_arch_irn_flag_immediate_form = arch_irn_flags_backend << 3,
+ sparc_arch_irn_flag_aggregate_return = arch_irn_flags_backend << 4,
};
/**
};
/**
- * attribute for save instruction
- */
-typedef struct sparc_save_attr_t sparc_save_attr_t;
-struct sparc_save_attr_t {
- sparc_attr_t base; /**< generic attribute */
- int initial_stacksize; /* the min. stack size required by the sparc ABI */
-};
-
-/**
- * attributes for load/store adressing modes
+ * attributes for load/store addressing modes
*/
typedef struct sparc_load_store_attr_t sparc_load_store_attr_t;
struct sparc_load_store_attr_t {
typedef struct sparc_jmp_cond_attr_t sparc_jmp_cond_attr_t;
struct sparc_jmp_cond_attr_t {
sparc_attr_t base; /**< generic attribute */
- pn_Cmp pnc;
+ ir_relation relation;
bool is_unsigned : 1;
};