projects
/
libfirm
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fixed out-flags parsing
[libfirm]
/
ir
/
be
/
bera.h
diff --git
a/ir/be/bera.h
b/ir/be/bera.h
index
16419ad
..
9315f8d
100644
(file)
--- a/
ir/be/bera.h
+++ b/
ir/be/bera.h
@@
-10,7
+10,6
@@
#include "firm_config.h"
#ifdef WITH_LIBCORE
#include "firm_config.h"
#ifdef WITH_LIBCORE
-#include <libcore/lc_opts.h>
#include <libcore/lc_timing.h>
#endif
#include <libcore/lc_timing.h>
#endif
@@
-18,6
+17,10
@@
#include "be.h"
#include "belive.h"
#include "be.h"
#include "belive.h"
+#include "beirg.h"
+#include "bemodule.h"
+
+#ifdef WITH_LIBCORE
typedef struct {
lc_timer_t *t_prolog; /**< timer for prolog */
typedef struct {
lc_timer_t *t_prolog; /**< timer for prolog */
@@
-33,14
+36,22
@@
typedef struct {
lc_timer_t *t_other; /**< timer for remaining stuff */
} be_ra_timer_t;
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);
+extern be_ra_timer_t *global_ra_timer;
+#else
+typedef void *be_ra_timer_t;
+typedef void *lc_opt_entry_t;
+#endif /* WITH_LIBCORE */
+
+typedef struct be_ra_t {
+ void (*allocate)(be_irg_t *bi); /**< allocate registers on a graph */
} be_ra_t;
} be_ra_t;
+void be_register_allocator(const char *name, be_ra_t *allocator);
+/**
+ * Do register allocation with currently selected register allocator
+ */
+void be_allocate_registers(be_irg_t *birg);
/**
* Check, if two values interfere.
/**
* Check, if two values interfere.