X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fbe%2Fia32%2Fbearch_ia32.c;h=3abf57d17168497c755b0de61bdd4d5a5952c97d;hb=a1a465eb2b3f54027b29f829423fffd0396937f4;hp=5a3dfe128b4e4e6b5d75d330ef286722abbc50b9;hpb=323267da3fcfb2a3029b19e17008645055d86590;p=libfirm diff --git a/ir/be/ia32/bearch_ia32.c b/ir/be/ia32/bearch_ia32.c index 5a3dfe128..3abf57d17 100644 --- a/ir/be/ia32/bearch_ia32.c +++ b/ir/be/ia32/bearch_ia32.c @@ -138,6 +138,10 @@ static const arch_register_req_t *ia32_get_irn_reg_req(const void *self, arch_re if (is_ia32_irn(irn)) { irn_req = (pos >= 0) ? get_ia32_in_req(irn, pos) : get_ia32_out_req(irn, node_pos); + if (irn_req == NULL) { + /* no requirements */ + return NULL; + } DB((mod, LEVEL_1, "returning reqs for %+F at pos %d\n", irn, pos)); @@ -222,14 +226,9 @@ static const arch_register_t *ia32_get_irn_reg(const void *self, const ir_node * } if (is_ia32_irn(irn)) { - /* retrieve "real" x87 register */ - if (ia32_has_x87_register(irn)) - reg = get_ia32_attr(irn)->x87[pos + 2]; - else { - const arch_register_t **slots; - slots = get_ia32_slots(irn); - reg = slots[pos]; - } + const arch_register_t **slots; + slots = get_ia32_slots(irn); + reg = slots[pos]; } else { reg = ia32_get_firm_reg(irn, cur_reg_set); @@ -265,17 +264,19 @@ static arch_irn_class_t ia32_classify(const void *self, const ir_node *irn) { } static arch_irn_flags_t ia32_get_flags(const void *self, const ir_node *irn) { - arch_irn_flags_t flags = arch_irn_flags_none; - - if (is_Proj(irn) && is_ia32_irn(get_Proj_pred(irn))) { - flags |= get_ia32_out_flags(irn, get_Proj_proj(irn)); - } + arch_irn_flags_t flags; + ir_node *pred = is_Proj(irn) && mode_is_datab(get_irn_mode(irn)) ? get_Proj_pred(irn) : NULL; - irn = skip_Proj(irn); - if (is_ia32_irn(irn)) - flags |= get_ia32_flags(irn); - else if (is_Unknown(irn)) + if (is_Unknown(irn)) flags = arch_irn_flags_ignore; + else { + /* pred is only set, if we have a Proj */ + flags = pred && is_ia32_irn(pred) ? get_ia32_out_flags(pred, get_Proj_proj(irn)) : arch_irn_flags_none; + + irn = skip_Proj(irn); + if (is_ia32_irn(irn)) + flags |= get_ia32_flags(irn); + } return flags; }