/*
- * Copyright (C) 1995-2008 University of Karlsruhe. All right reserved.
- *
* This file is part of libFirm.
- *
- * This file may be distributed and/or modified under the terms of the
- * GNU General Public License version 2 as published by the Free Software
- * Foundation and appearing in the file LICENSE.GPL included in the
- * packaging of this file.
- *
- * Licensees holding valid libFirm Professional Edition licenses may use
- * this file in accordance with the libFirm Commercial License.
- * Agreement provided with the Software.
- *
- * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
- * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE.
+ * Copyright (C) 2012 University of Karlsruhe.
*/
/**
* @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;
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;
-
- ir_entity *immediate_value_entity; /* hack for now */
+ int32_t immediate_value; /* immediate values */
+ ir_entity *immediate_value_entity;
};
enum sparc_arch_irn_flags_t {
- 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 << 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
- */
-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 {
sparc_attr_t base; /**< generic attribute */
ir_mode *load_store_mode;
- ir_entity *entity;
- int entity_sign;
- long offset;
- bool is_frame_entity;
-};
-
-/**
- * attributes for SymConsts
- */
-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;
+ bool is_frame_entity : 1;
+ bool is_reg_reg : 1;
};
/**
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;
- bool is_unsigned : 1;
+ 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;
+};
+
+enum n_sparc_Return {
+ n_sparc_Return_mem = 0,
+ n_sparc_Return_sp = 1,
};
#endif