X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fbe%2Fbeblocksched.c;h=38fc4def5e6fc30fc74cb495a82399d4c4a7dde4;hb=a9eee95c42def4095dad5214b493aa0e3ab5a1f7;hp=953ca6dcbfb7e621ed15a496864f169fb798711a;hpb=b1ac1ed940d29350a6e64266856affac026c8da1;p=libfirm diff --git a/ir/be/beblocksched.c b/ir/be/beblocksched.c index 953ca6dcb..38fc4def5 100644 --- a/ir/be/beblocksched.c +++ b/ir/be/beblocksched.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 1995-2007 University of Karlsruhe. All right reserved. + * Copyright (C) 1995-2008 University of Karlsruhe. All right reserved. * * This file is part of libFirm. * @@ -59,9 +59,8 @@ #include "bemodule.h" #include "be.h" -#include -#include -#include +#include "lc_opts.h" +#include "lc_opts_enum.h" #ifdef WITH_ILP #include @@ -147,8 +146,10 @@ static void collect_egde_frequency(ir_node *block, void *data) arity = get_Block_n_cfgpreds(block); if (arity == 0) { - assert(block == get_irg_start_block(env->irg)); - /* must be the start block, nothing to do here */ + assert(block == get_irg_start_block(env->irg) + || block == get_irg_end_block(env->irg)); + /* must be the start block (or end-block for endless loops), nothing to + * do here */ return; } else if (arity == 1) { edge.block = block; @@ -360,7 +361,7 @@ static blocksched_entry_t *finish_block_schedule(blocksched_env_t *env) ir_node *startblock = get_irg_start_block(irg); blocksched_entry_t *entry = get_irn_link(startblock); - set_using_visited(irg); + set_using_irn_visited(irg); inc_irg_visited(irg); env->worklist = new_pdeq(); @@ -368,7 +369,7 @@ static blocksched_entry_t *finish_block_schedule(blocksched_env_t *env) assert(pdeq_empty(env->worklist)); del_pdeq(env->worklist); - clear_using_visited(irg); + clear_using_irn_visited(irg); return entry; } @@ -712,7 +713,7 @@ static ir_node **create_extbb_block_schedule(ir_graph *irg, ir_exec_freq *execfr list.n_blks = 0; set_using_irn_link(irg); - set_using_visited(irg); + set_using_irn_visited(irg); inc_irg_block_visited(irg); create_block_list(get_irg_start_block(irg), &list); @@ -726,7 +727,7 @@ static ir_node **create_extbb_block_schedule(ir_graph *irg, ir_exec_freq *execfr } clear_using_irn_link(irg); - clear_using_visited(irg); + clear_using_irn_visited(irg); return blk_list; }