X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fbe%2Fbeifg_t.h;h=a1fbc5c6c4921bb92b7a8e61f2203f68f51a6687;hb=48f0393daa5d5a14ed7e3e32ee2b090759c9371e;hp=5e3f085871e479e26d7a37ea23db3c0b2a84aeee;hpb=4c66ebcce62ceffb68a891142dd309429e03351a;p=libfirm diff --git a/ir/be/beifg_t.h b/ir/be/beifg_t.h index 5e3f08587..a1fbc5c6c 100644 --- a/ir/be/beifg_t.h +++ b/ir/be/beifg_t.h @@ -11,35 +11,54 @@ #include "beifg.h" struct _be_ifg_impl_t { - size_t iter_size; + size_t nodes_iter_size; + size_t neighbours_iter_size; + size_t cliques_iter_size; void (*free)(void *self); int (*connected)(const void *self, const ir_node *a, const ir_node *b); ir_node *(*neighbours_begin)(const void *self, void *iter, const ir_node *irn); ir_node *(*neighbours_next)(const void *self, void *iter); + void (*neighbours_break)(const void *self, void *iter); ir_node *(*nodes_begin)(const void *self, void *iter); ir_node *(*nodes_next)(const void *self, void *iter); + void (*nodes_break)(const void *self, void *iter); + + int (*cliques_begin)(const void *self, void *iter, ir_node **buf); + int (*cliques_next)(const void *self, void *iter); + void (*cliques_break)(const void *self, void *iter); int (*degree)(const void *self, const ir_node *irn); }; struct _be_ifg_t { const be_ifg_impl_t *impl; + const be_chordal_env_t *env; }; #ifdef _BE_IFG_USE_MACROS -#define be_ifg_iter_size(self) ((self)->impl->iter_size) +#define be_ifg_nodes_iter_size(self) ((self)->impl->nodes_iter_size) +#define be_ifg_neighbours_iter_size(self) ((self)->impl->neighbours_iter_size) +#define be_ifg_cliques_iter_size(self) ((self)->impl->cliques_iter_size) + #define be_ifg_free(self) ((self)->impl->free(self)) #define be_ifg_connected(self,a,b) ((self)->impl->connected(self, a, b)) #define be_ifg_neighbours_begin(self, iter, irn) ((self)->impl->neighbours_begin(self, iter, irn)) #define be_ifg_neighbours_next(self, iter) ((self)->impl->neighbours_next(self, iter)) +#define be_ifg_neighbours_break(self, iter) ((self)->impl->neighbours_break(self, iter)) #define be_ifg_nodes_begin(self, iter) ((self)->impl->nodes_begin(self, iter)) #define be_ifg_nodes_next(self, iter) ((self)->impl->nodes_next(self, iter)) +#define be_ifg_nodes_break(self, iter) ((self)->impl->nodes_break(self, iter)) +#define be_ifg_cliques_begin(self, iter, buf) ((self)->impl->cliques_begin(self, iter, buf)) +#define be_ifg_cliques_next(self, iter) ((self)->impl->cliques_next(self, iter)) +#define be_ifg_cliques_break(self, iter) ((self)->impl->cliques_break(self, iter)) #define be_ifg_degree(self,irn) ((self)->impl->degree(self, irn)) #endif +void be_ifg_check(const be_ifg_t *ifg); + #endif /*_BEIFG_T_H_*/