added doxygen comments, transform mips to new emit style, use gnuas gendecls
[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
32 typedef struct _mips_attr_t {
33         arch_irn_flags_t flags;     /**< indicating if spillable, rematerializeable ... etc. */
34         int              n_res;     /**< number of results for this node */
35
36         tarval *tv;                                     /**< contains the immediate value (if the node has any) */
37         ident *symconst_id;                     /**< contains the ident (for la operations) */
38
39         union {
40                 ir_mode *load_store_mode;       /**< contains the mode of a load/store */
41                 ir_mode *original_mode;         /**< contains the original mode of the node */
42         } modes;
43         ir_entity *stack_entity;        /**< contains the entity on the stack for a load/store mode */
44         int stack_entity_offset;        /**< contains the real stack offset for the entity */
45         int switch_default_pn;          /**< proj number of default case in switch */
46
47         const arch_register_req_t **in_req;  /**< register requirements for arguments */
48         const arch_register_req_t **out_req; /**< register requirements for results */
49
50         /* must be last, dynamically allocated */
51         const arch_register_t *slots[1];     /**< register slots for assigned registers */
52 } mips_attr_t;
53
54 #endif