X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fbe%2Fbeverify.c;h=52c824f3f95cc1c3ac3497613c2b009668a22e48;hb=dcb0342ffc45ffe11ab32835a9673b8dd3b5ec2e;hp=de4cf4a48a038943d1cfe9d82768cd236b25617b;hpb=bd4175dd9c290a499676ef53aa5c6c2106472c1d;p=libfirm diff --git a/ir/be/beverify.c b/ir/be/beverify.c index de4cf4a48..52c824f3f 100644 --- a/ir/be/beverify.c +++ b/ir/be/beverify.c @@ -122,7 +122,7 @@ int be_verify_register_pressure(const be_irg_t *birg, ir_graph *irg) { be_verify_register_pressure_env_t env; - env.lv = be_liveness(birg); + env.lv = be_liveness(irg); env.irg = irg; env.cls = cls; env.registers_available = env.cls->n_regs - be_put_ignore_regs(birg, env.cls, NULL); @@ -284,31 +284,28 @@ static void verify_schedule_walker(ir_node *block, void *data) { static int should_be_scheduled(ir_node *node) { - if(is_Block(node)) - return -1; - - if(is_Proj(node)) - return 0; - - if(get_irn_mode(node) == mode_M) { - if(is_Phi(node) || is_Sync(node) || is_Pin(node)) - return 0; - } - if(be_is_Keep(node) && get_irn_opcode(get_nodes_block(node)) == iro_Bad) - return 0; - switch(get_irn_opcode(node)) { + case iro_Bad: + case iro_Block: case iro_End: case iro_NoMem: - case iro_Bad: + case iro_Pin: + case iro_Proj: + case iro_Sync: case iro_Unknown: return 0; + case iro_Phi: + if (get_irn_mode(node) == mode_M) + return 0; + break; default: break; } - if (arch_irn_get_flags(node) & arch_irn_flags_ignore) - return -1; + if (get_irn_mode(node) != mode_T) { + if (arch_irn_is_ignore(node)) + return -1; + } return 1; } @@ -544,11 +541,12 @@ static void collect_spills_walker(ir_node *node, void *data) { } } -static void check_spillslot_interference(be_verify_spillslots_env_t *env) { - int spillcount = set_count(env->spills); - spill_t **spills = alloca(spillcount * sizeof(spills[0])); - spill_t *spill; - int i; +static void check_spillslot_interference(be_verify_spillslots_env_t *env) +{ + int spillcount = set_count(env->spills); + spill_t **spills = ALLOCAN(spill_t*, spillcount); + spill_t *spill; + int i; for(spill = set_first(env->spills), i = 0; spill != NULL; spill = set_next(env->spills), ++i) { spills[i] = spill; @@ -770,7 +768,7 @@ static void value_used(ir_node *node) { return; reg = arch_get_irn_register(node); - if (reg->type & arch_register_type_virtual) + if (reg == NULL || reg->type & arch_register_type_virtual) return; reg_node = registers[reg->index]; @@ -793,7 +791,7 @@ static void value_def(ir_node *node) return; reg = arch_get_irn_register(node); - if (reg->type & arch_register_type_virtual) + if (reg == NULL || reg->type & arch_register_type_virtual) return; reg_node = registers[reg->index]; @@ -820,8 +818,7 @@ static void verify_block_register_allocation(ir_node *block, void *data) { assert(lv->nodes && "live sets must be computed"); n_regs = arch_register_class_n_regs(regclass); - registers = alloca(n_regs * sizeof(registers[0])); - memset(registers, 0, n_regs * sizeof(registers[0])); + registers = ALLOCANZ(ir_node*, n_regs); be_lv_foreach(lv, block, be_lv_state_end, idx) { ir_node *node = be_lv_get_irn(lv, block, idx); @@ -872,7 +869,7 @@ static void verify_block_register_allocation(ir_node *block, void *data) { int be_verify_register_allocation(const be_irg_t *birg) { arch_env = be_get_birg_arch_env(birg); irg = be_get_birg_irg(birg); - lv = be_liveness(birg); + lv = be_liveness(irg); problem_found = 0; be_liveness_assure_sets(lv);