X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fbe%2Fbeutil.h;h=122e217fc0238dcf9d40fad23c4dd01ccfdfffa6;hb=e6ad8ee4680a88db8652483c2c6f3124f3d9a888;hp=1f6e7d3f4b481031064c88b7687cb967dfa644c3;hpb=e91c1db21d945d622be14e27bd4c6c405c042723;p=libfirm diff --git a/ir/be/beutil.h b/ir/be/beutil.h index 1f6e7d3f4..122e217fc 100644 --- a/ir/be/beutil.h +++ b/ir/be/beutil.h @@ -2,13 +2,21 @@ #ifndef _BEUTIL_H #define _BEUTIL_H +#include "firm_config.h" + #include +#include "pset.h" #include "irnode.h" -#include "config.h" - #include "bearch.h" +/** + * Get an empty set. + * This function always returns the same set. + */ +pset *be_empty_set(void); + + /** Undefine this to disable debugging mode. */ #define BE_DEBUG 1 @@ -21,7 +29,7 @@ */ static INLINE const ir_node *get_block(const ir_node *irn) { - return is_Block(irn) ? irn : get_nodes_block(irn); + return is_Block(irn) ? irn : get_nodes_block(irn); } static INLINE int is_firm_be_mode(const ir_mode *mode) @@ -94,3 +102,10 @@ static INLINE FILE *ffopen(const char *base, const char *ext, const char *mode) void dump_ir_block_graph_sched(ir_graph *irg, const char *suffix); #endif + +/** + * Search for an irn in @p accept. + * The search is started at @p start_point_exclusive and continues upwards the dom-tree + * @return The first node out of accept if found. Else NULL is returned. + */ +ir_node *dom_up_search(pset *accept, ir_node *start_point_exclusive);