- Fix some more stuff in ir_spec.py
[libfirm] / ir / ir / irnode_t.h
index 51df6b6..b824f61 100644 (file)
@@ -58,6 +58,7 @@ load_attr     *get_irn_load_attr     (ir_node *node);
 store_attr    *get_irn_store_attr    (ir_node *node);
 except_attr   *get_irn_except_attr   (ir_node *node);
 divmod_attr   *get_irn_divmod_attr   (ir_node *node);
+builtin_attr  *get_irn_builtin_attr  (ir_node *node);
 /** @} */
 
 /**
@@ -98,6 +99,14 @@ ir_op_ops *firm_set_default_get_type_attr(ir_opcode code, ir_op_ops *ops);
  */
 ir_op_ops *firm_set_default_get_entity_attr(ir_opcode code, ir_op_ops *ops);
 
+/**
+ * Returns an array with the predecessors of the Block. Depending on
+ * the implementation of the graph data structure this can be a copy of
+ * the internal representation of predecessors as well as the internal
+ * array itself. Therefore writing to this array might obstruct the IR.
+ */
+ir_node **get_Block_cfgpred_arr(ir_node *node);
+
 /*-------------------------------------------------------------------*/
 /*  These function are most used in libfirm.  Give them as static    */
 /*  functions so they can be inlined.                                */
@@ -496,6 +505,12 @@ _is_Carry(const ir_node *node) {
        return (_get_irn_op(node) == op_Carry);
 }
 
+static inline int
+_is_Borrow(const ir_node *node) {
+       assert(node);
+       return (_get_irn_op(node) == op_Borrow);
+}
+
 static inline int
 _is_And(const ir_node *node) {
        assert(node);
@@ -627,6 +642,12 @@ _is_Call(const ir_node *node) {
        return (_get_irn_op(node) == op_Call);
 }
 
+static inline int
+_is_Builtin(const ir_node *node) {
+       assert(node);
+       return (_get_irn_op(node) == op_Builtin);
+}
+
 static inline int
 _is_CallBegin(const ir_node *node) {
        assert(node);
@@ -746,6 +767,12 @@ _is_ASM(const ir_node *node) {
        return (_get_irn_op(node) == op_ASM);
 }
 
+static inline int
+_is_Dummy(const ir_node *node) {
+       assert(node);
+       return (_get_irn_op(node) == op_Dummy);
+}
+
 static inline int
 _is_Anchor(const ir_node *node) {
        return (_get_irn_op(node) == op_Anchor);
@@ -785,7 +812,7 @@ _get_Block_cfgpred(const ir_node *node, int pos) {
  *    We walk from the predecessor to the next pinned node
  *    (skip_Proj) and return the block that node is in.
  *  - If we encounter the Bad node, this function does not return
- *    Start, but the Bad node.
+ *    the Start block, but the Bad node.
  */
 static inline ir_node  *
 _get_Block_cfgpred_block(const ir_node *node, int pos) {
@@ -903,12 +930,12 @@ static inline int _is_irn_machine_user(const ir_node *node, unsigned n) {
 
 static inline cond_jmp_predicate _get_Cond_jmp_pred(const ir_node *node) {
        assert(_get_irn_op(node) == op_Cond);
-       return node->attr.cond.pred;
+       return node->attr.cond.jmp_pred;
 }
 
 static inline void _set_Cond_jmp_pred(ir_node *node, cond_jmp_predicate pred) {
        assert(_get_irn_op(node) == op_Cond);
-       node->attr.cond.pred = pred;
+       node->attr.cond.jmp_pred = pred;
 }
 
 static inline void *_get_irn_generic_attr(ir_node *node) {
@@ -1037,6 +1064,7 @@ _is_arg_Proj(const ir_node *node) {
 #define is_Unknown(node)                      _is_Unknown(node)
 #define is_Return(node)                       _is_Return(node)
 #define is_Call(node)                         _is_Call(node)
+#define is_Builtin(node)                      _is_Builtin(node)
 #define is_CallBegin(node)                    _is_CallBegin(node)
 #define is_Sel(node)                          _is_Sel(node)
 #define is_Mul(node)                          _is_Mul(node)
@@ -1057,6 +1085,7 @@ _is_arg_Proj(const ir_node *node) {
 #define is_IJmp(node)                         _is_IJmp(node)
 #define is_Raise(node)                        _is_Raise(node)
 #define is_ASM(node)                          _is_ASM(node)
+#define is_Dummy(node)                        _is_Dummy(node)
 #define is_Anchor(node)                       _is_Anchor(node)
 #define is_Bad(node)                          _is_Bad(node)
 #define is_NoMem(node)                        _is_NoMem(node)
@@ -1070,6 +1099,7 @@ _is_arg_Proj(const ir_node *node) {
 #define is_Quot(node)                         _is_Quot(node)
 #define is_Add(node)                          _is_Add(node)
 #define is_Carry(node)                        _is_Carry(node)
+#define is_Borrow(node)                       _is_Borrow(node)
 #define is_And(node)                          _is_And(node)
 #define is_Or(node)                           _is_Or(node)
 #define is_Eor(node)                          _is_Eor(node)