3f91a96d3a5642dc3f8793ec4a3256647ac349db
[libfirm] / ir / be / sparc / sparc_nodes_attr.h
1 /*
2  * Copyright (C) 1995-2008 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   attributes attached to all sparc nodes
23  * @version $Id$
24  */
25 #ifndef FIRM_BE_SPARC_SPARC_NODES_ATTR_H
26 #define FIRM_BE_SPARC_SPARC_NODES_ATTR_H
27
28 #include "../bearch.h"
29
30 typedef struct sparc_attr_t  sparc_attr_t;
31
32 /**
33  * base SPARC attribute
34  */
35 struct sparc_attr_t
36 {
37         except_attr                                     exc;                            /**< the exception attribute. MUST be the first one. */
38         const arch_register_req_t       **in_req;                       /**< register requirements for arguments */
39         int                                                     immediate_value;        /* immediate values */
40         bool                                            is_load_store;
41 };
42
43
44 /**
45  * attributes for load/store adressing modes
46  */
47 typedef struct sparc_load_store_attr_t sparc_load_store_attr_t;
48 struct sparc_load_store_attr_t {
49         sparc_attr_t    base;    /**< generic attribute */
50         ir_mode                 *load_store_mode;
51         ir_entity               *entity;
52         int                     entity_sign;
53         long                    offset;
54         bool                    is_frame_entity;
55 };
56
57 /**
58  * attributes for SymConsts
59  */
60 typedef struct sparc_symconst_attr_t sparc_symconst_attr_t;
61 struct sparc_symconst_attr_t {
62         sparc_attr_t    base;    /**< generic attribute */
63         ir_entity               *entity;
64         int                             fp_offset;
65 };
66
67 /**
68  * attributes for conditional jumps
69  */
70 typedef struct sparc_jmp_cond_attr_t sparc_jmp_cond_attr_t;
71 struct sparc_jmp_cond_attr_t {
72         sparc_attr_t    base;    /**< generic attribute */
73         int                             proj_num;
74 };
75
76 /**
77  * attributes for switch jumps
78  */
79 typedef struct sparc_jmp_switch_attr_t sparc_jmp_switch_attr_t;
80 struct sparc_jmp_switch_attr_t {
81         sparc_attr_t    base;    /**< generic attribute */
82         int                             n_projs;
83         long                    default_proj_num;
84 };
85
86 /**
87  * attributes for Cmp
88  */
89 typedef struct sparc_cmp_attr_t sparc_cmp_attr_t;
90 struct sparc_cmp_attr_t {
91         sparc_attr_t    base;    /**< generic attribute */
92         bool                    ins_permuted : 1;
93         bool                    is_unsigned  : 1;
94 };
95
96 #endif