X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fir%2Firprog.c;h=0200998a17551a8f9f5fa509902b66748d2d9d81;hb=a226465c4f00c94b3e94a7c717e04061625e7a33;hp=b0c2b637b3971a7aaf6a6073afed399915705aa9;hpb=a470a4b14b82b2f4eadf3b244fdfc622d10d5b2f;p=libfirm diff --git a/ir/ir/irprog.c b/ir/ir/irprog.c index b0c2b637b..0200998a1 100644 --- a/ir/ir/irprog.c +++ b/ir/ir/irprog.c @@ -58,7 +58,7 @@ ir_prog *new_ir_prog (void) { /* res->obst = (struct obstack *) xmalloc (sizeof (struct obstack)); */ res->graphs = NEW_ARR_F (ir_graph *, 1); res->types = NEW_ARR_F (type *, 1); - res->name = NULL; + res->name = new_id_from_str("no_name_set"); #ifdef DEBUG_libfirm res->max_node_nr = 0; @@ -72,11 +72,25 @@ ir_prog *new_ir_prog (void) { res->const_code_irg = new_const_code_irg(); + res->outs_state = no_outs; + res->ip_outedges = NULL; return res; } -/** Functions to access the fields of ir_prog **/ +/* frees all memory used by irp. Types in type list, irgs in irg + list and entities in global type must be freed by hand before. */ +void free_ir_prog() { + free_type(irp->glob_type); + /* @@@ * free_ir_graph(irp->const_code_irg); * ?? End has no in?? */ + DEL_ARR_F(irp->graphs); + DEL_ARR_F(irp->types); + + irp->kind = k_BAD; + irp->const_code_irg = NULL; +} + +/*- Functions to access the fields of ir_prog -*/ /* Access the main routine of the compiled program. */ @@ -176,7 +190,7 @@ int get_irp_new_node_nr() { } #endif -/** File name / executable name or the like **/ +/*- File name / executable name or the like -*/ void set_irp_prog_name(ident *name) { irp->name = name; } @@ -192,3 +206,19 @@ ir_graph *get_const_code_irg(void) { return irp->const_code_irg; } + +irg_outs_state get_irp_ip_outs_state() { + return irp->outs_state; +} +void set_irp_ip_outs_inconsistent() { + irp->outs_state = outs_inconsistent; +} +void set_irp_ip_outedges(ir_node ** ip_outedges) +{ + irp -> ip_outedges = ip_outedges; +} + +ir_node** get_irp_ip_outedges(void) +{ + return(irp -> ip_outedges); +}