/*
- * Copyright (C) 1995-2008 University of Karlsruhe. All right reserved.
+ * Copyright (C) 1995-2011 University of Karlsruhe. All right reserved.
*
* This file is part of libFirm.
*
set_Tuple_pred(call, pn_Call_X_regular, jmp);
set_Tuple_pred(call, pn_Call_X_except, bad);
set_Tuple_pred(call, pn_Call_T_result, tuple);
- set_Tuple_pred(call, pn_Call_P_value_res_base, bad);
for (i = 0; i < env->n_ress; ++i) {
ir_node *res = get_Return_res(p, i);
*/
void opt_tail_recursion(void)
{
- int i;
- int n_opt_applications = 0;
- ir_graph *irg;
+ size_t i, n;
+ size_t n_opt_applications = 0;
FIRM_DBG_REGISTER(dbg, "firm.opt.tailrec");
- for (i = get_irp_n_irgs() - 1; i >= 0; --i) {
- irg = get_irp_irg(i);
+ for (i = 0, n = get_irp_n_irgs(); i < n; ++i) {
+ ir_graph *irg = get_irp_irg(i);
ir_reserve_resources(irg, IR_RESOURCE_IRN_LINK);
if (opt_tail_rec_irg(irg))
ir_free_resources(irg, IR_RESOURCE_IRN_LINK);
}
- DB((dbg, LEVEL_1, "Performed tail recursion for %d of %d graphs\n",
+ DB((dbg, LEVEL_1, "Performed tail recursion for %zu of %zu graphs\n",
n_opt_applications, get_irp_n_irgs()));
}