X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;ds=sidebyside;f=ir%2Fbe%2Fbemodule.c;h=3fd65afd674e04de7bc880692e3ac2b6254064b9;hb=2be6077d3c0d1cdc8fad965f1857ac3a08c632aa;hp=5fad5159fd000cd81d45c03d621aa5d924db8939;hpb=29439abe8fe6f9d4e7bb754cb3774e81929e9fec;p=libfirm diff --git a/ir/be/bemodule.c b/ir/be/bemodule.c index 5fad5159f..3fd65afd6 100644 --- a/ir/be/bemodule.c +++ b/ir/be/bemodule.c @@ -1,20 +1,6 @@ /* - * Copyright (C) 1995-2007 University of Karlsruhe. All right reserved. - * * This file is part of libFirm. - * - * This file may be distributed and/or modified under the terms of the - * GNU General Public License version 2 as published by the Free Software - * Foundation and appearing in the file LICENSE.GPL included in the - * packaging of this file. - * - * Licensees holding valid libFirm Professional Edition licenses may use - * this file in accordance with the libFirm Commercial License. - * Agreement provided with the Software. - * - * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE - * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR - * PURPOSE. + * Copyright (C) 2012 University of Karlsruhe. */ /** @@ -22,53 +8,60 @@ * @brief Backend module interface. * @author Matthias Braun * @date 29.09.2005 - * @version $Id$ */ - -#include "firm_config.h" +#include "config.h" #include +#include #include "bemodule_t.h" #include "xmalloc.h" +void be_init_abi(void); void be_init_sched(void); void be_init_blocksched(void); void be_init_spill(void); void be_init_spilloptions(void); void be_init_listsched(void); -void be_init_schedrss(void); +void be_init_sched_rand(void); +void be_init_sched_normal(void); +void be_init_sched_regpress(void); +void be_init_sched_trace(void); +void be_init_sched_trivial(void); void be_init_chordal(void); +void be_init_pbqp_coloring(void); void be_init_chordal_main(void); -void be_init_copycoal(void); +void be_init_chordal_common(void); +void be_init_copyopt(void); +void be_init_copyheur(void); void be_init_copyheur2(void); -void be_init_copyheur3(void); void be_init_copyheur4(void); -void be_init_copyheur5(void); +void be_init_copyilp2(void); +void be_init_copynone(void); void be_init_copystat(void); void be_init_daemelspill(void); +void be_init_dwarf(void); void be_init_arch_ia32(void); -void be_init_arch_ppc32(void); -void be_init_arch_mips(void); void be_init_arch_arm(void); +void be_init_arch_amd64(void); void be_init_arch_sta(void); +void be_init_arch_sparc(void); void be_init_arch_TEMPLATE(void); -void be_init_ilpsched(void); void be_init_copyilp(void); -void be_init_javacoal(void); void be_init_peephole(void); void be_init_ra(void); void be_init_spillbelady(void); -void be_init_spillbelady2(void); void be_init_ssaconstr(void); -void be_init_ifg(void); +void be_init_pref_alloc(void); void be_init_irgmod(void); void be_init_loopana(void); void be_init_spillslots(void); void be_init_live(void); void be_init_state(void); +void be_init_pbqp(void); void be_quit_copystat(void); +void be_quit_pbqp(void); /** * Driver for module initialization. @@ -76,12 +69,13 @@ void be_quit_copystat(void); */ void be_init_modules(void) { - static int run_once = 0; + static bool run_once = false; if (run_once) return; - run_once = 1; + run_once = true; + be_init_abi(); be_init_irgmod(); be_init_loopana(); be_init_live(); @@ -90,48 +84,53 @@ void be_init_modules(void) be_init_blocksched(); be_init_spill(); be_init_spilloptions(); + be_init_listsched(); - be_init_schedrss(); + be_init_sched_normal(); + be_init_sched_trace(); + be_init_sched_regpress(); + be_init_sched_rand(); + be_init_sched_trivial(); + be_init_chordal_main(); + be_init_chordal_common(); be_init_chordal(); - be_init_copycoal(); - be_init_copyheur2(); + be_init_copyopt(); be_init_copyheur4(); - be_init_copyheur5(); + be_init_copyheur(); + be_init_copyheur2(); + be_init_copyilp2(); + be_init_pbqp_coloring(); + be_init_copynone(); be_init_copystat(); be_init_peephole(); be_init_ra(); be_init_spillbelady(); - be_init_spillbelady2(); be_init_daemelspill(); + be_init_dwarf(); be_init_ssaconstr(); + be_init_pref_alloc(); be_init_state(); - be_init_ifg(); be_init_arch_ia32(); - be_init_arch_ppc32(); - be_init_arch_mips(); be_init_arch_arm(); - /* do NOT call be_init_arch_TEMPLATE() here, this is NOT a backend :-) */ + be_init_arch_sparc(); + be_init_arch_amd64(); + be_init_arch_TEMPLATE(); -#ifdef WITH_ILP - be_init_ilpsched(); be_init_copyilp(); -#endif /* WITH_ILP */ - -#ifdef WITH_JVM - be_init_copyheur3(); - be_init_javacoal(); -#endif /* WITH_JVM */ -#if PLUGIN_IR_BE_STA - be_init_arch_sta(); -#endif /* PLUGIN_IR_BE_STA */ +#ifdef FIRM_GRGEN_BE + be_init_pbqp(); +#endif } void be_quit_modules(void) { be_quit_copystat(); +#ifdef FIRM_GRGEN_BE + be_quit_pbqp(); +#endif } //--------------------------------------------------------------------------- @@ -148,7 +147,7 @@ typedef struct module_opt_data_t { static int set_opt_module(const char *name, lc_opt_type_t type, void *data, size_t length, ...) { - module_opt_data_t *moddata = data; + module_opt_data_t *moddata = (module_opt_data_t*)data; int res = 0; va_list args; const char *opt; @@ -174,10 +173,10 @@ static int set_opt_module(const char *name, lc_opt_type_t type, void *data, /** * Dump the names of all registered module options. */ -int dump_opt_module(char *buf, size_t buflen, const char *name, - lc_opt_type_t type, void *data, size_t length) +static int dump_opt_module(char *buf, size_t buflen, const char *name, + lc_opt_type_t type, void *data, size_t length) { - module_opt_data_t *moddata = data; + module_opt_data_t *moddata = (module_opt_data_t*)data; const be_module_list_entry_t *module; (void) name; (void) type; @@ -197,10 +196,10 @@ int dump_opt_module(char *buf, size_t buflen, const char *name, /** * Dump the values of all register module options. */ -int dump_opt_module_vals(char *buf, size_t buflen, const char *name, - lc_opt_type_t type, void *data, size_t len) +static int dump_opt_module_vals(char *buf, size_t buflen, const char *name, + lc_opt_type_t type, void *data, size_t len) { - module_opt_data_t *moddata = data; + module_opt_data_t *moddata = (module_opt_data_t*)data; char *p = buf; const be_module_list_entry_t *module; (void) name; @@ -208,7 +207,7 @@ int dump_opt_module_vals(char *buf, size_t buflen, const char *name, (void) len; for (module = *(moddata->list_head); module != NULL; module = module->next) { - size_t len = strlen(module->name); + size_t name_len = strlen(module->name); if (module != *(moddata->list_head)) { p = strncat(p, ", ", buflen - 1); @@ -217,10 +216,10 @@ int dump_opt_module_vals(char *buf, size_t buflen, const char *name, p = strncat(p, module->name, buflen - 1); - if (len >= buflen) + if (name_len >= buflen) break; - buflen -= len; + buflen -= name_len; } return strlen(buf); @@ -232,9 +231,7 @@ int dump_opt_module_vals(char *buf, size_t buflen, const char *name, void be_add_module_to_list(be_module_list_entry_t **list_head, const char *name, void *module) { - be_module_list_entry_t *entry; - - entry = xmalloc(sizeof(entry[0])); + be_module_list_entry_t *entry = XMALLOC(be_module_list_entry_t); entry->name = name; entry->data = module; entry->next = *list_head; @@ -249,9 +246,7 @@ void be_add_module_list_opt(lc_opt_entry_t *grp, const char *name, be_module_list_entry_t * const * list_head, void **var) { - module_opt_data_t *moddata; - - moddata = xmalloc(sizeof(moddata[0])); + module_opt_data_t *moddata = XMALLOC(module_opt_data_t); moddata->var = var; moddata->list_head = list_head;