X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fbe%2Fbeutil.h;h=72a81fa054fb06bf4ad9037c85594d0a5498d52d;hb=39cb52264857d7c21c7141ba82bb55adaa78064d;hp=921f592c83e796764750e7fe93a40d1b02534e69;hpb=bb9f2e36362333c6635b89f5258171b06c786608;p=libfirm diff --git a/ir/be/beutil.h b/ir/be/beutil.h index 921f592c8..72a81fa05 100644 --- a/ir/be/beutil.h +++ b/ir/be/beutil.h @@ -31,7 +31,7 @@ #include "firm_types.h" #include "pset.h" -#include "bearch_t.h" +#include "bearch.h" #ifdef _MSC_VER typedef __int64 long64; @@ -58,9 +58,6 @@ typedef unsigned long long ulong64; */ pset *be_empty_set(void); -/** Undefine this to disable debugging mode. */ -#define BE_DEBUG 1 - /** * Convenient block getter. * Works also, if the given node is a block. @@ -78,11 +75,6 @@ static inline const ir_node *get_block_const(const ir_node *irn) return is_Block(irn) ? irn : get_nodes_block(irn); } -static inline int is_firm_be_mode(const ir_mode *mode) -{ - return mode_is_data(mode); -} - /** * Check, if a node produces or consumes a data value. * If it does, it is significant for scheduling and register allocation. @@ -96,13 +88,13 @@ static inline int is_data_node(const ir_node *irn) int i, n; /* If the node produces a data value, return immediately. */ - if (is_firm_be_mode(get_irn_mode(irn))) + if (mode_is_data(get_irn_mode(irn))) return 1; /* else check, if it takes a data value, if that is so, return */ for(i = 0, n = get_irn_arity(irn); i < n; ++i) { ir_node *op = get_irn_n(irn, i); - if (is_firm_be_mode(get_irn_mode(op))) + if (mode_is_data(get_irn_mode(op))) return 1; } @@ -150,6 +142,13 @@ unsigned get_num_reachable_nodes(ir_graph *irg); */ ir_node *be_get_Proj_for_pn(const ir_node *irn, long pn); +/** + * Returns an array (an ARR_F) of the programs blocks in reverse postorder + * (note: caller has to free the memory with DEL_ARR_F after use; + * of course you can use ARR_LEN on the array too.) + */ +ir_node **be_get_cfgpostorder(ir_graph *irg); + /** * Opens a file named base.ext with the mode mode. */