X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=testprograms%2Fwhile_example.c;h=0a86f073fe509fd59a6bb1d7aff811bb01c37f1a;hb=5470b27c201e3fd91f5af86753dd55806277edcb;hp=d7173f62f206097ee336f9e2cab19a432961fdf2;hpb=cbb9ee16c52724e2823d54cd3d17b50b6e6f218c;p=libfirm diff --git a/testprograms/while_example.c b/testprograms/while_example.c index d7173f62f..0a86f073f 100644 --- a/testprograms/while_example.c +++ b/testprograms/while_example.c @@ -6,6 +6,10 @@ ** testprogram. */ +# include +# include + +# include "irvrfy.h" # include "irdump.h" # include "firm.h" @@ -47,31 +51,34 @@ main(void) prim_t_int = new_type_primitive(id_from_str ("int", 3), mode_i); -#define METHODNAME "main" +#define METHODNAME "main_tp" #define NRARGS 1 -#define NRES 0 +#define NRES 1 proc_main = new_type_method(id_from_str(METHODNAME, strlen(METHODNAME)), NRARGS, NRES); set_method_param_type(proc_main, 0, prim_t_int); + set_method_res_type(proc_main, 0, prim_t_int); + - owner = new_type_class (id_from_str ("WHILE_EXAMPLE", 16)); - ent = new_entity (owner, id_from_str ("main", 4), proc_main); + owner = new_type_class (id_from_str ("WHILE_EXAMPLE", 13)); + ent = new_entity (owner, id_from_str ("main", strlen("main")), proc_main); /* Generates start and end blocks and nodes and a first, initial block */ irg = new_ir_graph (ent, 4); - /* Generate two constants */ - set_value (0, new_Proj(get_irg_args(irg), mode_I, 0)); - set_value (1, new_Const (mode_I, tarval_from_long (mode_I, 1))); + /* Generate two values */ + set_value (0, new_Proj(get_irg_args(irg), mode_i, 0)); + set_value (1, new_Const (mode_i, tarval_from_long (mode_i, 1))); x = new_Jmp(); mature_block (get_irg_current_block(irg)); + /* generate a block for the loop header and the conditional branch */ r = new_immBlock (); add_in_edge (r, x); - x = new_Cond (new_Proj(new_Cmp(new_Const (mode_I, tarval_from_long (mode_i, 0)), - new_Const (mode_I, tarval_from_long (mode_i, 0))), + x = new_Cond (new_Proj(new_Cmp(new_Const (mode_i, tarval_from_long (mode_i, 0)), + get_value(1, mode_i)), mode_b, Eq)); f = new_Proj (x, mode_X, 0); t = new_Proj (x, mode_X, 1); @@ -85,9 +92,9 @@ main(void) /* The code in the loop body, as we are dealing with local variables only the dataflow edges are manipulated. */ - set_value (2, get_value (0, mode_I)); - set_value (0, get_value (1, mode_I)); - set_value (1, get_value (2, mode_I)); + set_value (2, get_value (0, mode_i)); + set_value (0, get_value (1, mode_i)); + set_value (1, get_value (2, mode_i)); mature_block (b); mature_block (r); @@ -98,7 +105,7 @@ main(void) { ir_node *in[1]; - in[0] = new_Sub (get_value (0, mode_I), get_value (1, mode_I), mode_I); + in[0] = new_Sub (get_value (0, mode_i), get_value (1, mode_i), mode_i); x = new_Return (get_store (), 1, in); } @@ -107,6 +114,8 @@ main(void) add_in_edge (get_irg_end_block(irg), x); mature_block (get_irg_end_block(irg)); + finalize_cons (irg); + printf("Optimizing ...\n"); local_optimize_graph(irg), @@ -117,6 +126,8 @@ main(void) /* output the vcg file */ printf("Done building the graph. Dumping it.\n"); + turn_off_edge_labels(); + dump_all_types(); dump_ir_block_graph (irg); printf("Use xvcg to view this graph:\n"); printf("/ben/goetz/bin/xvcg GRAPHNAME\n\n");