Annotation of GNUtools/cc/rtlanal.c, revision 1.1

1.1     ! root        1: /* Analyze RTL for C-Compiler
        !             2:    Copyright (C) 1987, 1988, 1991, 1992, 1993 Free Software Foundation, Inc.
        !             3: 
        !             4: This file is part of GNU CC.
        !             5: 
        !             6: GNU CC is free software; you can redistribute it and/or modify
        !             7: it under the terms of the GNU General Public License as published by
        !             8: the Free Software Foundation; either version 2, or (at your option)
        !             9: any later version.
        !            10: 
        !            11: GNU CC is distributed in the hope that it will be useful,
        !            12: but WITHOUT ANY WARRANTY; without even the implied warranty of
        !            13: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
        !            14: GNU General Public License for more details.
        !            15: 
        !            16: You should have received a copy of the GNU General Public License
        !            17: along with GNU CC; see the file COPYING.  If not, write to
        !            18: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
        !            19: 
        !            20: 
        !            21: #include "config.h"
        !            22: #include "rtl.h"
        !            23: 
        !            24: void note_stores ();
        !            25: int reg_set_p ();
        !            26: 
        !            27: /* Bit flags that specify the machine subtype we are compiling for.
        !            28:    Bits are tested using macros TARGET_... defined in the tm.h file
        !            29:    and set by `-m...' switches.  Must be defined in rtlanal.c.  */
        !            30: 
        !            31: int target_flags;
        !            32: 
        !            33: /* Return 1 if the value of X is unstable
        !            34:    (would be different at a different point in the program).
        !            35:    The frame pointer, arg pointer, etc. are considered stable
        !            36:    (within one function) and so is anything marked `unchanging'.  */
        !            37: 
        !            38: int
        !            39: rtx_unstable_p (x)
        !            40:      rtx x;
        !            41: {
        !            42:   register RTX_CODE code = GET_CODE (x);
        !            43:   register int i;
        !            44:   register char *fmt;
        !            45: 
        !            46:   if (code == MEM)
        !            47:     return ! RTX_UNCHANGING_P (x);
        !            48: 
        !            49:   if (code == QUEUED)
        !            50:     return 1;
        !            51: 
        !            52:   if (code == CONST || code == CONST_INT)
        !            53:     return 0;
        !            54: 
        !            55:   if (code == REG)
        !            56:     return ! (REGNO (x) == FRAME_POINTER_REGNUM
        !            57:              || REGNO (x) == HARD_FRAME_POINTER_REGNUM
        !            58:              || REGNO (x) == ARG_POINTER_REGNUM
        !            59:              || RTX_UNCHANGING_P (x));
        !            60: 
        !            61:   fmt = GET_RTX_FORMAT (code);
        !            62:   for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)
        !            63:     if (fmt[i] == 'e')
        !            64:       if (rtx_unstable_p (XEXP (x, i)))
        !            65:        return 1;
        !            66:   return 0;
        !            67: }
        !            68: 
        !            69: /* Return 1 if X has a value that can vary even between two
        !            70:    executions of the program.  0 means X can be compared reliably
        !            71:    against certain constants or near-constants.
        !            72:    The frame pointer and the arg pointer are considered constant.  */
        !            73: 
        !            74: int
        !            75: rtx_varies_p (x)
        !            76:      rtx x;
        !            77: {
        !            78:   register RTX_CODE code = GET_CODE (x);
        !            79:   register int i;
        !            80:   register char *fmt;
        !            81: 
        !            82:   switch (code)
        !            83:     {
        !            84:     case MEM:
        !            85:     case QUEUED:
        !            86:       return 1;
        !            87: 
        !            88:     case CONST:
        !            89:     case CONST_INT:
        !            90:     case CONST_DOUBLE:
        !            91:     case SYMBOL_REF:
        !            92:     case LABEL_REF:
        !            93:       return 0;
        !            94: 
        !            95:     case REG:
        !            96:       /* Note that we have to test for the actual rtx used for the frame
        !            97:         and arg pointers and not just the register number in case we have
        !            98:         eliminated the frame and/or arg pointer and are using it
        !            99:         for pseudos.  */
        !           100:       return ! (x == frame_pointer_rtx || x == hard_frame_pointer_rtx
        !           101:                || x == arg_pointer_rtx);
        !           102: 
        !           103:     case LO_SUM:
        !           104:       /* The operand 0 of a LO_SUM is considered constant
        !           105:         (in fact is it related specifically to operand 1).  */
        !           106:       return rtx_varies_p (XEXP (x, 1));
        !           107:     }
        !           108: 
        !           109:   fmt = GET_RTX_FORMAT (code);
        !           110:   for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)
        !           111:     if (fmt[i] == 'e')
        !           112:       if (rtx_varies_p (XEXP (x, i)))
        !           113:        return 1;
        !           114:   return 0;
        !           115: }
        !           116: 
        !           117: /* Return 0 if the use of X as an address in a MEM can cause a trap.  */
        !           118: 
        !           119: int
        !           120: rtx_addr_can_trap_p (x)
        !           121:      register rtx x;
        !           122: {
        !           123:   register enum rtx_code code = GET_CODE (x);
        !           124: 
        !           125:   switch (code)
        !           126:     {
        !           127:     case SYMBOL_REF:
        !           128:     case LABEL_REF:
        !           129:       /* SYMBOL_REF is problematic due to the possible presence of
        !           130:         a #pragma weak, but to say that loads from symbols can trap is
        !           131:         *very* costly.  It's not at all clear what's best here.  For
        !           132:         now, we ignore the impact of #pragma weak.  */
        !           133:       return 0;
        !           134: 
        !           135:     case REG:
        !           136:       /* As in rtx_varies_p, we have to use the actual rtx, not reg number.  */
        !           137:       return ! (x == frame_pointer_rtx || x == hard_frame_pointer_rtx
        !           138:                || x == stack_pointer_rtx || x == arg_pointer_rtx);
        !           139: 
        !           140:     case CONST:
        !           141:       return rtx_addr_can_trap_p (XEXP (x, 0));
        !           142: 
        !           143:     case PLUS:
        !           144:       /* An address is assumed not to trap if it is an address that can't
        !           145:         trap plus a constant integer.  */
        !           146:       return (rtx_addr_can_trap_p (XEXP (x, 0))
        !           147:              || GET_CODE (XEXP (x, 1)) != CONST_INT);
        !           148: 
        !           149:     case LO_SUM:
        !           150:       return rtx_addr_can_trap_p (XEXP (x, 1));
        !           151:     }
        !           152: 
        !           153:   /* If it isn't one of the case above, it can cause a trap.  */
        !           154:   return 1;
        !           155: }
        !           156: 
        !           157: /* Return 1 if X refers to a memory location whose address 
        !           158:    cannot be compared reliably with constant addresses,
        !           159:    or if X refers to a BLKmode memory object.  */
        !           160: 
        !           161: int
        !           162: rtx_addr_varies_p (x)
        !           163:      rtx x;
        !           164: {
        !           165:   register enum rtx_code code;
        !           166:   register int i;
        !           167:   register char *fmt;
        !           168: 
        !           169:   if (x == 0)
        !           170:     return 0;
        !           171: 
        !           172:   code = GET_CODE (x);
        !           173:   if (code == MEM)
        !           174:     return GET_MODE (x) == BLKmode || rtx_varies_p (XEXP (x, 0));
        !           175: 
        !           176:   fmt = GET_RTX_FORMAT (code);
        !           177:   for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)
        !           178:     if (fmt[i] == 'e')
        !           179:       if (rtx_addr_varies_p (XEXP (x, i)))
        !           180:        return 1;
        !           181:   return 0;
        !           182: }
        !           183: 
        !           184: /* Return the value of the integer term in X, if one is apparent;
        !           185:    otherwise return 0.
        !           186:    Only obvious integer terms are detected.
        !           187:    This is used in cse.c with the `related_value' field.*/
        !           188: 
        !           189: HOST_WIDE_INT
        !           190: get_integer_term (x)
        !           191:      rtx x;
        !           192: {
        !           193:   if (GET_CODE (x) == CONST)
        !           194:     x = XEXP (x, 0);
        !           195: 
        !           196:   if (GET_CODE (x) == MINUS
        !           197:       && GET_CODE (XEXP (x, 1)) == CONST_INT)
        !           198:     return - INTVAL (XEXP (x, 1));
        !           199:   if (GET_CODE (x) == PLUS
        !           200:       && GET_CODE (XEXP (x, 1)) == CONST_INT)
        !           201:     return INTVAL (XEXP (x, 1));
        !           202:   return 0;
        !           203: }
        !           204: 
        !           205: /* If X is a constant, return the value sans apparent integer term;
        !           206:    otherwise return 0.
        !           207:    Only obvious integer terms are detected.  */
        !           208: 
        !           209: rtx
        !           210: get_related_value (x)
        !           211:      rtx x;
        !           212: {
        !           213:   if (GET_CODE (x) != CONST)
        !           214:     return 0;
        !           215:   x = XEXP (x, 0);
        !           216:   if (GET_CODE (x) == PLUS
        !           217:       && GET_CODE (XEXP (x, 1)) == CONST_INT)
        !           218:     return XEXP (x, 0);
        !           219:   else if (GET_CODE (x) == MINUS
        !           220:           && GET_CODE (XEXP (x, 1)) == CONST_INT)
        !           221:     return XEXP (x, 0);
        !           222:   return 0;
        !           223: }
        !           224: 
        !           225: /* Nonzero if register REG appears somewhere within IN.
        !           226:    Also works if REG is not a register; in this case it checks
        !           227:    for a subexpression of IN that is Lisp "equal" to REG.  */
        !           228: 
        !           229: int
        !           230: reg_mentioned_p (reg, in)
        !           231:      register rtx reg, in;
        !           232: {
        !           233:   register char *fmt;
        !           234:   register int i;
        !           235:   register enum rtx_code code;
        !           236: 
        !           237:   if (in == 0)
        !           238:     return 0;
        !           239: 
        !           240:   if (reg == in)
        !           241:     return 1;
        !           242: 
        !           243:   if (GET_CODE (in) == LABEL_REF)
        !           244:     return reg == XEXP (in, 0);
        !           245: 
        !           246:   code = GET_CODE (in);
        !           247: 
        !           248:   switch (code)
        !           249:     {
        !           250:       /* Compare registers by number.  */
        !           251:     case REG:
        !           252:       return GET_CODE (reg) == REG && REGNO (in) == REGNO (reg);
        !           253: 
        !           254:       /* These codes have no constituent expressions
        !           255:         and are unique.  */
        !           256:     case SCRATCH:
        !           257:     case CC0:
        !           258:     case PC:
        !           259:       return 0;
        !           260: 
        !           261:     case CONST_INT:
        !           262:       return GET_CODE (reg) == CONST_INT && INTVAL (in) == INTVAL (reg);
        !           263:       
        !           264:     case CONST_DOUBLE:
        !           265:       /* These are kept unique for a given value.  */
        !           266:       return 0;
        !           267:     }
        !           268: 
        !           269:   if (GET_CODE (reg) == code && rtx_equal_p (reg, in))
        !           270:     return 1;
        !           271: 
        !           272:   fmt = GET_RTX_FORMAT (code);
        !           273: 
        !           274:   for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)
        !           275:     {
        !           276:       if (fmt[i] == 'E')
        !           277:        {
        !           278:          register int j;
        !           279:          for (j = XVECLEN (in, i) - 1; j >= 0; j--)
        !           280:            if (reg_mentioned_p (reg, XVECEXP (in, i, j)))
        !           281:              return 1;
        !           282:        }
        !           283:       else if (fmt[i] == 'e'
        !           284:               && reg_mentioned_p (reg, XEXP (in, i)))
        !           285:        return 1;
        !           286:     }
        !           287:   return 0;
        !           288: }
        !           289: 
        !           290: /* Return 1 if in between BEG and END, exclusive of BEG and END, there is
        !           291:    no CODE_LABEL insn.  */
        !           292: 
        !           293: int
        !           294: no_labels_between_p (beg, end)
        !           295:      rtx beg, end;
        !           296: {
        !           297:   register rtx p;
        !           298:   for (p = NEXT_INSN (beg); p != end; p = NEXT_INSN (p))
        !           299:     if (GET_CODE (p) == CODE_LABEL)
        !           300:       return 0;
        !           301:   return 1;
        !           302: }
        !           303: 
        !           304: /* Nonzero if register REG is used in an insn between
        !           305:    FROM_INSN and TO_INSN (exclusive of those two).  */
        !           306: 
        !           307: int
        !           308: reg_used_between_p (reg, from_insn, to_insn)
        !           309:      rtx reg, from_insn, to_insn;
        !           310: {
        !           311:   register rtx insn;
        !           312: 
        !           313:   if (from_insn == to_insn)
        !           314:     return 0;
        !           315: 
        !           316:   for (insn = NEXT_INSN (from_insn); insn != to_insn; insn = NEXT_INSN (insn))
        !           317:     if (GET_RTX_CLASS (GET_CODE (insn)) == 'i'
        !           318:        && reg_overlap_mentioned_p (reg, PATTERN (insn)))
        !           319:       return 1;
        !           320:   return 0;
        !           321: }
        !           322: 
        !           323: /* Nonzero if the old value of X, a register, is referenced in BODY.  If X
        !           324:    is entirely replaced by a new value and the only use is as a SET_DEST,
        !           325:    we do not consider it a reference.  */
        !           326: 
        !           327: int
        !           328: reg_referenced_p (x, body)
        !           329:      rtx x;
        !           330:      rtx body;
        !           331: {
        !           332:   int i;
        !           333: 
        !           334:   switch (GET_CODE (body))
        !           335:     {
        !           336:     case SET:
        !           337:       if (reg_overlap_mentioned_p (x, SET_SRC (body)))
        !           338:        return 1;
        !           339: 
        !           340:       /* If the destination is anything other than CC0, PC, a REG or a SUBREG
        !           341:         of a REG that occupies all of the REG, the insn references X if
        !           342:         it is mentioned in the destination.  */
        !           343:       if (GET_CODE (SET_DEST (body)) != CC0
        !           344:          && GET_CODE (SET_DEST (body)) != PC
        !           345:          && GET_CODE (SET_DEST (body)) != REG
        !           346:          && ! (GET_CODE (SET_DEST (body)) == SUBREG
        !           347:                && GET_CODE (SUBREG_REG (SET_DEST (body))) == REG
        !           348:                && (((GET_MODE_SIZE (GET_MODE (SUBREG_REG (SET_DEST (body))))
        !           349:                      + (UNITS_PER_WORD - 1)) / UNITS_PER_WORD)
        !           350:                    == ((GET_MODE_SIZE (GET_MODE (SET_DEST (body)))
        !           351:                         + (UNITS_PER_WORD - 1)) / UNITS_PER_WORD)))
        !           352:          && reg_overlap_mentioned_p (x, SET_DEST (body)))
        !           353:        return 1;
        !           354:       break;
        !           355: 
        !           356:     case ASM_OPERANDS:
        !           357:       for (i = ASM_OPERANDS_INPUT_LENGTH (body) - 1; i >= 0; i--)
        !           358:        if (reg_overlap_mentioned_p (x, ASM_OPERANDS_INPUT (body, i)))
        !           359:          return 1;
        !           360:       break;
        !           361: 
        !           362:     case CALL:
        !           363:     case USE:
        !           364:       return reg_overlap_mentioned_p (x, body);
        !           365: 
        !           366:     case TRAP_IF:
        !           367:       return reg_overlap_mentioned_p (x, TRAP_CONDITION (body));
        !           368: 
        !           369:     case UNSPEC:
        !           370:     case UNSPEC_VOLATILE:
        !           371:     case PARALLEL:
        !           372:       for (i = XVECLEN (body, 0) - 1; i >= 0; i--)
        !           373:        if (reg_referenced_p (x, XVECEXP (body, 0, i)))
        !           374:          return 1;
        !           375:       break;
        !           376:     }
        !           377: 
        !           378:   return 0;
        !           379: }
        !           380: 
        !           381: /* Nonzero if register REG is referenced in an insn between
        !           382:    FROM_INSN and TO_INSN (exclusive of those two).  Sets of REG do
        !           383:    not count. */
        !           384: 
        !           385: int
        !           386: reg_referenced_between_p (reg, from_insn, to_insn)
        !           387:      rtx reg, from_insn, to_insn;
        !           388: {
        !           389:   register rtx insn;
        !           390: 
        !           391:   if (from_insn == to_insn)
        !           392:     return 0;
        !           393: 
        !           394:   for (insn = NEXT_INSN (from_insn); insn != to_insn; insn = NEXT_INSN (insn))
        !           395:     if (GET_RTX_CLASS (GET_CODE (insn)) == 'i'
        !           396:        && reg_referenced_p (reg, PATTERN (insn)))
        !           397:       return 1;
        !           398:   return 0;
        !           399: }
        !           400: 
        !           401: /* Nonzero if register REG is set or clobbered in an insn between
        !           402:    FROM_INSN and TO_INSN (exclusive of those two).  */
        !           403: 
        !           404: int
        !           405: reg_set_between_p (reg, from_insn, to_insn)
        !           406:      rtx reg, from_insn, to_insn;
        !           407: {
        !           408:   register rtx insn;
        !           409: 
        !           410:   if (from_insn == to_insn)
        !           411:     return 0;
        !           412: 
        !           413:   for (insn = NEXT_INSN (from_insn); insn != to_insn; insn = NEXT_INSN (insn))
        !           414:     if (GET_RTX_CLASS (GET_CODE (insn)) == 'i'
        !           415:        && reg_set_p (reg, insn))
        !           416:       return 1;
        !           417:   return 0;
        !           418: }
        !           419: 
        !           420: /* Internals of reg_set_between_p.  */
        !           421: 
        !           422: static rtx reg_set_reg;
        !           423: static int reg_set_flag;
        !           424: 
        !           425: void
        !           426: reg_set_p_1 (x)
        !           427:      rtx x;
        !           428: {
        !           429:   /* We don't want to return 1 if X is a MEM that contains a register
        !           430:      within REG_SET_REG.  */
        !           431: 
        !           432:   if ((GET_CODE (x) != MEM)
        !           433:       && reg_overlap_mentioned_p (reg_set_reg, x))
        !           434:     reg_set_flag = 1;
        !           435: }
        !           436: 
        !           437: int
        !           438: reg_set_p (reg, insn)
        !           439:      rtx reg, insn;
        !           440: {
        !           441:   rtx body = insn;
        !           442: 
        !           443:   /* We can be passed an insn or part of one.  If we are passed an insn,
        !           444:      check if a side-effect of the insn clobbers REG.  */
        !           445:   if (GET_RTX_CLASS (GET_CODE (insn)) == 'i')
        !           446:     {
        !           447:       if (FIND_REG_INC_NOTE (insn, reg)
        !           448:          || (GET_CODE (insn) == CALL_INSN
        !           449:              /* We'd like to test call_used_regs here, but rtlanal.c can't
        !           450:                 reference that variable due to its use in genattrtab.  So
        !           451:                 we'll just be more conservative.  */
        !           452:              && ((GET_CODE (reg) == REG
        !           453:                   && REGNO (reg) < FIRST_PSEUDO_REGISTER)
        !           454:                  || GET_CODE (reg) == MEM)))
        !           455:        return 1;
        !           456: 
        !           457:       body = PATTERN (insn);
        !           458:     }
        !           459: 
        !           460:   reg_set_reg = reg;
        !           461:   reg_set_flag = 0;
        !           462:   note_stores (body, reg_set_p_1);
        !           463:   return reg_set_flag;
        !           464: }
        !           465: 
        !           466: /* Similar to reg_set_between_p, but check all registers in X.  Return 0
        !           467:    only if none of them are modified between START and END.  Return 1 if
        !           468:    X contains a MEM; this routine does not perform any memory aliasing.  */
        !           469: 
        !           470: int
        !           471: modified_between_p (x, start, end)
        !           472:      rtx x;
        !           473:      rtx start, end;
        !           474: {
        !           475:   enum rtx_code code = GET_CODE (x);
        !           476:   char *fmt;
        !           477:   int i, j;
        !           478: 
        !           479:   switch (code)
        !           480:     {
        !           481:     case CONST_INT:
        !           482:     case CONST_DOUBLE:
        !           483:     case CONST:
        !           484:     case SYMBOL_REF:
        !           485:     case LABEL_REF:
        !           486:       return 0;
        !           487: 
        !           488:     case PC:
        !           489:     case CC0:
        !           490:       return 1;
        !           491: 
        !           492:     case MEM:
        !           493:       /* If the memory is not constant, assume it is modified.  If it is
        !           494:         constant, we still have to check the address.  */
        !           495:       if (! RTX_UNCHANGING_P (x))
        !           496:        return 1;
        !           497:       break;
        !           498: 
        !           499:     case REG:
        !           500:       return reg_set_between_p (x, start, end);
        !           501:     }
        !           502: 
        !           503:   fmt = GET_RTX_FORMAT (code);
        !           504:   for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)
        !           505:     {
        !           506:       if (fmt[i] == 'e' && modified_between_p (XEXP (x, i), start, end))
        !           507:        return 1;
        !           508: 
        !           509:       if (fmt[i] == 'E')
        !           510:        for (j = XVECLEN (x, i) - 1; j >= 0; j--)
        !           511:          if (modified_between_p (XVECEXP (x, i, j), start, end))
        !           512:            return 1;
        !           513:     }
        !           514: 
        !           515:   return 0;
        !           516: }
        !           517: 
        !           518: /* Similar to reg_set_p, but check all registers in X.  Return 0 only if none
        !           519:    of them are modified in INSN.  Return 1 if X contains a MEM; this routine
        !           520:    does not perform any memory aliasing.  */
        !           521: 
        !           522: int
        !           523: modified_in_p (x, insn)
        !           524:      rtx x;
        !           525:      rtx insn;
        !           526: {
        !           527:   enum rtx_code code = GET_CODE (x);
        !           528:   char *fmt;
        !           529:   int i, j;
        !           530: 
        !           531:   switch (code)
        !           532:     {
        !           533:     case CONST_INT:
        !           534:     case CONST_DOUBLE:
        !           535:     case CONST:
        !           536:     case SYMBOL_REF:
        !           537:     case LABEL_REF:
        !           538:       return 0;
        !           539: 
        !           540:     case PC:
        !           541:     case CC0:
        !           542:       return 1;
        !           543: 
        !           544:     case MEM:
        !           545:       /* If the memory is not constant, assume it is modified.  If it is
        !           546:         constant, we still have to check the address.  */
        !           547:       if (! RTX_UNCHANGING_P (x))
        !           548:        return 1;
        !           549:       break;
        !           550: 
        !           551:     case REG:
        !           552:       return reg_set_p (x, insn);
        !           553:     }
        !           554: 
        !           555:   fmt = GET_RTX_FORMAT (code);
        !           556:   for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)
        !           557:     {
        !           558:       if (fmt[i] == 'e' && modified_in_p (XEXP (x, i), insn))
        !           559:        return 1;
        !           560: 
        !           561:       if (fmt[i] == 'E')
        !           562:        for (j = XVECLEN (x, i) - 1; j >= 0; j--)
        !           563:          if (modified_in_p (XVECEXP (x, i, j), insn))
        !           564:            return 1;
        !           565:     }
        !           566: 
        !           567:   return 0;
        !           568: }
        !           569: 
        !           570: /* Given an INSN, return a SET expression if this insn has only a single SET.
        !           571:    It may also have CLOBBERs, USEs, or SET whose output
        !           572:    will not be used, which we ignore.  */
        !           573: 
        !           574: rtx
        !           575: single_set (insn)
        !           576:      rtx insn;
        !           577: {
        !           578:   rtx set;
        !           579:   int i;
        !           580:   
        !           581:   if (GET_RTX_CLASS (GET_CODE (insn)) != 'i')
        !           582:     return 0;
        !           583: 
        !           584:   if (GET_CODE (PATTERN (insn)) == SET)
        !           585:     return PATTERN (insn);
        !           586:   
        !           587:   else if (GET_CODE (PATTERN (insn)) == PARALLEL)
        !           588:     {
        !           589:       for (i = 0, set = 0; i < XVECLEN (PATTERN (insn), 0); i++)
        !           590:        if (GET_CODE (XVECEXP (PATTERN (insn), 0, i)) == SET
        !           591:            && (! find_reg_note (insn, REG_UNUSED,
        !           592:                                 SET_DEST (XVECEXP (PATTERN (insn), 0, i)))
        !           593:                || side_effects_p (XVECEXP (PATTERN (insn), 0, i))))
        !           594:          {
        !           595:            if (set)
        !           596:              return 0;
        !           597:            else
        !           598:              set = XVECEXP (PATTERN (insn), 0, i);
        !           599:          }
        !           600:       return set;
        !           601:     }
        !           602:   
        !           603:   return 0;
        !           604: }
        !           605: 
        !           606: /* Return the last thing that X was assigned from before *PINSN.  Verify that
        !           607:    the object is not modified up to VALID_TO.  If it was, if we hit
        !           608:    a partial assignment to X, or hit a CODE_LABEL first, return X.  If we
        !           609:    found an assignment, update *PINSN to point to it.  */
        !           610: 
        !           611: rtx
        !           612: find_last_value (x, pinsn, valid_to)
        !           613:      rtx x;
        !           614:      rtx *pinsn;
        !           615:      rtx valid_to;
        !           616: {
        !           617:   rtx p;
        !           618: 
        !           619:   for (p = PREV_INSN (*pinsn); p && GET_CODE (p) != CODE_LABEL;
        !           620:        p = PREV_INSN (p))
        !           621:     if (GET_RTX_CLASS (GET_CODE (p)) == 'i')
        !           622:       {
        !           623:        rtx set = single_set (p);
        !           624:        rtx note = find_reg_note (p, REG_EQUAL, NULL_RTX);
        !           625: 
        !           626:        if (set && rtx_equal_p (x, SET_DEST (set)))
        !           627:          {
        !           628:            rtx src = SET_SRC (set);
        !           629: 
        !           630:            if (note && GET_CODE (XEXP (note, 0)) != EXPR_LIST)
        !           631:              src = XEXP (note, 0);
        !           632: 
        !           633:            if (! modified_between_p (src, PREV_INSN (p), valid_to)
        !           634:                /* Reject hard registers because we don't usually want
        !           635:                   to use them; we'd rather use a pseudo.  */
        !           636:                && ! (GET_CODE (src) == REG
        !           637:                      && REGNO (src) < FIRST_PSEUDO_REGISTER))
        !           638:              {
        !           639:                *pinsn = p;
        !           640:                return src;
        !           641:              }
        !           642:          }
        !           643:          
        !           644:        /* If set in non-simple way, we don't have a value.  */
        !           645:        if (reg_set_p (x, p))
        !           646:          break;
        !           647:       }
        !           648: 
        !           649:   return x;
        !           650: }     
        !           651: 
        !           652: /* Return nonzero if register in range [REGNO, ENDREGNO)
        !           653:    appears either explicitly or implicitly in X
        !           654:    other than being stored into.
        !           655: 
        !           656:    References contained within the substructure at LOC do not count.
        !           657:    LOC may be zero, meaning don't ignore anything.  */
        !           658: 
        !           659: int
        !           660: refers_to_regno_p (regno, endregno, x, loc)
        !           661:      int regno, endregno;
        !           662:      rtx x;
        !           663:      rtx *loc;
        !           664: {
        !           665:   register int i;
        !           666:   register RTX_CODE code;
        !           667:   register char *fmt;
        !           668: 
        !           669:  repeat:
        !           670:   /* The contents of a REG_NONNEG note is always zero, so we must come here
        !           671:      upon repeat in case the last REG_NOTE is a REG_NONNEG note.  */
        !           672:   if (x == 0)
        !           673:     return 0;
        !           674: 
        !           675:   code = GET_CODE (x);
        !           676: 
        !           677:   switch (code)
        !           678:     {
        !           679:     case REG:
        !           680:       i = REGNO (x);
        !           681: 
        !           682:       /* If we modifying the stack, frame, or argument pointer, it will
        !           683:         clobber a virtual register.  In fact, we could be more precise,
        !           684:         but it isn't worth it.  */
        !           685:       if ((i == STACK_POINTER_REGNUM
        !           686: #if FRAME_POINTER_REGNUM != ARG_POINTER_REGNUM
        !           687:           || i == ARG_POINTER_REGNUM
        !           688: #endif
        !           689:           || i == FRAME_POINTER_REGNUM)
        !           690:          && regno >= FIRST_VIRTUAL_REGISTER && regno <= LAST_VIRTUAL_REGISTER)
        !           691:        return 1;
        !           692: 
        !           693:       return (endregno > i
        !           694:              && regno < i + (i < FIRST_PSEUDO_REGISTER 
        !           695:                              ? HARD_REGNO_NREGS (i, GET_MODE (x))
        !           696:                              : 1));
        !           697: 
        !           698:     case SUBREG:
        !           699:       /* If this is a SUBREG of a hard reg, we can see exactly which
        !           700:         registers are being modified.  Otherwise, handle normally.  */
        !           701:       if (GET_CODE (SUBREG_REG (x)) == REG
        !           702:          && REGNO (SUBREG_REG (x)) < FIRST_PSEUDO_REGISTER)
        !           703:        {
        !           704:          int inner_regno = REGNO (SUBREG_REG (x)) + SUBREG_WORD (x);
        !           705:          int inner_endregno
        !           706:            = inner_regno + (inner_regno < FIRST_PSEUDO_REGISTER
        !           707:                             ? HARD_REGNO_NREGS (regno, GET_MODE (x)) : 1);
        !           708: 
        !           709:          return endregno > inner_regno && regno < inner_endregno;
        !           710:        }
        !           711:       break;
        !           712: 
        !           713:     case CLOBBER:
        !           714:     case SET:
        !           715:       if (&SET_DEST (x) != loc
        !           716:          /* Note setting a SUBREG counts as referring to the REG it is in for
        !           717:             a pseudo but not for hard registers since we can
        !           718:             treat each word individually.  */
        !           719:          && ((GET_CODE (SET_DEST (x)) == SUBREG
        !           720:               && loc != &SUBREG_REG (SET_DEST (x))
        !           721:               && GET_CODE (SUBREG_REG (SET_DEST (x))) == REG
        !           722:               && REGNO (SUBREG_REG (SET_DEST (x))) >= FIRST_PSEUDO_REGISTER
        !           723:               && refers_to_regno_p (regno, endregno,
        !           724:                                     SUBREG_REG (SET_DEST (x)), loc))
        !           725:              || (GET_CODE (SET_DEST (x)) != REG
        !           726:                  && refers_to_regno_p (regno, endregno, SET_DEST (x), loc))))
        !           727:        return 1;
        !           728: 
        !           729:       if (code == CLOBBER || loc == &SET_SRC (x))
        !           730:        return 0;
        !           731:       x = SET_SRC (x);
        !           732:       goto repeat;
        !           733:     }
        !           734: 
        !           735:   /* X does not match, so try its subexpressions.  */
        !           736: 
        !           737:   fmt = GET_RTX_FORMAT (code);
        !           738:   for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)
        !           739:     {
        !           740:       if (fmt[i] == 'e' && loc != &XEXP (x, i))
        !           741:        {
        !           742:          if (i == 0)
        !           743:            {
        !           744:              x = XEXP (x, 0);
        !           745:              goto repeat;
        !           746:            }
        !           747:          else
        !           748:            if (refers_to_regno_p (regno, endregno, XEXP (x, i), loc))
        !           749:              return 1;
        !           750:        }
        !           751:       else if (fmt[i] == 'E')
        !           752:        {
        !           753:          register int j;
        !           754:          for (j = XVECLEN (x, i) - 1; j >=0; j--)
        !           755:            if (loc != &XVECEXP (x, i, j)
        !           756:                && refers_to_regno_p (regno, endregno, XVECEXP (x, i, j), loc))
        !           757:              return 1;
        !           758:        }
        !           759:     }
        !           760:   return 0;
        !           761: }
        !           762: 
        !           763: /* Nonzero if modifying X will affect IN.  If X is a register or a SUBREG,
        !           764:    we check if any register number in X conflicts with the relevant register
        !           765:    numbers.  If X is a constant, return 0.  If X is a MEM, return 1 iff IN
        !           766:    contains a MEM (we don't bother checking for memory addresses that can't
        !           767:    conflict because we expect this to be a rare case.  */
        !           768: 
        !           769: int
        !           770: reg_overlap_mentioned_p (x, in)
        !           771:      rtx x, in;
        !           772: {
        !           773:   int regno, endregno;
        !           774: 
        !           775:   if (GET_CODE (x) == SUBREG)
        !           776:     {
        !           777:       regno = REGNO (SUBREG_REG (x));
        !           778:       if (regno < FIRST_PSEUDO_REGISTER)
        !           779:        regno += SUBREG_WORD (x);
        !           780:     }
        !           781:   else if (GET_CODE (x) == REG)
        !           782:     regno = REGNO (x);
        !           783:   else if (CONSTANT_P (x))
        !           784:     return 0;
        !           785:   else if (GET_CODE (x) == MEM)
        !           786:     {
        !           787:       char *fmt;
        !           788:       int i;
        !           789: 
        !           790:       if (GET_CODE (in) == MEM)
        !           791:        return 1;
        !           792: 
        !           793:       fmt = GET_RTX_FORMAT (GET_CODE (in));
        !           794: 
        !           795:       for (i = GET_RTX_LENGTH (GET_CODE (in)) - 1; i >= 0; i--)
        !           796:        if (fmt[i] == 'e' && reg_overlap_mentioned_p (x, XEXP (in, i)))
        !           797:          return 1;
        !           798: 
        !           799:       return 0;
        !           800:     }
        !           801:   else if (GET_CODE (x) == SCRATCH || GET_CODE (x) == PC
        !           802:           || GET_CODE (x) == CC0)
        !           803:     return reg_mentioned_p (x, in);
        !           804:   else
        !           805:     abort ();
        !           806: 
        !           807:   endregno = regno + (regno < FIRST_PSEUDO_REGISTER
        !           808:                      ? HARD_REGNO_NREGS (regno, GET_MODE (x)) : 1);
        !           809: 
        !           810:   return refers_to_regno_p (regno, endregno, in, NULL_PTR);
        !           811: }
        !           812: 
        !           813: /* Used for communications between the next few functions.  */
        !           814: 
        !           815: static int reg_set_last_unknown;
        !           816: static rtx reg_set_last_value;
        !           817: static int reg_set_last_first_regno, reg_set_last_last_regno;
        !           818: 
        !           819: /* Called via note_stores from reg_set_last.  */
        !           820: 
        !           821: static void
        !           822: reg_set_last_1 (x, pat)
        !           823:      rtx x;
        !           824:      rtx pat;
        !           825: {
        !           826:   int first, last;
        !           827: 
        !           828:   /* If X is not a register, or is not one in the range we care
        !           829:      about, ignore.  */
        !           830:   if (GET_CODE (x) != REG)
        !           831:     return;
        !           832: 
        !           833:   first = REGNO (x);
        !           834:   last = first + (first < FIRST_PSEUDO_REGISTER
        !           835:                  ? HARD_REGNO_NREGS (first, GET_MODE (x)) : 1);
        !           836: 
        !           837:   if (first >= reg_set_last_last_regno
        !           838:       || last <= reg_set_last_first_regno)
        !           839:     return;
        !           840: 
        !           841:   /* If this is a CLOBBER or is some complex LHS, or doesn't modify
        !           842:      exactly the registers we care about, show we don't know the value.  */
        !           843:   if (GET_CODE (pat) == CLOBBER || SET_DEST (pat) != x
        !           844:       || first != reg_set_last_first_regno
        !           845:       || last != reg_set_last_last_regno)
        !           846:     reg_set_last_unknown = 1;
        !           847:   else
        !           848:     reg_set_last_value = SET_SRC (pat);
        !           849: }
        !           850: 
        !           851: /* Return the last value to which REG was set prior to INSN.  If we can't
        !           852:    find it easily, return 0.
        !           853: 
        !           854:    We only return a REG, SUBREG, or constant because it is too hard to
        !           855:    check if a MEM remains unchanged.  */
        !           856: 
        !           857: rtx
        !           858: reg_set_last (x, insn)
        !           859:      rtx x;
        !           860:      rtx insn;
        !           861: {
        !           862:   rtx orig_insn = insn;
        !           863: 
        !           864:   reg_set_last_first_regno = REGNO (x);
        !           865: 
        !           866:   reg_set_last_last_regno
        !           867:     = reg_set_last_first_regno
        !           868:       + (reg_set_last_first_regno < FIRST_PSEUDO_REGISTER
        !           869:         ? HARD_REGNO_NREGS (reg_set_last_first_regno, GET_MODE (x)) : 1);
        !           870: 
        !           871:   reg_set_last_unknown = 0;
        !           872:   reg_set_last_value = 0;
        !           873: 
        !           874:   /* Scan backwards until reg_set_last_1 changed one of the above flags.
        !           875:      Stop when we reach a label or X is a hard reg and we reach a
        !           876:      CALL_INSN (if reg_set_last_last_regno is a hard reg).
        !           877: 
        !           878:      If we find a set of X, ensure that its SET_SRC remains unchanged.  */
        !           879: 
        !           880:   /* We compare with <= here, because reg_set_last_last_regno
        !           881:      is actually the number of the first reg *not* in X.  */
        !           882:   for (;
        !           883:        insn && GET_CODE (insn) != CODE_LABEL
        !           884:        && ! (GET_CODE (insn) == CALL_INSN
        !           885:             && reg_set_last_last_regno <= FIRST_PSEUDO_REGISTER);
        !           886:        insn = PREV_INSN (insn))
        !           887:     if (GET_RTX_CLASS (GET_CODE (insn)) == 'i')
        !           888:       {
        !           889:        note_stores (PATTERN (insn), reg_set_last_1);
        !           890:        if (reg_set_last_unknown)
        !           891:          return 0;
        !           892:        else if (reg_set_last_value)
        !           893:          {
        !           894:            if (CONSTANT_P (reg_set_last_value)
        !           895:                || ((GET_CODE (reg_set_last_value) == REG
        !           896:                     || GET_CODE (reg_set_last_value) == SUBREG)
        !           897:                    && ! reg_set_between_p (reg_set_last_value,
        !           898:                                            NEXT_INSN (insn), orig_insn)))
        !           899:              return reg_set_last_value;
        !           900:            else
        !           901:              return 0;
        !           902:          }
        !           903:       }
        !           904: 
        !           905:   return 0;
        !           906: }
        !           907: 
        !           908: /* This is 1 until after reload pass.  */
        !           909: int rtx_equal_function_value_matters;
        !           910: 
        !           911: /* Return 1 if X and Y are identical-looking rtx's.
        !           912:    This is the Lisp function EQUAL for rtx arguments.  */
        !           913: 
        !           914: int
        !           915: rtx_equal_p (x, y)
        !           916:      rtx x, y;
        !           917: {
        !           918:   register int i;
        !           919:   register int j;
        !           920:   register enum rtx_code code;
        !           921:   register char *fmt;
        !           922: 
        !           923:   if (x == y)
        !           924:     return 1;
        !           925:   if (x == 0 || y == 0)
        !           926:     return 0;
        !           927: 
        !           928:   code = GET_CODE (x);
        !           929:   /* Rtx's of different codes cannot be equal.  */
        !           930:   if (code != GET_CODE (y))
        !           931:     return 0;
        !           932: 
        !           933:   /* (MULT:SI x y) and (MULT:HI x y) are NOT equivalent.
        !           934:      (REG:SI x) and (REG:HI x) are NOT equivalent.  */
        !           935: 
        !           936:   if (GET_MODE (x) != GET_MODE (y))
        !           937:     return 0;
        !           938: 
        !           939:   /* REG, LABEL_REF, and SYMBOL_REF can be compared nonrecursively.  */
        !           940: 
        !           941:   if (code == REG)
        !           942:     /* Until rtl generation is complete, don't consider a reference to the
        !           943:        return register of the current function the same as the return from a
        !           944:        called function.  This eases the job of function integration.  Once the
        !           945:        distinction is no longer needed, they can be considered equivalent.  */
        !           946:     return (REGNO (x) == REGNO (y)
        !           947:            && (! rtx_equal_function_value_matters
        !           948:                || REG_FUNCTION_VALUE_P (x) == REG_FUNCTION_VALUE_P (y)));
        !           949:   else if (code == LABEL_REF)
        !           950:     return XEXP (x, 0) == XEXP (y, 0);
        !           951:   else if (code == SYMBOL_REF)
        !           952:     return XSTR (x, 0) == XSTR (y, 0);
        !           953:   else if (code == SCRATCH || code == CONST_DOUBLE)
        !           954:     return 0;
        !           955: 
        !           956:   /* Compare the elements.  If any pair of corresponding elements
        !           957:      fail to match, return 0 for the whole things.  */
        !           958: 
        !           959:   fmt = GET_RTX_FORMAT (code);
        !           960:   for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)
        !           961:     {
        !           962:       switch (fmt[i])
        !           963:        {
        !           964:        case 'w':
        !           965:          if (XWINT (x, i) != XWINT (y, i))
        !           966:            return 0;
        !           967:          break;
        !           968: 
        !           969:        case 'n':
        !           970:        case 'i':
        !           971:          if (XINT (x, i) != XINT (y, i))
        !           972:            return 0;
        !           973:          break;
        !           974: 
        !           975:        case 'V':
        !           976:        case 'E':
        !           977:          /* Two vectors must have the same length.  */
        !           978:          if (XVECLEN (x, i) != XVECLEN (y, i))
        !           979:            return 0;
        !           980: 
        !           981:          /* And the corresponding elements must match.  */
        !           982:          for (j = 0; j < XVECLEN (x, i); j++)
        !           983:            if (rtx_equal_p (XVECEXP (x, i, j), XVECEXP (y, i, j)) == 0)
        !           984:              return 0;
        !           985:          break;
        !           986: 
        !           987:        case 'e':
        !           988:          if (rtx_equal_p (XEXP (x, i), XEXP (y, i)) == 0)
        !           989:            return 0;
        !           990:          break;
        !           991: 
        !           992:        case 'S':
        !           993:        case 's':
        !           994:          if (strcmp (XSTR (x, i), XSTR (y, i)))
        !           995:            return 0;
        !           996:          break;
        !           997: 
        !           998:        case 'u':
        !           999:          /* These are just backpointers, so they don't matter.  */
        !          1000:          break;
        !          1001: 
        !          1002:        case '0':
        !          1003:          break;
        !          1004: 
        !          1005:          /* It is believed that rtx's at this level will never
        !          1006:             contain anything but integers and other rtx's,
        !          1007:             except for within LABEL_REFs and SYMBOL_REFs.  */
        !          1008:        default:
        !          1009:          abort ();
        !          1010:        }
        !          1011:     }
        !          1012:   return 1;
        !          1013: }
        !          1014: 
        !          1015: /* Call FUN on each register or MEM that is stored into or clobbered by X.
        !          1016:    (X would be the pattern of an insn).
        !          1017:    FUN receives two arguments:
        !          1018:      the REG, MEM, CC0 or PC being stored in or clobbered,
        !          1019:      the SET or CLOBBER rtx that does the store.
        !          1020: 
        !          1021:   If the item being stored in or clobbered is a SUBREG of a hard register,
        !          1022:   the SUBREG will be passed.  */
        !          1023:      
        !          1024: void
        !          1025: note_stores (x, fun)
        !          1026:      register rtx x;
        !          1027:      void (*fun) ();
        !          1028: {
        !          1029:   if ((GET_CODE (x) == SET || GET_CODE (x) == CLOBBER))
        !          1030:     {
        !          1031:       register rtx dest = SET_DEST (x);
        !          1032:       while ((GET_CODE (dest) == SUBREG
        !          1033:              && (GET_CODE (SUBREG_REG (dest)) != REG
        !          1034:                  || REGNO (SUBREG_REG (dest)) >= FIRST_PSEUDO_REGISTER))
        !          1035:             || GET_CODE (dest) == ZERO_EXTRACT
        !          1036:             || GET_CODE (dest) == SIGN_EXTRACT
        !          1037:             || GET_CODE (dest) == STRICT_LOW_PART)
        !          1038:        dest = XEXP (dest, 0);
        !          1039:       (*fun) (dest, x);
        !          1040:     }
        !          1041:   else if (GET_CODE (x) == PARALLEL)
        !          1042:     {
        !          1043:       register int i;
        !          1044:       for (i = XVECLEN (x, 0) - 1; i >= 0; i--)
        !          1045:        {
        !          1046:          register rtx y = XVECEXP (x, 0, i);
        !          1047:          if (GET_CODE (y) == SET || GET_CODE (y) == CLOBBER)
        !          1048:            {
        !          1049:              register rtx dest = SET_DEST (y);
        !          1050:              while ((GET_CODE (dest) == SUBREG
        !          1051:                      && (GET_CODE (SUBREG_REG (dest)) != REG
        !          1052:                          || (REGNO (SUBREG_REG (dest))
        !          1053:                              >= FIRST_PSEUDO_REGISTER)))
        !          1054:                     || GET_CODE (dest) == ZERO_EXTRACT
        !          1055:                     || GET_CODE (dest) == SIGN_EXTRACT
        !          1056:                     || GET_CODE (dest) == STRICT_LOW_PART)
        !          1057:                dest = XEXP (dest, 0);
        !          1058:              (*fun) (dest, y);
        !          1059:            }
        !          1060:        }
        !          1061:     }
        !          1062: }
        !          1063: 
        !          1064: /* Return nonzero if X's old contents don't survive after INSN.
        !          1065:    This will be true if X is (cc0) or if X is a register and
        !          1066:    X dies in INSN or because INSN entirely sets X.
        !          1067: 
        !          1068:    "Entirely set" means set directly and not through a SUBREG,
        !          1069:    ZERO_EXTRACT or SIGN_EXTRACT, so no trace of the old contents remains.
        !          1070:    Likewise, REG_INC does not count.
        !          1071: 
        !          1072:    REG may be a hard or pseudo reg.  Renumbering is not taken into account,
        !          1073:    but for this use that makes no difference, since regs don't overlap
        !          1074:    during their lifetimes.  Therefore, this function may be used
        !          1075:    at any time after deaths have been computed (in flow.c).
        !          1076: 
        !          1077:    If REG is a hard reg that occupies multiple machine registers, this
        !          1078:    function will only return 1 if each of those registers will be replaced
        !          1079:    by INSN.  */
        !          1080: 
        !          1081: int
        !          1082: dead_or_set_p (insn, x)
        !          1083:      rtx insn;
        !          1084:      rtx x;
        !          1085: {
        !          1086:   register int regno, last_regno;
        !          1087:   register int i;
        !          1088: 
        !          1089:   /* Can't use cc0_rtx below since this file is used by genattrtab.c.  */
        !          1090:   if (GET_CODE (x) == CC0)
        !          1091:     return 1;
        !          1092: 
        !          1093:   if (GET_CODE (x) != REG)
        !          1094:     abort ();
        !          1095: 
        !          1096:   regno = REGNO (x);
        !          1097:   last_regno = (regno >= FIRST_PSEUDO_REGISTER ? regno
        !          1098:                : regno + HARD_REGNO_NREGS (regno, GET_MODE (x)) - 1);
        !          1099: 
        !          1100:   for (i = regno; i <= last_regno; i++)
        !          1101:     if (! dead_or_set_regno_p (insn, i))
        !          1102:       return 0;
        !          1103: 
        !          1104:   return 1;
        !          1105: }
        !          1106: 
        !          1107: /* Utility function for dead_or_set_p to check an individual register.  Also
        !          1108:    called from flow.c.  */
        !          1109: 
        !          1110: int
        !          1111: dead_or_set_regno_p (insn, test_regno)
        !          1112:      rtx insn;
        !          1113:      int test_regno;
        !          1114: {
        !          1115:   int regno, endregno;
        !          1116:   rtx link;
        !          1117: 
        !          1118:   /* See if there is a death note for something that includes TEST_REGNO.  */
        !          1119:   for (link = REG_NOTES (insn); link; link = XEXP (link, 1))
        !          1120:     {
        !          1121:       if (REG_NOTE_KIND (link) != REG_DEAD || GET_CODE (XEXP (link, 0)) != REG)
        !          1122:        continue;
        !          1123: 
        !          1124:       regno = REGNO (XEXP (link, 0));
        !          1125:       endregno = (regno >= FIRST_PSEUDO_REGISTER ? regno + 1
        !          1126:                  : regno + HARD_REGNO_NREGS (regno,
        !          1127:                                              GET_MODE (XEXP (link, 0))));
        !          1128: 
        !          1129:       if (test_regno >= regno && test_regno < endregno)
        !          1130:        return 1;
        !          1131:     }
        !          1132: 
        !          1133:   if (GET_CODE (PATTERN (insn)) == SET)
        !          1134:     {
        !          1135:       rtx dest = SET_DEST (PATTERN (insn));
        !          1136:  
        !          1137:       /* A value is totally replaced if it is the destination or the
        !          1138:         destination is a SUBREG of REGNO that does not change the number of
        !          1139:         words in it.  */
        !          1140:      if (GET_CODE (dest) == SUBREG
        !          1141:          && (((GET_MODE_SIZE (GET_MODE (dest))
        !          1142:                + UNITS_PER_WORD - 1) / UNITS_PER_WORD)
        !          1143:              == ((GET_MODE_SIZE (GET_MODE (SUBREG_REG (dest)))
        !          1144:                   + UNITS_PER_WORD - 1) / UNITS_PER_WORD)))
        !          1145:        dest = SUBREG_REG (dest);
        !          1146: 
        !          1147:       if (GET_CODE (dest) != REG)
        !          1148:        return 0;
        !          1149: 
        !          1150:       regno = REGNO (dest);
        !          1151:       endregno = (regno >= FIRST_PSEUDO_REGISTER ? regno + 1
        !          1152:                  : regno + HARD_REGNO_NREGS (regno, GET_MODE (dest)));
        !          1153: 
        !          1154:       return (test_regno >= regno && test_regno < endregno);
        !          1155:     }
        !          1156:   else if (GET_CODE (PATTERN (insn)) == PARALLEL)
        !          1157:     {
        !          1158:       register int i;
        !          1159: 
        !          1160:       for (i = XVECLEN (PATTERN (insn), 0) - 1; i >= 0; i--)
        !          1161:        {
        !          1162:          rtx body = XVECEXP (PATTERN (insn), 0, i);
        !          1163: 
        !          1164:          if (GET_CODE (body) == SET || GET_CODE (body) == CLOBBER)
        !          1165:            {
        !          1166:              rtx dest = SET_DEST (body);
        !          1167: 
        !          1168:              if (GET_CODE (dest) == SUBREG
        !          1169:                  && (((GET_MODE_SIZE (GET_MODE (dest))
        !          1170:                        + UNITS_PER_WORD - 1) / UNITS_PER_WORD)
        !          1171:                      == ((GET_MODE_SIZE (GET_MODE (SUBREG_REG (dest)))
        !          1172:                           + UNITS_PER_WORD - 1) / UNITS_PER_WORD)))
        !          1173:                dest = SUBREG_REG (dest);
        !          1174: 
        !          1175:              if (GET_CODE (dest) != REG)
        !          1176:                continue;
        !          1177: 
        !          1178:              regno = REGNO (dest);
        !          1179:              endregno = (regno >= FIRST_PSEUDO_REGISTER ? regno + 1
        !          1180:                          : regno + HARD_REGNO_NREGS (regno, GET_MODE (dest)));
        !          1181: 
        !          1182:              if (test_regno >= regno && test_regno < endregno)
        !          1183:                return 1;
        !          1184:            }
        !          1185:        }
        !          1186:     }
        !          1187: 
        !          1188:   return 0;
        !          1189: }
        !          1190: 
        !          1191: /* Return the reg-note of kind KIND in insn INSN, if there is one.
        !          1192:    If DATUM is nonzero, look for one whose datum is DATUM.  */
        !          1193: 
        !          1194: rtx
        !          1195: find_reg_note (insn, kind, datum)
        !          1196:      rtx insn;
        !          1197:      enum reg_note kind;
        !          1198:      rtx datum;
        !          1199: {
        !          1200:   register rtx link;
        !          1201: 
        !          1202:   for (link = REG_NOTES (insn); link; link = XEXP (link, 1))
        !          1203:     if (REG_NOTE_KIND (link) == kind
        !          1204:        && (datum == 0 || datum == XEXP (link, 0)))
        !          1205:       return link;
        !          1206:   return 0;
        !          1207: }
        !          1208: 
        !          1209: /* Return the reg-note of kind KIND in insn INSN which applies to register
        !          1210:    number REGNO, if any.  Return 0 if there is no such reg-note.  Note that
        !          1211:    the REGNO of this NOTE need not be REGNO if REGNO is a hard register;
        !          1212:    it might be the case that the note overlaps REGNO.  */
        !          1213: 
        !          1214: rtx
        !          1215: find_regno_note (insn, kind, regno)
        !          1216:      rtx insn;
        !          1217:      enum reg_note kind;
        !          1218:      int regno;
        !          1219: {
        !          1220:   register rtx link;
        !          1221: 
        !          1222:   for (link = REG_NOTES (insn); link; link = XEXP (link, 1))
        !          1223:     if (REG_NOTE_KIND (link) == kind
        !          1224:        /* Verify that it is a register, so that scratch and MEM won't cause a
        !          1225:           problem here.  */
        !          1226:        && GET_CODE (XEXP (link, 0)) == REG
        !          1227:        && REGNO (XEXP (link, 0)) <= regno
        !          1228:        && ((REGNO (XEXP (link, 0))
        !          1229:             + (REGNO (XEXP (link, 0)) >= FIRST_PSEUDO_REGISTER ? 1
        !          1230:                : HARD_REGNO_NREGS (REGNO (XEXP (link, 0)),
        !          1231:                                    GET_MODE (XEXP (link, 0)))))
        !          1232:            > regno))
        !          1233:       return link;
        !          1234:   return 0;
        !          1235: }
        !          1236: 
        !          1237: /* Remove register note NOTE from the REG_NOTES of INSN.  */
        !          1238: 
        !          1239: void
        !          1240: remove_note (insn, note)
        !          1241:      register rtx note;
        !          1242:      register rtx insn;
        !          1243: {
        !          1244:   register rtx link;
        !          1245: 
        !          1246:   if (REG_NOTES (insn) == note)
        !          1247:     {
        !          1248:       REG_NOTES (insn) = XEXP (note, 1);
        !          1249:       return;
        !          1250:     }
        !          1251: 
        !          1252:   for (link = REG_NOTES (insn); link; link = XEXP (link, 1))
        !          1253:     if (XEXP (link, 1) == note)
        !          1254:       {
        !          1255:        XEXP (link, 1) = XEXP (note, 1);
        !          1256:        return;
        !          1257:       }
        !          1258: 
        !          1259:   abort ();
        !          1260: }
        !          1261: 
        !          1262: /* Nonzero if X contains any volatile instructions.  These are instructions
        !          1263:    which may cause unpredictable machine state instructions, and thus no
        !          1264:    instructions should be moved or combined across them.  This includes
        !          1265:    only volatile asms and UNSPEC_VOLATILE instructions.  */
        !          1266: 
        !          1267: int
        !          1268: volatile_insn_p (x)
        !          1269:      rtx x;
        !          1270: {
        !          1271:   register RTX_CODE code;
        !          1272: 
        !          1273:   code = GET_CODE (x);
        !          1274:   switch (code)
        !          1275:     {
        !          1276:     case LABEL_REF:
        !          1277:     case SYMBOL_REF:
        !          1278:     case CONST_INT:
        !          1279:     case CONST:
        !          1280:     case CONST_DOUBLE:
        !          1281:     case CC0:
        !          1282:     case PC:
        !          1283:     case REG:
        !          1284:     case SCRATCH:
        !          1285:     case CLOBBER:
        !          1286:     case ASM_INPUT:
        !          1287:     case ADDR_VEC:
        !          1288:     case ADDR_DIFF_VEC:
        !          1289:     case CALL:
        !          1290:     case MEM:
        !          1291:       return 0;
        !          1292: 
        !          1293:     case UNSPEC_VOLATILE:
        !          1294:  /* case TRAP_IF: This isn't clear yet.  */
        !          1295:       return 1;
        !          1296: 
        !          1297:     case ASM_OPERANDS:
        !          1298:       if (MEM_VOLATILE_P (x))
        !          1299:        return 1;
        !          1300:     }
        !          1301: 
        !          1302:   /* Recursively scan the operands of this expression.  */
        !          1303: 
        !          1304:   {
        !          1305:     register char *fmt = GET_RTX_FORMAT (code);
        !          1306:     register int i;
        !          1307:     
        !          1308:     for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)
        !          1309:       {
        !          1310:        if (fmt[i] == 'e')
        !          1311:          {
        !          1312:            if (volatile_refs_p (XEXP (x, i)))
        !          1313:              return 1;
        !          1314:          }
        !          1315:        if (fmt[i] == 'E')
        !          1316:          {
        !          1317:            register int j;
        !          1318:            for (j = 0; j < XVECLEN (x, i); j++)
        !          1319:              if (volatile_refs_p (XVECEXP (x, i, j)))
        !          1320:                return 1;
        !          1321:          }
        !          1322:       }
        !          1323:   }
        !          1324:   return 0;
        !          1325: }
        !          1326: 
        !          1327: /* Nonzero if X contains any volatile memory references
        !          1328:    UNSPEC_VOLATILE operations or volatile ASM_OPERANDS expressions.  */
        !          1329: 
        !          1330: int
        !          1331: volatile_refs_p (x)
        !          1332:      rtx x;
        !          1333: {
        !          1334:   register RTX_CODE code;
        !          1335: 
        !          1336:   code = GET_CODE (x);
        !          1337:   switch (code)
        !          1338:     {
        !          1339:     case LABEL_REF:
        !          1340:     case SYMBOL_REF:
        !          1341:     case CONST_INT:
        !          1342:     case CONST:
        !          1343:     case CONST_DOUBLE:
        !          1344:     case CC0:
        !          1345:     case PC:
        !          1346:     case REG:
        !          1347:     case SCRATCH:
        !          1348:     case CLOBBER:
        !          1349:     case ASM_INPUT:
        !          1350:     case ADDR_VEC:
        !          1351:     case ADDR_DIFF_VEC:
        !          1352:       return 0;
        !          1353: 
        !          1354:     case CALL:
        !          1355:     case UNSPEC_VOLATILE:
        !          1356:  /* case TRAP_IF: This isn't clear yet.  */
        !          1357:       return 1;
        !          1358: 
        !          1359:     case MEM:
        !          1360:     case ASM_OPERANDS:
        !          1361:       if (MEM_VOLATILE_P (x))
        !          1362:        return 1;
        !          1363:     }
        !          1364: 
        !          1365:   /* Recursively scan the operands of this expression.  */
        !          1366: 
        !          1367:   {
        !          1368:     register char *fmt = GET_RTX_FORMAT (code);
        !          1369:     register int i;
        !          1370:     
        !          1371:     for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)
        !          1372:       {
        !          1373:        if (fmt[i] == 'e')
        !          1374:          {
        !          1375:            if (volatile_refs_p (XEXP (x, i)))
        !          1376:              return 1;
        !          1377:          }
        !          1378:        if (fmt[i] == 'E')
        !          1379:          {
        !          1380:            register int j;
        !          1381:            for (j = 0; j < XVECLEN (x, i); j++)
        !          1382:              if (volatile_refs_p (XVECEXP (x, i, j)))
        !          1383:                return 1;
        !          1384:          }
        !          1385:       }
        !          1386:   }
        !          1387:   return 0;
        !          1388: }
        !          1389: 
        !          1390: /* Similar to above, except that it also rejects register pre- and post-
        !          1391:    incrementing.  */
        !          1392: 
        !          1393: int
        !          1394: side_effects_p (x)
        !          1395:      rtx x;
        !          1396: {
        !          1397:   register RTX_CODE code;
        !          1398: 
        !          1399:   code = GET_CODE (x);
        !          1400:   switch (code)
        !          1401:     {
        !          1402:     case LABEL_REF:
        !          1403:     case SYMBOL_REF:
        !          1404:     case CONST_INT:
        !          1405:     case CONST:
        !          1406:     case CONST_DOUBLE:
        !          1407:     case CC0:
        !          1408:     case PC:
        !          1409:     case REG:
        !          1410:     case SCRATCH:
        !          1411:     case ASM_INPUT:
        !          1412:     case ADDR_VEC:
        !          1413:     case ADDR_DIFF_VEC:
        !          1414:       return 0;
        !          1415: 
        !          1416:     case CLOBBER:
        !          1417:       /* Reject CLOBBER with a non-VOID mode.  These are made by combine.c
        !          1418:         when some combination can't be done.  If we see one, don't think
        !          1419:         that we can simplify the expression.  */
        !          1420:       return (GET_MODE (x) != VOIDmode);
        !          1421: 
        !          1422:     case PRE_INC:
        !          1423:     case PRE_DEC:
        !          1424:     case POST_INC:
        !          1425:     case POST_DEC:
        !          1426:     case CALL:
        !          1427:     case UNSPEC_VOLATILE:
        !          1428:  /* case TRAP_IF: This isn't clear yet.  */
        !          1429:       return 1;
        !          1430: 
        !          1431:     case MEM:
        !          1432:     case ASM_OPERANDS:
        !          1433:       if (MEM_VOLATILE_P (x))
        !          1434:        return 1;
        !          1435:     }
        !          1436: 
        !          1437:   /* Recursively scan the operands of this expression.  */
        !          1438: 
        !          1439:   {
        !          1440:     register char *fmt = GET_RTX_FORMAT (code);
        !          1441:     register int i;
        !          1442:     
        !          1443:     for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)
        !          1444:       {
        !          1445:        if (fmt[i] == 'e')
        !          1446:          {
        !          1447:            if (side_effects_p (XEXP (x, i)))
        !          1448:              return 1;
        !          1449:          }
        !          1450:        if (fmt[i] == 'E')
        !          1451:          {
        !          1452:            register int j;
        !          1453:            for (j = 0; j < XVECLEN (x, i); j++)
        !          1454:              if (side_effects_p (XVECEXP (x, i, j)))
        !          1455:                return 1;
        !          1456:          }
        !          1457:       }
        !          1458:   }
        !          1459:   return 0;
        !          1460: }
        !          1461: 
        !          1462: /* Return nonzero if evaluating rtx X might cause a trap.  */
        !          1463: 
        !          1464: int
        !          1465: may_trap_p (x)
        !          1466:      rtx x;
        !          1467: {
        !          1468:   int i;
        !          1469:   enum rtx_code code;
        !          1470:   char *fmt;
        !          1471: 
        !          1472:   if (x == 0)
        !          1473:     return 0;
        !          1474:   code = GET_CODE (x);
        !          1475:   switch (code)
        !          1476:     {
        !          1477:       /* Handle these cases quickly.  */
        !          1478:     case CONST_INT:
        !          1479:     case CONST_DOUBLE:
        !          1480:     case SYMBOL_REF:
        !          1481:     case LABEL_REF:
        !          1482:     case CONST:
        !          1483:     case PC:
        !          1484:     case CC0:
        !          1485:     case REG:
        !          1486:     case SCRATCH:
        !          1487:       return 0;
        !          1488: 
        !          1489:       /* Conditional trap can trap!  */
        !          1490:     case UNSPEC_VOLATILE:
        !          1491:     case TRAP_IF:
        !          1492:       return 1;
        !          1493: 
        !          1494:       /* Memory ref can trap unless it's a static var or a stack slot.  */
        !          1495:     case MEM:
        !          1496:       return rtx_addr_can_trap_p (XEXP (x, 0));
        !          1497: 
        !          1498:       /* Division by a non-constant might trap.  */
        !          1499:     case DIV:
        !          1500:     case MOD:
        !          1501:     case UDIV:
        !          1502:     case UMOD:
        !          1503:       if (! CONSTANT_P (XEXP (x, 1)))
        !          1504:        return 1;
        !          1505:       /* This was const0_rtx, but by not using that,
        !          1506:         we can link this file into other programs.  */
        !          1507:       if (GET_CODE (XEXP (x, 1)) == CONST_INT && INTVAL (XEXP (x, 1)) == 0)
        !          1508:        return 1;
        !          1509:     default:
        !          1510:       /* Any floating arithmetic may trap.  */
        !          1511:       if (GET_MODE_CLASS (GET_MODE (x)) == MODE_FLOAT)
        !          1512:        return 1;
        !          1513:     }
        !          1514: 
        !          1515:   fmt = GET_RTX_FORMAT (code);
        !          1516:   for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)
        !          1517:     {
        !          1518:       if (fmt[i] == 'e')
        !          1519:        {
        !          1520:          if (may_trap_p (XEXP (x, i)))
        !          1521:            return 1;
        !          1522:        }
        !          1523:       else if (fmt[i] == 'E')
        !          1524:        {
        !          1525:          register int j;
        !          1526:          for (j = 0; j < XVECLEN (x, i); j++)
        !          1527:            if (may_trap_p (XVECEXP (x, i, j)))
        !          1528:              return 1;
        !          1529:        }
        !          1530:     }
        !          1531:   return 0;
        !          1532: }
        !          1533: 
        !          1534: /* Return nonzero if X contains a comparison that is not either EQ or NE,
        !          1535:    i.e., an inequality.  */
        !          1536: 
        !          1537: int
        !          1538: inequality_comparisons_p (x)
        !          1539:      rtx x;
        !          1540: {
        !          1541:   register char *fmt;
        !          1542:   register int len, i;
        !          1543:   register enum rtx_code code = GET_CODE (x);
        !          1544: 
        !          1545:   switch (code)
        !          1546:     {
        !          1547:     case REG:
        !          1548:     case SCRATCH:
        !          1549:     case PC:
        !          1550:     case CC0:
        !          1551:     case CONST_INT:
        !          1552:     case CONST_DOUBLE:
        !          1553:     case CONST:
        !          1554:     case LABEL_REF:
        !          1555:     case SYMBOL_REF:
        !          1556:       return 0;
        !          1557: 
        !          1558:     case LT:
        !          1559:     case LTU:
        !          1560:     case GT:
        !          1561:     case GTU:
        !          1562:     case LE:
        !          1563:     case LEU:
        !          1564:     case GE:
        !          1565:     case GEU:
        !          1566:       return 1;
        !          1567:     }
        !          1568: 
        !          1569:   len = GET_RTX_LENGTH (code);
        !          1570:   fmt = GET_RTX_FORMAT (code);
        !          1571: 
        !          1572:   for (i = 0; i < len; i++)
        !          1573:     {
        !          1574:       if (fmt[i] == 'e')
        !          1575:        {
        !          1576:          if (inequality_comparisons_p (XEXP (x, i)))
        !          1577:            return 1;
        !          1578:        }
        !          1579:       else if (fmt[i] == 'E')
        !          1580:        {
        !          1581:          register int j;
        !          1582:          for (j = XVECLEN (x, i) - 1; j >= 0; j--)
        !          1583:            if (inequality_comparisons_p (XVECEXP (x, i, j)))
        !          1584:              return 1;
        !          1585:        }
        !          1586:     }
        !          1587:            
        !          1588:   return 0;
        !          1589: }
        !          1590: 
        !          1591: /* Replace any occurrence of FROM in X with TO.
        !          1592: 
        !          1593:    Note that copying is not done so X must not be shared unless all copies
        !          1594:    are to be modified.  */
        !          1595: 
        !          1596: rtx
        !          1597: replace_rtx (x, from, to)
        !          1598:      rtx x, from, to;
        !          1599: {
        !          1600:   register int i, j;
        !          1601:   register char *fmt;
        !          1602: 
        !          1603:   if (x == from)
        !          1604:     return to;
        !          1605: 
        !          1606:   /* Allow this function to make replacements in EXPR_LISTs.  */
        !          1607:   if (x == 0)
        !          1608:     return 0;
        !          1609: 
        !          1610:   fmt = GET_RTX_FORMAT (GET_CODE (x));
        !          1611:   for (i = GET_RTX_LENGTH (GET_CODE (x)) - 1; i >= 0; i--)
        !          1612:     {
        !          1613:       if (fmt[i] == 'e')
        !          1614:        XEXP (x, i) = replace_rtx (XEXP (x, i), from, to);
        !          1615:       else if (fmt[i] == 'E')
        !          1616:        for (j = XVECLEN (x, i) - 1; j >= 0; j--)
        !          1617:          XVECEXP (x, i, j) = replace_rtx (XVECEXP (x, i, j), from, to);
        !          1618:     }
        !          1619: 
        !          1620:   return x;
        !          1621: }  
        !          1622: 
        !          1623: /* Throughout the rtx X, replace many registers according to REG_MAP.
        !          1624:    Return the replacement for X (which may be X with altered contents).
        !          1625:    REG_MAP[R] is the replacement for register R, or 0 for don't replace.
        !          1626:    NREGS is the length of REG_MAP; regs >= NREGS are not mapped.  
        !          1627: 
        !          1628:    We only support REG_MAP entries of REG or SUBREG.  Also, hard registers
        !          1629:    should not be mapped to pseudos or vice versa since validate_change
        !          1630:    is not called.
        !          1631: 
        !          1632:    If REPLACE_DEST is 1, replacements are also done in destinations;
        !          1633:    otherwise, only sources are replaced.  */
        !          1634: 
        !          1635: rtx
        !          1636: replace_regs (x, reg_map, nregs, replace_dest)
        !          1637:      rtx x;
        !          1638:      rtx *reg_map;
        !          1639:      int nregs;
        !          1640:      int replace_dest;
        !          1641: {
        !          1642:   register enum rtx_code code;
        !          1643:   register int i;
        !          1644:   register char *fmt;
        !          1645: 
        !          1646:   if (x == 0)
        !          1647:     return x;
        !          1648: 
        !          1649:   code = GET_CODE (x);
        !          1650:   switch (code)
        !          1651:     {
        !          1652:     case SCRATCH:
        !          1653:     case PC:
        !          1654:     case CC0:
        !          1655:     case CONST_INT:
        !          1656:     case CONST_DOUBLE:
        !          1657:     case CONST:
        !          1658:     case SYMBOL_REF:
        !          1659:     case LABEL_REF:
        !          1660:       return x;
        !          1661: 
        !          1662:     case REG:
        !          1663:       /* Verify that the register has an entry before trying to access it.  */
        !          1664:       if (REGNO (x) < nregs && reg_map[REGNO (x)] != 0)
        !          1665:        return reg_map[REGNO (x)];
        !          1666:       return x;
        !          1667: 
        !          1668:     case SUBREG:
        !          1669:       /* Prevent making nested SUBREGs.  */
        !          1670:       if (GET_CODE (SUBREG_REG (x)) == REG && REGNO (SUBREG_REG (x)) < nregs
        !          1671:          && reg_map[REGNO (SUBREG_REG (x))] != 0
        !          1672:          && GET_CODE (reg_map[REGNO (SUBREG_REG (x))]) == SUBREG)
        !          1673:        {
        !          1674:          rtx map_val = reg_map[REGNO (SUBREG_REG (x))];
        !          1675:          rtx map_inner = SUBREG_REG (map_val);
        !          1676: 
        !          1677:          if (GET_MODE (x) == GET_MODE (map_inner))
        !          1678:            return map_inner;
        !          1679:          else
        !          1680:            {
        !          1681:              /* We cannot call gen_rtx here since we may be linked with
        !          1682:                 genattrtab.c.  */
        !          1683:              /* Let's try clobbering the incoming SUBREG and see
        !          1684:                 if this is really safe.  */
        !          1685:              SUBREG_REG (x) = map_inner;
        !          1686:              SUBREG_WORD (x) += SUBREG_WORD (map_val);
        !          1687:              return x;
        !          1688: #if 0
        !          1689:              rtx new = rtx_alloc (SUBREG);
        !          1690:              PUT_MODE (new, GET_MODE (x));
        !          1691:              SUBREG_REG (new) = map_inner;
        !          1692:              SUBREG_WORD (new) = SUBREG_WORD (x) + SUBREG_WORD (map_val);
        !          1693: #endif
        !          1694:            }
        !          1695:        }
        !          1696:       break;
        !          1697: 
        !          1698:     case SET:
        !          1699:       if (replace_dest)
        !          1700:        SET_DEST (x) = replace_regs (SET_DEST (x), reg_map, nregs, 0);
        !          1701: 
        !          1702:       else if (GET_CODE (SET_DEST (x)) == MEM
        !          1703:               || GET_CODE (SET_DEST (x)) == STRICT_LOW_PART)
        !          1704:        /* Even if we are not to replace destinations, replace register if it
        !          1705:           is CONTAINED in destination (destination is memory or
        !          1706:           STRICT_LOW_PART).  */
        !          1707:        XEXP (SET_DEST (x), 0) = replace_regs (XEXP (SET_DEST (x), 0),
        !          1708:                                               reg_map, nregs, 0);
        !          1709:       else if (GET_CODE (SET_DEST (x)) == ZERO_EXTRACT)
        !          1710:        /* Similarly, for ZERO_EXTRACT we replace all operands.  */
        !          1711:        break;
        !          1712: 
        !          1713:       SET_SRC (x) = replace_regs (SET_SRC (x), reg_map, nregs, 0);
        !          1714:       return x;
        !          1715:     }
        !          1716: 
        !          1717:   fmt = GET_RTX_FORMAT (code);
        !          1718:   for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)
        !          1719:     {
        !          1720:       if (fmt[i] == 'e')
        !          1721:        XEXP (x, i) = replace_regs (XEXP (x, i), reg_map, nregs, replace_dest);
        !          1722:       if (fmt[i] == 'E')
        !          1723:        {
        !          1724:          register int j;
        !          1725:          for (j = 0; j < XVECLEN (x, i); j++)
        !          1726:            XVECEXP (x, i, j) = replace_regs (XVECEXP (x, i, j), reg_map,
        !          1727:                                              nregs, replace_dest);
        !          1728:        }
        !          1729:     }
        !          1730:   return x;
        !          1731: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.