fix mips immediate dumper
[libfirm] / ir / be / mips / mips_nodes_attr.h
1 /*
2  * Copyright (C) 1995-2007 University of Karlsruhe.  All right reserved.
3  *
4  * This file is part of libFirm.
5  *
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.
10  *
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.
14  *
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
17  * PURPOSE.
18  */
19
20 /**
21  * @file
22  * @brief   declaration of attributes for mips nodes
23  * @author  Matthias Braun
24  * @version $Id$
25  */
26 #ifndef FIRM_BE_MIPS_MIPS_NODES_ATTR_H
27 #define FIRM_BE_MIPS_MIPS_NODES_ATTR_H
28
29 #include "../bearch_t.h"
30 #include "irmode_t.h"
31 #include "irnode_t.h"
32
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. */
36
37         int switch_default_pn;          /**< proj number of default case in switch */
38
39         const arch_register_req_t **in_req;  /**< register requirements for arguments */
40         const arch_register_req_t **out_req; /**< register requirements for results */
41
42         const arch_register_t **slots;     /**< register slots for assigned registers */
43 } mips_attr_t;
44
45 typedef enum mips_immediate_type_t {
46         MIPS_IMM_CONST,
47         MIPS_IMM_SYMCONST_LO,
48         MIPS_IMM_SYMCONST_HI
49 } mips_immediate_type_t;
50
51 typedef struct mips_immediate_attr_t {
52         mips_attr_t            attr;
53         mips_immediate_type_t  imm_type;
54         ir_entity             *entity;
55         long                   val;
56 } mips_immediate_attr_t;
57
58 typedef struct mips_load_store_attr_t {
59         mips_attr_t  attr;
60         ir_entity   *stack_entity;
61         long         offset;
62 } mips_load_store_attr_t;
63
64 #endif