X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fbe%2Fbera.h;h=0664a6bc91fc840594bab1cc7336b70ebecaab74;hb=6866751667f73eeec02ac8275f1011f9e424cce2;hp=92e8cf94a3928db057319f29050d734a07561707;hpb=2711d82f513508a04b51d446c5426da425a3882b;p=libfirm diff --git a/ir/be/bera.h b/ir/be/bera.h index 92e8cf94a..0664a6bc9 100644 --- a/ir/be/bera.h +++ b/ir/be/bera.h @@ -7,7 +7,38 @@ #ifndef _BERA_H #define _BERA_H -#include "irnode.h" +#include "firm_config.h" + +#ifdef WITH_LIBCORE +#include +#include +#endif + +#include "firm_types.h" + +#include "be.h" + +typedef struct { + lc_timer_t *t_prolog; /**< timer for prolog */ + lc_timer_t *t_epilog; /**< timer for epilog */ + lc_timer_t *t_live; /**< timer for liveness calculation */ + lc_timer_t *t_spill; /**< timer for spilling */ + lc_timer_t *t_color; /**< timer for graph coloring */ + lc_timer_t *t_ifg; /**< timer for building interference graph */ + lc_timer_t *t_copymin; /**< timer for copy minimization */ + lc_timer_t *t_ssa; /**< timer for ssa destruction */ + lc_timer_t *t_verify; /**< timer for verification runs */ + lc_timer_t *t_other; /**< timer for remaining stuff */ +} be_ra_timer_t; + +typedef struct { +#ifdef WITH_LIBCORE + void (*register_options)(lc_opt_entry_t *grp); +#endif + be_ra_timer_t *(*allocate)(const be_irg_t *bi); +} be_ra_t; + + /** * Check, if two values interfere. @@ -19,7 +50,7 @@ int values_interfere(const ir_node *a, const ir_node *b); /** * Check, if a value dominates the other one. - * Note, that this function also consideres the schedule and does thus + * Note, that this function also considers the schedule and does thus * more than block_dominates(). * * @param a The first. @@ -28,5 +59,4 @@ int values_interfere(const ir_node *a, const ir_node *b); */ int value_dominates(const ir_node *a, const ir_node *b); - #endif /* _BERA_H */