bescripts: Copy all common node attributes into the constructor variants.
[libfirm] / ir / be / sparc / sparc_nodes_attr.h
index fe266ab..5af5291 100644 (file)
 /**
  * @file
  * @brief   attributes attached to all sparc nodes
- * @version $Id$
+ * @author  Hannes Rapp, Matthias Braun
  */
 #ifndef FIRM_BE_SPARC_SPARC_NODES_ATTR_H
 #define FIRM_BE_SPARC_SPARC_NODES_ATTR_H
 
-#include "../bearch.h"
+#include "bearch.h"
+#include <stdint.h>
 
 typedef struct sparc_attr_t  sparc_attr_t;
 
@@ -34,43 +35,43 @@ typedef struct sparc_attr_t  sparc_attr_t;
  */
 struct sparc_attr_t
 {
-       except_attr                                     exc;                            /**< the exception attribute. MUST be the first one. */
-       const arch_register_req_t       **in_req;                       /**< register requirements for arguments */
-       int                                                     immediate_value;        /* immediate values */
-       bool                                            is_load_store;
+       except_attr                 exc;                /**< the exception attribute. MUST be the first one. */
+       int32_t                     immediate_value;    /* immediate values */
+       ir_entity                  *immediate_value_entity;
 };
 
+enum sparc_arch_irn_flags_t {
+       sparc_arch_irn_flag_needs_64bit_spillslot = arch_irn_flags_backend << 0,
+       sparc_arch_irn_flag_immediate_form        = arch_irn_flags_backend << 1,
+       sparc_arch_irn_flag_aggregate_return      = arch_irn_flags_backend << 2,
+       sparc_arch_irn_flag_has_delay_slot        = arch_irn_flags_backend << 3,
+};
 
 /**
- * attribute for save instruction
+ * attribute for FP immediate 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 */
+typedef struct sparc_fp_attr_t sparc_fp_attr_t;
+struct sparc_fp_attr_t {
+       sparc_attr_t  base;         /**< generic attribute */
+       ir_mode      *fp_mode;
 };
 
-/**
- * attributes for load/store adressing modes
- */
-typedef struct sparc_load_store_attr_t sparc_load_store_attr_t;
-struct sparc_load_store_attr_t {
-       sparc_attr_t    base;    /**< generic attribute */
-       ir_mode                 *load_store_mode;
-       ir_entity               *entity;
-       int                     entity_sign;
-       long                    offset;
-       bool                    is_frame_entity;
+typedef struct sparc_fp_conv_attr_t sparc_fp_conv_attr_t;
+struct sparc_fp_conv_attr_t {
+       sparc_attr_t  base;
+       ir_mode      *src_mode;
+       ir_mode      *dest_mode;
 };
 
 /**
- * attributes for SymConsts
+ * attributes for load/store addressing modes
  */
-typedef struct sparc_symconst_attr_t sparc_symconst_attr_t;
-struct sparc_symconst_attr_t {
-       sparc_attr_t    base;    /**< generic attribute */
-       ir_entity               *entity;
-       int                             fp_offset;
+typedef struct sparc_load_store_attr_t sparc_load_store_attr_t;
+struct sparc_load_store_attr_t {
+       sparc_attr_t  base;    /**< generic attribute */
+       ir_mode      *load_store_mode;
+       bool          is_frame_entity : 1;
+       bool          is_reg_reg      : 1;
 };
 
 /**
@@ -78,28 +79,25 @@ struct sparc_symconst_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 */
-       int                             proj_num;
+       sparc_attr_t base;    /**< generic attribute */
+       ir_relation  relation;
+       bool         is_unsigned      : 1;
+       bool         annul_delay_slot : 1;
 };
 
 /**
  * attributes for switch jumps
  */
-typedef struct sparc_jmp_switch_attr_t sparc_jmp_switch_attr_t;
-struct sparc_jmp_switch_attr_t {
-       sparc_attr_t    base;    /**< generic attribute */
-       int                             n_projs;
-       long                    default_proj_num;
+typedef struct sparc_switch_jmp_attr_t sparc_switch_jmp_attr_t;
+struct sparc_switch_jmp_attr_t {
+       sparc_attr_t           base;
+       const ir_switch_table *table;
+       ir_entity             *table_entity;
 };
 
-/**
- * attributes for Cmp
- */
-typedef struct sparc_cmp_attr_t sparc_cmp_attr_t;
-struct sparc_cmp_attr_t {
-       sparc_attr_t    base;    /**< generic attribute */
-       bool                    ins_permuted : 1;
-       bool                    is_unsigned  : 1;
+enum n_sparc_Return {
+       n_sparc_Return_mem = 0,
+       n_sparc_Return_sp  = 1,
 };
 
 #endif