improve comments, remove unnecessary test
[libfirm] / ir / ir / irnode.c
index 2548b17..2666aa9 100644 (file)
@@ -1430,14 +1430,14 @@ set_Builtin_param(ir_node *node, int pos, ir_node *param) {
 ir_type *
 get_Builtin_type(ir_node *node) {
        assert(is_Builtin(node));
-       return node->attr.builtin.builtin_tp = skip_tid(node->attr.builtin.builtin_tp);
+       return node->attr.builtin.type = skip_tid(node->attr.builtin.type);
 }
 
 void
 set_Builtin_type(ir_node *node, ir_type *tp) {
        assert(is_Builtin(node));
        assert((get_unknown_type() == tp) || is_Method_type(tp));
-       node->attr.builtin.builtin_tp = tp;
+       node->attr.builtin.type = tp;
 }
 
 /* Returns a human readable string for the ir_builtin_kind. */
@@ -1447,7 +1447,7 @@ const char *get_builtin_kind_name(ir_builtin_kind kind) {
                X(ir_bk_trap);
                X(ir_bk_debugbreak);
                X(ir_bk_return_address);
-               X(ir_bk_frame_addess);
+               X(ir_bk_frame_address);
                X(ir_bk_prefetch);
                X(ir_bk_ffs);
                X(ir_bk_clz);
@@ -1587,6 +1587,7 @@ void set_##OP##_resmode(ir_node *node, ir_mode *mode) { \
 
 
 BINOP(Add)
+BINOP(Borrow)
 BINOP(Carry)
 BINOP(Sub)
 UNOP(Minus)
@@ -1614,6 +1615,11 @@ int get_Div_no_remainder(const ir_node *node) {
        return node->attr.divmod.no_remainder;
 }
 
+void set_Div_no_remainder(ir_node *node, int no_remainder) {
+       assert(is_Div(node));
+       node->attr.divmod.no_remainder = no_remainder;
+}
+
 int get_Conv_strict(const ir_node *node) {
        assert(is_Conv(node));
        return node->attr.conv.strict;
@@ -1733,11 +1739,6 @@ set_binop_right(ir_node *node, ir_node *right) {
        set_irn_n(node, node->op->op_index + 1, right);
 }
 
-int
-(is_Phi)(const ir_node *n) {
-       return _is_Phi(n);
-}
-
 int is_Phi0(const ir_node *n) {
        assert(n);
 
@@ -2352,12 +2353,12 @@ void set_CopyB_src(ir_node *node, ir_node *src) {
 
 ir_type *get_CopyB_type(ir_node *node) {
        assert(is_CopyB(node));
-       return node->attr.copyb.data_type = skip_tid(node->attr.copyb.data_type);
+       return node->attr.copyb.type = skip_tid(node->attr.copyb.type);
 }
 
 void set_CopyB_type(ir_node *node, ir_type *data_type) {
        assert(is_CopyB(node) && data_type);
-       node->attr.copyb.data_type = data_type;
+       node->attr.copyb.type = data_type;
 }
 
 
@@ -2684,310 +2685,22 @@ void skip_Id_and_store(ir_node **node) {
        *node = skip_Id(n);
 }
 
-int
-(is_Bad)(const ir_node *node) {
-       return _is_Bad(node);
-}
-
-int
-(is_NoMem)(const ir_node *node) {
-       return _is_NoMem(node);
-}
-
-int
-(is_Minus)(const ir_node *node) {
-       return _is_Minus(node);
-}
-
-int
-(is_Abs)(const ir_node *node) {
-       return _is_Abs(node);
-}
-
-int
-(is_Mod)(const ir_node *node) {
-       return _is_Mod(node);
-}
-
-int
-(is_Div)(const ir_node *node) {
-       return _is_Div(node);
-}
-
-int
-(is_DivMod)(const ir_node *node) {
-       return _is_DivMod(node);
-}
-
-int
-(is_Quot)(const ir_node *node) {
-       return _is_Quot(node);
-}
-
-int
-(is_Add)(const ir_node *node) {
-       return _is_Add(node);
-}
-
-int
-(is_Carry)(const ir_node *node) {
-       return _is_Carry(node);
-}
-
-int
-(is_And)(const ir_node *node) {
-       return _is_And(node);
-}
-
-int
-(is_Or)(const ir_node *node) {
-       return _is_Or(node);
-}
-
-int
-(is_Eor)(const ir_node *node) {
-       return _is_Eor(node);
-}
-
-int
-(is_Sub)(const ir_node *node) {
-       return _is_Sub(node);
-}
-
-int
-(is_Shl)(const ir_node *node) {
-       return _is_Shl(node);
-}
-
-int
-(is_Shr)(const ir_node *node) {
-       return _is_Shr(node);
-}
-
-int
-(is_Shrs)(const ir_node *node) {
-       return _is_Shrs(node);
-}
-
-int
-(is_Rotl)(const ir_node *node) {
-       return _is_Rotl(node);
-}
-
-int
-(is_Not)(const ir_node *node) {
-       return _is_Not(node);
-}
-
-int
-(is_Id)(const ir_node *node) {
-       return _is_Id(node);
-}
-
-int
-(is_Tuple)(const ir_node *node) {
-       return _is_Tuple(node);
-}
-
-int
-(is_Bound)(const ir_node *node) {
-       return _is_Bound(node);
-}
-
-int
-(is_Start)(const ir_node *node) {
-  return _is_Start(node);
-}
-
-int
-(is_End)(const ir_node *node) {
-       return _is_End(node);
-}
-
-int
-(is_Const)(const ir_node *node) {
-       return _is_Const(node);
-}
-
-int
-(is_Conv)(const ir_node *node) {
-       return _is_Conv(node);
-}
-
 int
 (is_strictConv)(const ir_node *node) {
        return _is_strictConv(node);
 }
 
-int
-(is_Cast)(const ir_node *node) {
-       return _is_Cast(node);
-}
-
 int
 (is_no_Block)(const ir_node *node) {
        return _is_no_Block(node);
 }
 
-int
-(is_Block)(const ir_node *node) {
-       return _is_Block(node);
-}
-
-/* returns true if node is an Unknown node. */
-int
-(is_Unknown)(const ir_node *node) {
-       return _is_Unknown(node);
-}
-
-/* returns true if node is a Return node. */
-int
-(is_Return)(const ir_node *node) {
-       return _is_Return(node);
-}
-
-/* returns true if node is a Call node. */
-int
-(is_Call)(const ir_node *node) {
-       return _is_Call(node);
-}
-
-/* returns true if node is a Builtin node. */
-int
-(is_Builtin)(const ir_node *node) {
-       return _is_Builtin(node);
-}
-
-/* returns true if node is a CallBegin node. */
-int
-(is_CallBegin)(const ir_node *node) {
-       return _is_CallBegin(node);
-}
-
-/* returns true if node is a Sel node. */
-int
-(is_Sel)(const ir_node *node) {
-       return _is_Sel(node);
-}
-
-/* returns true if node is a Mux node. */
-int
-(is_Mux)(const ir_node *node) {
-       return _is_Mux(node);
-}
-
-/* returns true if node is a Load node. */
-int
-(is_Load)(const ir_node *node) {
-       return _is_Load(node);
-}
-
-/* returns true if node is a Load node. */
-int
-(is_Store)(const ir_node *node) {
-       return _is_Store(node);
-}
-
-/* returns true if node is a Sync node. */
-int
-(is_Sync)(const ir_node *node) {
-       return _is_Sync(node);
-}
-
-/* Returns true if node is a Confirm node. */
-int
-(is_Confirm)(const ir_node *node) {
-       return _is_Confirm(node);
-}
-
-/* Returns true if node is a Pin node. */
-int
-(is_Pin)(const ir_node *node) {
-       return _is_Pin(node);
-}
-
-/* Returns true if node is a SymConst node. */
-int
-(is_SymConst)(const ir_node *node) {
-       return _is_SymConst(node);
-}
-
 /* Returns true if node is a SymConst node with kind symconst_addr_ent. */
 int
 (is_SymConst_addr_ent)(const ir_node *node) {
        return _is_SymConst_addr_ent(node);
 }
 
-/* Returns true if node is a Cond node. */
-int
-(is_Cond)(const ir_node *node) {
-       return _is_Cond(node);
-}
-
-int
-(is_CopyB)(const ir_node *node) {
-       return _is_CopyB(node);
-}
-
-/* returns true if node is a Cmp node. */
-int
-(is_Cmp)(const ir_node *node) {
-       return _is_Cmp(node);
-}
-
-/* returns true if node is an Alloc node. */
-int
-(is_Alloc)(const ir_node *node) {
-       return _is_Alloc(node);
-}
-
-/* returns true if node is a Free node. */
-int
-(is_Free)(const ir_node *node) {
-       return _is_Free(node);
-}
-
-/* returns true if a node is a Jmp node. */
-int
-(is_Jmp)(const ir_node *node) {
-       return _is_Jmp(node);
-}
-
-/* returns true if a node is a IJmp node. */
-int
-(is_IJmp)(const ir_node *node) {
-       return _is_IJmp(node);
-}
-
-/* returns true if a node is a Raise node. */
-int
-(is_Raise)(const ir_node *node) {
-       return _is_Raise(node);
-}
-
-/* returns true if a node is an ASM node. */
-int
-(is_ASM)(const ir_node *node) {
-       return _is_ASM(node);
-}
-
-/* returns true if a node is an Dummy node. */
-int
-(is_Dummy)(const ir_node *node) {
-       return _is_Dummy(node);
-}
-
-int
-(is_Proj)(const ir_node *node) {
-       return _is_Proj(node);
-}
-
-/* Returns true if node is a Filter node. */
-int
-(is_Filter)(const ir_node *node) {
-       return _is_Filter(node);
-}
-
 /* Returns true if the operation manipulates control flow. */
 int is_cfop(const ir_node *node) {
        return is_op_cfopcode(get_irn_op(node));
@@ -3220,30 +2933,6 @@ dbg_info *(get_irn_dbg_info)(const ir_node *n) {
        return _get_irn_dbg_info(n);
 }
 
-#if 0 /* allow the global pointer */
-
-/* checks whether a node represents a global address */
-int is_Global(const ir_node *node) {
-       ir_node *ptr;
-
-       if (is_SymConst_addr_ent(node))
-               return 1;
-       if (! is_Sel(node))
-               return 0;
-
-       ptr = get_Sel_ptr(node);
-       return is_globals_pointer(ptr) != NULL;
-}
-
-/* returns the entity of a global address */
-ir_entity *get_Global_entity(const ir_node *node) {
-       if (is_SymConst(node))
-               return get_SymConst_entity(node);
-       else
-               return get_Sel_entity(node);
-}
-#else
-
 /* checks whether a node represents a global address */
 int is_Global(const ir_node *node) {
        return is_SymConst_addr_ent(node);
@@ -3253,7 +2942,6 @@ int is_Global(const ir_node *node) {
 ir_entity *get_Global_entity(const ir_node *node) {
        return get_SymConst_entity(node);
 }
-#endif
 
 /*
  * Calculate a hash value of a node.
@@ -3277,3 +2965,6 @@ unsigned firm_default_hash(const ir_node *node) {
 
        return h;
 }  /* firm_default_hash */
+
+/* include generated code */
+#include "gen_irnode.c.inl"