summaryrefslogtreecommitdiffhomepage
path: root/ir/be/bera.h
diff options
context:
space:
mode:
authorMatthias Braun <matze@braunis.de>2006-12-21 15:55:08 +0100
committerMatthias Braun <matze@braunis.de>2006-12-21 15:55:08 +0100
commitda48a7f7266cfe6274fc4d159d63bba245724222 (patch)
treebc526cd9b9457d6374857b4c07ab0d831df75f95 /ir/be/bera.h
parent6d2368b06b89d3d1bc34e04588e32b658f4c5f8d (diff)
- All backend modules use module constructors for registering their options now
- New register allocator modules can register themselfes in a list now, the same will be done for spillers, copy coalescers, architectures soon
Diffstat (limited to 'ir/be/bera.h')
-rw-r--r--ir/be/bera.h13
1 files changed, 9 insertions, 4 deletions
diff --git a/ir/be/bera.h b/ir/be/bera.h
index 1b83e76..1ca7f64 100644
--- a/ir/be/bera.h
+++ b/ir/be/bera.h
@@ -10,7 +10,6 @@
#include "firm_config.h"
#ifdef WITH_LIBCORE
-#include <libcore/lc_opts.h>
#include <libcore/lc_timing.h>
#endif
@@ -19,6 +18,7 @@
#include "be.h"
#include "belive.h"
#include "beirg.h"
+#include "bemodule.h"
#ifdef WITH_LIBCORE
@@ -40,11 +40,16 @@ typedef void *be_ra_timer_t;
typedef void *lc_opt_entry_t;
#endif /* WITH_LIBCORE */
-typedef struct {
- void (*register_options)(lc_opt_entry_t *grp);
- be_ra_timer_t *(*allocate)(be_irg_t *bi);
+typedef struct be_ra_t {
+ void (*allocate)(be_irg_t *bi); /**< allocate registers on a graph */
} 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.