Added a dom-tree-upwards search
authorDaniel Grund <grund@cs.uni-saarland.de>
Wed, 25 Jan 2006 17:59:10 +0000 (17:59 +0000)
committerDaniel Grund <grund@cs.uni-saarland.de>
Wed, 25 Jan 2006 17:59:10 +0000 (17:59 +0000)
ir/be/beutil.c
ir/be/beutil.h

index 97e1268..d1d53c4 100644 (file)
@@ -7,6 +7,7 @@
 #include "irgraph.h"
 #include "irgwalk.h"
 #include "irdump_t.h"
+#include "irdom_t.h"
 #include "ircons.h"
 #include "iropt.h"
 #include "irgopt.h"
@@ -160,3 +161,20 @@ void be_collect_phis(ir_graph *irg)
 {
        irg_walk_graph(irg, collect_phis, NULL, NULL);
 }
+
+
+ir_node *dom_up_search(pset *accept, ir_node *start_point_exclusive) {
+       ir_node *irn, *idom;
+
+       /* search the current block */
+       for (irn=sched_prev(start_point_exclusive); irn; irn=sched_prev(irn))
+               if (pset_find_ptr(accept, irn))
+                       return irn;
+
+       idom = get_Block_idom(get_nodes_block(start_point_exclusive));
+
+       if (idom)
+               return dom_up_search(accept, idom); /* continue search in idom-block */
+       else
+               return NULL; /* this was the start block and we did not find an acceptable irn */
+}
index 8df13b8..84a59ed 100644 (file)
@@ -6,6 +6,7 @@
 
 #include <stdio.h>
 
+#include "pset.h"
 #include "irnode.h"
 #include "bearch.h"
 
@@ -94,3 +95,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);