2 * Copyright (C) 1995-2008 University of Karlsruhe. All right reserved.
4 * This file is part of libFirm.
6 * This file may be distributed and/or modified under the terms of the
7 * GNU General Public License version 2 as published by the Free Software
8 * Foundation and appearing in the file LICENSE.GPL included in the
9 * packaging of this file.
11 * Licensees holding valid libFirm Professional Edition licenses may use
12 * this file in accordance with the libFirm Commercial License.
13 * Agreement provided with the Software.
15 * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
16 * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * @brief declaration of attributes for mips nodes
23 * @author Matthias Braun
26 #ifndef FIRM_BE_MIPS_MIPS_NODES_ATTR_H
27 #define FIRM_BE_MIPS_MIPS_NODES_ATTR_H
29 #include "../bearch_t.h"
33 typedef struct mips_attr_t {
34 except_attr exc; /**< the exception attribute. MUST be the first one. */
35 arch_irn_flags_t flags; /**< indicating if spillable, rematerializeable ... etc. */
37 int switch_default_pn; /**< proj number of default case in switch */
39 const arch_register_req_t **in_req; /**< register requirements for arguments */
40 const arch_register_req_t **out_req; /**< register requirements for results */
42 const arch_register_t **slots; /**< register slots for assigned registers */
45 typedef enum mips_immediate_type_t {
49 } mips_immediate_type_t;
51 typedef struct mips_immediate_attr_t {
53 mips_immediate_type_t imm_type;
56 } mips_immediate_attr_t;
58 typedef struct mips_load_store_attr_t {
60 ir_entity *stack_entity;
62 } mips_load_store_attr_t;