/*
- * Copyright (C) 1995-2008 University of Karlsruhe. All right reserved.
- *
* This file is part of libFirm.
- *
- * This file may be distributed and/or modified under the terms of the
- * GNU General Public License version 2 as published by the Free Software
- * Foundation and appearing in the file LICENSE.GPL included in the
- * packaging of this file.
- *
- * Licensees holding valid libFirm Professional Edition licenses may use
- * this file in accordance with the libFirm Commercial License.
- * Agreement provided with the Software.
- *
- * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
- * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE.
+ * Copyright (C) 2012 University of Karlsruhe.
*/
/**
#include "firm_types.h"
#include "bitset.h"
-#include "obst.h"
#include "bearch.h"
#include "bechordal.h"
typedef struct be_insn_t be_insn_t;
struct be_operand_t {
- ir_node *irn; /**< Firm node of the insn this operand belongs to */
- ir_node *carrier; /**< node representing the operand value (Proj or the node itself for defs, the used value for uses) */
- be_operand_t *partner; /**< used in bechordal later... (TODO what does it do?) */
- const bitset_t *regs; /**< admissible register bitset */
- int pos; /**< pos of the operand (0 to n are inputs, -1 to -n are outputs) */
- const arch_register_req_t *req; /**< register constraints for the carrier node */
- unsigned has_constraints : 1; /**< the carrier node has register constraints (the constraint type is limited) */
+ ir_node *carrier; /**< node representing the operand value (Proj or the node itself for defs, the used value for uses) */
+ be_operand_t *partner; /**< used in bechordal later... (TODO what does it do?) */
+ unsigned const *regs; /**< admissible register bitset */
};
struct be_insn_t {
- be_operand_t *ops; /**< the values used and defined by the insn */
- int n_ops; /**< length of the ops array */
- int use_start; /**< entries [0-use_start) in ops are defs,
- [use_start-n_ops) uses */
- ir_node *irn; /**< ir_node of the instruction */
- unsigned has_constraints : 1; /**< in_constraints or out_constraints true */
+ be_operand_t *ops; /**< the values used and defined by the insn */
+ int n_ops; /**< length of the ops array */
+ int use_start; /**< entries [0-use_start) in ops are defs,
+ [use_start-n_ops) uses */
+ ir_node *irn; /**< ir_node of the instruction */
};
/**
*
* @return the be_insn for the IR node
*/
-be_insn_t *be_scan_insn(be_chordal_env_t const *env, ir_node *irn);
+be_insn_t *be_scan_insn(be_chordal_env_t *env, ir_node *irn);
#endif /* FIRM_BE_BEINSN_T_H */