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 amd64 nodes
23 * @version $Id: amd64_nodes_attr.h 26317 2009-08-05 10:53:46Z matze $
25 #ifndef FIRM_BE_amd64_amd64_NODES_ATTR_H
26 #define FIRM_BE_amd64_amd64_NODES_ATTR_H
28 #include "../bearch.h"
30 typedef struct amd64_attr_t amd64_attr_t;
31 typedef struct amd64_SymConst_attr_t amd64_SymConst_attr_t;
35 except_attr exc; /**< the exception attribute. MUST be the first one. */
36 ir_mode *ls_mode; /**< Stores the "input" mode */
37 struct amd64_attr_data_bitfield {
38 unsigned ins_permuted : 1; /**< inputs of node have been permuted
39 (for commutative nodes) */
40 unsigned cmp_unsigned : 1; /**< compare should be unsigned */
42 struct amd64_attr_extended {
43 ir_relation relation; /**< type of compare operation >*/
44 unsigned imm_value; /**< immediate value to use >*/
48 struct amd64_SymConst_attr_t
55 #define CAST_AMD64_ATTR(type,ptr) ((type *)(ptr))
56 #define CONST_CAST_AMD64_ATTR(type,ptr) ((const type *)(ptr))