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 attributes attached to all sparc nodes
25 #ifndef FIRM_BE_SPARC_SPARC_NODES_ATTR_H
26 #define FIRM_BE_SPARC_SPARC_NODES_ATTR_H
28 #include "../bearch.h"
30 typedef struct sparc_attr_t sparc_attr_t;
33 * base SPARC attribute
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 */
44 * attribute for FP immediate instruction
46 typedef struct sparc_fp_attr_t sparc_fp_attr_t;
47 struct sparc_fp_attr_t {
48 sparc_attr_t base; /**< generic attribute */
49 double fp_immediate; /* the FP immediate value */
53 * attribute for save instruction
55 typedef struct sparc_save_attr_t sparc_save_attr_t;
56 struct sparc_save_attr_t {
57 sparc_attr_t base; /**< generic attribute */
58 int initial_stacksize; /* the min. stack size required by the sparc ABI */
62 * attributes for load/store adressing modes
64 typedef struct sparc_load_store_attr_t sparc_load_store_attr_t;
65 struct sparc_load_store_attr_t {
66 sparc_attr_t base; /**< generic attribute */
67 ir_mode *load_store_mode;
75 * attributes for SymConsts
77 typedef struct sparc_symconst_attr_t sparc_symconst_attr_t;
78 struct sparc_symconst_attr_t {
79 sparc_attr_t base; /**< generic attribute */
85 * attributes for conditional jumps
87 typedef struct sparc_jmp_cond_attr_t sparc_jmp_cond_attr_t;
88 struct sparc_jmp_cond_attr_t {
89 sparc_attr_t base; /**< generic attribute */
94 * attributes for switch jumps
96 typedef struct sparc_jmp_switch_attr_t sparc_jmp_switch_attr_t;
97 struct sparc_jmp_switch_attr_t {
98 sparc_attr_t base; /**< generic attribute */
100 long default_proj_num;
106 typedef struct sparc_cmp_attr_t sparc_cmp_attr_t;
107 struct sparc_cmp_attr_t {
108 sparc_attr_t base; /**< generic attribute */
109 bool ins_permuted : 1;
110 bool is_unsigned : 1;