X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fir%2Firopt_t.h;h=93267ae619b7e1152acc6cfa2dde0b5c4dbddbc9;hb=b597c7fd473086ca6374b2abbdf129f595c156d0;hp=5e95c801dd4fb803412767dd1a8df6597a071bd5;hpb=0c8ec6efe050e425be99454315e4f58b0976a38a;p=libfirm diff --git a/ir/ir/iropt_t.h b/ir/ir/iropt_t.h index 5e95c801d..93267ae61 100644 --- a/ir/ir/iropt_t.h +++ b/ir/ir/iropt_t.h @@ -26,22 +26,28 @@ #ifndef FIRM_IR_IROPT_T_H #define FIRM_IR_IROPT_T_H +#include "irop_t.h" #include "iropt.h" #include "irnode_t.h" #include "pset.h" #include "tv.h" -ir_node *equivalent_node(ir_node *n); - /** * Calculate a hash value of a node. - * The hash value is calculated from the nodes predecessors. - * Special handling for Const and SymConst nodes (these don't have predecessors). * * @param node The IR-node */ unsigned ir_node_hash(const ir_node *node); +/** + * equivalent_node() returns a node equivalent to input n. It skips all nodes that + * perform no actual computation, as, e.g., the Id nodes. It does not create + * new nodes. It is therefore safe to free n if the node returned is not n. + * If a node returns a Tuple we can not just skip it. If the size of the + * in array fits, we transform n into a tuple (e.g., Div). + */ +ir_node *equivalent_node(ir_node *n); + /** * Creates a new value table used for storing CSE identities. * The value table is used to identify common expressions.