X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fir%2Firphase.c;h=44e1841ff935a2891fa61ea2382ecdaf06c2448d;hb=e1c33a238578342a072e1c95ff12eefe6d0acd37;hp=92c1fe965264e864f5c1406c42130e2ea80ae3b0;hpb=84cf245c49c98c666ab459d17f52fcadcfd0c674;p=libfirm diff --git a/ir/ir/irphase.c b/ir/ir/irphase.c index 92c1fe965..44e1841ff 100644 --- a/ir/ir/irphase.c +++ b/ir/ir/irphase.c @@ -18,25 +18,19 @@ #include "irnode_t.h" #include "irphase_t.h" -phase_t *phase_new(const char *name, ir_graph *irg, size_t data_size, unsigned growth_factor, - phase_irn_data_init_t *data_init, void *priv) +phase_t *phase_init(phase_t *ph, const char *name, ir_graph *irg, unsigned growth_factor, phase_irn_data_init_t *data_init) { - phase_t *ph; - assert(growth_factor >= 1.0 && "growth factor must greater or equal to 1.0"); - - ph = xmalloc(sizeof(ph[0])); + assert(data_init && "You must provide a data constructor"); obstack_init(&ph->obst); ph->name = name; ph->growth_factor = growth_factor; ph->data_init = data_init; - ph->data_size = data_size; ph->irg = irg; ph->n_data_ptr = 0; ph->data_ptr = NULL; - ph->priv = priv; return ph; } @@ -44,7 +38,8 @@ phase_t *phase_new(const char *name, ir_graph *irg, size_t data_size, unsigned g void phase_free(phase_t *phase) { obstack_free(&phase->obst, NULL); - xfree(phase->data_ptr); + if(phase->data_ptr) + xfree(phase->data_ptr); } phase_stat_t *phase_stat(const phase_t *phase, phase_stat_t *stat) @@ -57,9 +52,21 @@ phase_stat_t *phase_stat(const phase_t *phase, phase_stat_t *stat) for(i = 0, n = phase->n_data_ptr; i < n; ++i) { if(phase->data_ptr[i] != NULL) { stat->node_slots_used++; - stat->node_data_bytes += phase->data_size; } } stat->overall_bytes = stat->node_map_bytes + obstack_memory_used(&((phase_t *)phase)->obst); return stat; } + +void phase_reinit_irn_data(phase_t *phase) +{ + int i, n; + + if(!phase->data_init) + return; + + for(i = 0, n = phase->n_data_ptr; i < n; ++i) { + if(phase->data_ptr[i]) + phase->data_init(phase, NULL, phase->data_ptr[i]); + } +}