Annotation of GNUtools/cc/config/vax/vax.md, revision 1.1.1.1

1.1       root        1: ;;- Machine description for GNU compiler, Vax Version
                      2: ;;   Copyright (C) 1987, 1988, 1991 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: ;;- Instruction patterns.  When multiple patterns apply,
                     22: ;;- the first one in the file is chosen.
                     23: ;;-
                     24: ;;- See file "rtl.def" for documentation on define_insn, match_*, et. al.
                     25: ;;-
                     26: ;;- cpp macro #define NOTICE_UPDATE_CC in file tm.h handles condition code
                     27: ;;- updates for most instructions.
                     28: 
                     29: ;; We don't want to allow a constant operand for test insns because
                     30: ;; (set (cc0) (const_int foo)) has no mode information.  Such insns will
                     31: ;; be folded while optimizing anyway.
                     32: 
                     33: (define_insn "tstsi"
                     34:   [(set (cc0)
                     35:        (match_operand:SI 0 "nonimmediate_operand" "g"))]
                     36:   ""
                     37:   "tstl %0")
                     38: 
                     39: (define_insn "tsthi"
                     40:   [(set (cc0)
                     41:        (match_operand:HI 0 "nonimmediate_operand" "g"))]
                     42:   ""
                     43:   "tstw %0")
                     44: 
                     45: (define_insn "tstqi"
                     46:   [(set (cc0)
                     47:        (match_operand:QI 0 "nonimmediate_operand" "g"))]
                     48:   ""
                     49:   "tstb %0")
                     50: 
                     51: (define_insn "tstdf"
                     52:   [(set (cc0)
                     53:        (match_operand:DF 0 "general_operand" "gF"))]
                     54:   ""
                     55:   "tst%# %0")
                     56: 
                     57: (define_insn "tstsf"
                     58:   [(set (cc0)
                     59:        (match_operand:SF 0 "general_operand" "gF"))]
                     60:   ""
                     61:   "tstf %0")
                     62: 
                     63: (define_insn "cmpsi"
                     64:   [(set (cc0)
                     65:        (compare (match_operand:SI 0 "nonimmediate_operand" "g")
                     66:                 (match_operand:SI 1 "general_operand" "g")))]
                     67:   ""
                     68:   "cmpl %0,%1")
                     69: 
                     70: (define_insn "cmphi"
                     71:   [(set (cc0)
                     72:        (compare (match_operand:HI 0 "nonimmediate_operand" "g")
                     73:                 (match_operand:HI 1 "general_operand" "g")))]
                     74:   ""
                     75:   "cmpw %0,%1")
                     76: 
                     77: (define_insn "cmpqi"
                     78:   [(set (cc0)
                     79:        (compare (match_operand:QI 0 "nonimmediate_operand" "g")
                     80:                 (match_operand:QI 1 "general_operand" "g")))]
                     81:   ""
                     82:   "cmpb %0,%1")
                     83: 
                     84: (define_insn "cmpdf"
                     85:   [(set (cc0)
                     86:        (compare (match_operand:DF 0 "general_operand" "gF,gF")
                     87:                 (match_operand:DF 1 "general_operand" "G,gF")))]
                     88:   ""
                     89:   "@
                     90:    tst%# %0
                     91:    cmp%# %0,%1")
                     92: 
                     93: (define_insn "cmpsf"
                     94:   [(set (cc0)
                     95:        (compare (match_operand:SF 0 "general_operand" "gF,gF")
                     96:                 (match_operand:SF 1 "general_operand" "G,gF")))]
                     97:   ""
                     98:   "@
                     99:    tstf %0
                    100:    cmpf %0,%1")
                    101: 
                    102: (define_insn ""
                    103:   [(set (cc0)
                    104:        (and:SI (match_operand:SI 0 "general_operand" "g")
                    105:                (match_operand:SI 1 "general_operand" "g")))]
                    106:   ""
                    107:   "bitl %0,%1")
                    108: 
                    109: (define_insn ""
                    110:   [(set (cc0)
                    111:        (and:HI (match_operand:HI 0 "general_operand" "g")
                    112:                (match_operand:HI 1 "general_operand" "g")))]
                    113:   ""
                    114:   "bitw %0,%1")
                    115: 
                    116: (define_insn ""
                    117:   [(set (cc0)
                    118:        (and:QI (match_operand:QI 0 "general_operand" "g")
                    119:                (match_operand:QI 1 "general_operand" "g")))]
                    120:   ""
                    121:   "bitb %0,%1")
                    122: 
                    123: ;; The vax has no sltu or sgeu patterns, but does have two-operand
                    124: ;; add/subtract with carry.  This is still better than the alternative.
                    125: ;; Since the cc0-using insn cannot be separated from the cc0-setting insn,
                    126: ;; and the two are created independently, we can't just use a define_expand
                    127: ;; to try to optimize this.  (The "movl" and "clrl" insns alter the cc0
                    128: ;; flags, but leave the carry flag alone, but that can't easily be expressed.)
                    129: ;;
                    130: ;; Several two-operator combinations could be added to make slightly more
                    131: ;; optimal code, but they'd have to cover all combinations of plus and minus
                    132: ;; using match_dup.  If you want to do this, I'd suggest changing the "sgeu"
                    133: ;; pattern to something like (minus (const_int 1) (ltu ...)), so fewer
                    134: ;; patterns need to be recognized.
                    135: ;; -- Ken Raeburn ([email protected]) 24 August 1991.
                    136: 
                    137: (define_insn "sltu"
                    138:   [(set (match_operand:SI 0 "general_operand" "=ro")
                    139:        (ltu (cc0) (const_int 0)))]
                    140:   ""
                    141:   "clrl %0\;adwc $0,%0")
                    142: 
                    143: (define_insn "sgeu"
                    144:   [(set (match_operand:SI 0 "general_operand" "=ro")
                    145:        (geu (cc0) (const_int 0)))]
                    146:   ""
                    147:   "movl $1,%0\;sbwc $0,%0")
                    148: 
                    149: (define_insn "movdf"
                    150:   [(set (match_operand:DF 0 "general_operand" "=g,g")
                    151:        (match_operand:DF 1 "general_operand" "G,gF"))]
                    152:   ""
                    153:   "@
                    154:    clr%# %0
                    155:    mov%# %1,%0")
                    156: 
                    157: (define_insn "movsf"
                    158:   [(set (match_operand:SF 0 "general_operand" "=g,g")
                    159:        (match_operand:SF 1 "general_operand" "G,gF"))]
                    160:   ""
                    161:   "@
                    162:    clrf %0
                    163:    movf %1,%0")
                    164: 
                    165: ;; Some vaxes don't support this instruction.
                    166: ;;(define_insn "movti"
                    167: ;;  [(set (match_operand:TI 0 "general_operand" "=g")
                    168: ;;     (match_operand:TI 1 "general_operand" "g"))]
                    169: ;;  ""
                    170: ;;  "movh %1,%0")
                    171: 
                    172: (define_insn "movdi"
                    173:   [(set (match_operand:DI 0 "general_operand" "=g,g")
                    174:        (match_operand:DI 1 "general_operand" "I,g"))]
                    175:   ""
                    176:   "@
                    177:    clrq %0
                    178:    movq %D1,%0")
                    179: 
                    180: ;; The VAX move instructions have space-time tradeoffs.  On a microVAX
                    181: ;; register-register mov instructions take 3 bytes and 2 CPU cycles.  clrl
                    182: ;; takes 2 bytes and 3 cycles.  mov from constant to register takes 2 cycles
                    183: ;; if the constant is smaller than 4 bytes, 3 cycles for a longword
                    184: ;; constant.  movz, mneg, and mcom are as fast as mov, so movzwl is faster
                    185: ;; than movl for positive constants that fit in 16 bits but not 6 bits.  cvt
                    186: ;; instructions take 4 cycles.  inc takes 3 cycles.  The machine description
                    187: ;; is willing to trade 1 byte for 1 cycle (clrl instead of movl $0; cvtwl
                    188: ;; instead of movl).
                    189: 
                    190: ;; Cycle counts for other models may vary (on a VAX 750 they are similar,
                    191: ;; but on a VAX 9000 most move and add instructions with one constant
                    192: ;; operand take 1 cycle).
                    193: 
                    194: ;;  Loads of constants between 64 and 128 used to be done with
                    195: ;; "addl3 $63,#,dst" but this is slower than movzbl and takes as much space.
                    196: 
                    197: (define_insn "movsi"
                    198:   [(set (match_operand:SI 0 "general_operand" "=g")
                    199:        (match_operand:SI 1 "general_operand" "g"))]
                    200:   ""
                    201:   "*
                    202: {
                    203:   rtx link;
                    204:   if (operands[1] == const1_rtx
                    205:       && (link = find_reg_note (insn, REG_WAS_0, 0))
                    206:       /* Make sure the insn that stored the 0 is still present.  */
                    207:       && ! INSN_DELETED_P (XEXP (link, 0))
                    208:       && GET_CODE (XEXP (link, 0)) != NOTE
                    209:       /* Make sure cross jumping didn't happen here.  */
                    210:       && no_labels_between_p (XEXP (link, 0), insn)
                    211:       /* Make sure the reg hasn't been clobbered.  */
                    212:       && ! reg_set_between_p (operands[0], XEXP (link, 0), insn))
                    213:     return \"incl %0\";
                    214:   if (GET_CODE (operands[1]) == SYMBOL_REF || GET_CODE (operands[1]) == CONST)
                    215:     {
                    216:       if (push_operand (operands[0], SImode))
                    217:        return \"pushab %a1\";
                    218:       return \"movab %a1,%0\";
                    219:     }
                    220:   if (operands[1] == const0_rtx)
                    221:     return \"clrl %0\";
                    222:   if (GET_CODE (operands[1]) == CONST_INT
                    223:       && (unsigned) INTVAL (operands[1]) >= 64)
                    224:     {
                    225:       int i = INTVAL (operands[1]);
                    226:       if ((unsigned)(~i) < 64)
                    227:        return \"mcoml %N1,%0\";
                    228:       if ((unsigned)i < 0x100)
                    229:        return \"movzbl %1,%0\";
                    230:       if (i >= -0x80 && i < 0)
                    231:        return \"cvtbl %1,%0\";
                    232:       if ((unsigned)i < 0x10000)
                    233:        return \"movzwl %1,%0\";
                    234:       if (i >= -0x8000 && i < 0)
                    235:        return \"cvtwl %1,%0\";
                    236:     }
                    237:   if (push_operand (operands[0], SImode))
                    238:     return \"pushl %1\";
                    239:   return \"movl %1,%0\";
                    240: }")
                    241: 
                    242: (define_insn "movhi"
                    243:   [(set (match_operand:HI 0 "general_operand" "=g")
                    244:        (match_operand:HI 1 "general_operand" "g"))]
                    245:   ""
                    246:   "*
                    247: {
                    248:   rtx link;
                    249:   if (operands[1] == const1_rtx
                    250:       && (link = find_reg_note (insn, REG_WAS_0, 0))
                    251:       /* Make sure the insn that stored the 0 is still present.  */
                    252:       && ! INSN_DELETED_P (XEXP (link, 0))
                    253:       && GET_CODE (XEXP (link, 0)) != NOTE
                    254:       /* Make sure cross jumping didn't happen here.  */
                    255:       && no_labels_between_p (XEXP (link, 0), insn)
                    256:       /* Make sure the reg hasn't been clobbered.  */
                    257:       && ! reg_set_between_p (operands[0], XEXP (link, 0), insn))
                    258:     return \"incw %0\";
                    259: 
                    260:   if (GET_CODE (operands[1]) == CONST_INT)
                    261:     {
                    262:       int i = INTVAL (operands[1]);
                    263:       if (i == 0)
                    264:        return \"clrw %0\";
                    265:       else if ((unsigned int)i < 64)
                    266:        return \"movw %1,%0\";
                    267:       else if ((unsigned int)~i < 64)
                    268:        return \"mcomw %H1,%0\";
                    269:       else if ((unsigned int)i < 256)
                    270:        return \"movzbw %1,%0\";
                    271:     }
                    272:   return \"movw %1,%0\";
                    273: }")
                    274: 
                    275: (define_insn "movstricthi"
                    276:   [(set (strict_low_part (match_operand:HI 0 "register_operand" "=g"))
                    277:        (match_operand:HI 1 "general_operand" "g"))]
                    278:   ""
                    279:   "*
                    280: {
                    281:   if (GET_CODE (operands[1]) == CONST_INT)
                    282:     {
                    283:       int i = INTVAL (operands[1]);
                    284:       if (i == 0)
                    285:        return \"clrw %0\";
                    286:       else if ((unsigned int)i < 64)
                    287:        return \"movw %1,%0\";
                    288:       else if ((unsigned int)~i < 64)
                    289:        return \"mcomw %H1,%0\";
                    290:       else if ((unsigned int)i < 256)
                    291:        return \"movzbw %1,%0\";
                    292:     }
                    293:   return \"movw %1,%0\";
                    294: }")
                    295: 
                    296: (define_insn "movqi"
                    297:   [(set (match_operand:QI 0 "general_operand" "=g")
                    298:        (match_operand:QI 1 "general_operand" "g"))]
                    299:   ""
                    300:   "*
                    301: {
                    302:   rtx link;
                    303:   if (operands[1] == const1_rtx
                    304:       && (link = find_reg_note (insn, REG_WAS_0, 0))
                    305:       /* Make sure the insn that stored the 0 is still present.  */
                    306:       && ! INSN_DELETED_P (XEXP (link, 0))
                    307:       && GET_CODE (XEXP (link, 0)) != NOTE
                    308:       /* Make sure cross jumping didn't happen here.  */
                    309:       && no_labels_between_p (XEXP (link, 0), insn)
                    310:       /* Make sure the reg hasn't been clobbered.  */
                    311:       && ! reg_set_between_p (operands[0], XEXP (link, 0), insn))
                    312:     return \"incb %0\";
                    313: 
                    314:   if (GET_CODE (operands[1]) == CONST_INT)
                    315:     {
                    316:       int i = INTVAL (operands[1]);
                    317:       if (i == 0)
                    318:        return \"clrb %0\";
                    319:       else if ((unsigned int)~i < 64)
                    320:        return \"mcomb %B1,%0\";
                    321:     }
                    322:   return \"movb %1,%0\";
                    323: }")
                    324: 
                    325: (define_insn "movstrictqi"
                    326:   [(set (strict_low_part (match_operand:QI 0 "register_operand" "=g"))
                    327:        (match_operand:QI 1 "general_operand" "g"))]
                    328:   ""
                    329:   "*
                    330: {
                    331:   if (GET_CODE (operands[1]) == CONST_INT)
                    332:     {
                    333:       int i = INTVAL (operands[1]);
                    334:       if (i == 0)
                    335:        return \"clrb %0\";
                    336:       else if ((unsigned int)~i < 64)
                    337:        return \"mcomb %B1,%0\";
                    338:     }
                    339:   return \"movb %1,%0\";
                    340: }")
                    341: 
                    342: ;; This is here to accept 4 arguments and pass the first 3 along
                    343: ;; to the movstrhi1 pattern that really does the work.
                    344: (define_expand "movstrhi"
                    345:   [(set (match_operand:BLK 0 "general_operand" "=g")
                    346:        (match_operand:BLK 1 "general_operand" "g"))
                    347:    (use (match_operand:HI 2 "general_operand" "g"))
                    348:    (match_operand 3 "" "")]
                    349:   ""
                    350:   "
                    351:   emit_insn (gen_movstrhi1 (operands[0], operands[1], operands[2]));
                    352:   DONE;
                    353: ")
                    354: 
                    355: ;; The definition of this insn does not really explain what it does,
                    356: ;; but it should suffice
                    357: ;; that anything generated as this insn will be recognized as one
                    358: ;; and that it won't successfully combine with anything.
                    359: (define_insn "movstrhi1"
                    360:   [(set (match_operand:BLK 0 "general_operand" "=g")
                    361:        (match_operand:BLK 1 "general_operand" "g"))
                    362:    (use (match_operand:HI 2 "general_operand" "g"))
                    363:    (clobber (reg:SI 0))
                    364:    (clobber (reg:SI 1))
                    365:    (clobber (reg:SI 2))
                    366:    (clobber (reg:SI 3))
                    367:    (clobber (reg:SI 4))
                    368:    (clobber (reg:SI 5))]
                    369:   ""
                    370:   "movc3 %2,%1,%0")
                    371: 
                    372: ;; Extension and truncation insns.
                    373: 
                    374: (define_insn "truncsiqi2"
                    375:   [(set (match_operand:QI 0 "general_operand" "=g")
                    376:        (truncate:QI (match_operand:SI 1 "nonimmediate_operand" "g")))]
                    377:   ""
                    378:   "cvtlb %1,%0")
                    379: 
                    380: (define_insn "truncsihi2"
                    381:   [(set (match_operand:HI 0 "general_operand" "=g")
                    382:        (truncate:HI (match_operand:SI 1 "nonimmediate_operand" "g")))]
                    383:   ""
                    384:   "cvtlw %1,%0")
                    385: 
                    386: (define_insn "trunchiqi2"
                    387:   [(set (match_operand:QI 0 "general_operand" "=g")
                    388:        (truncate:QI (match_operand:HI 1 "nonimmediate_operand" "g")))]
                    389:   ""
                    390:   "cvtwb %1,%0")
                    391: 
                    392: (define_insn "extendhisi2"
                    393:   [(set (match_operand:SI 0 "general_operand" "=g")
                    394:        (sign_extend:SI (match_operand:HI 1 "nonimmediate_operand" "g")))]
                    395:   ""
                    396:   "cvtwl %1,%0")
                    397: 
                    398: (define_insn "extendqihi2"
                    399:   [(set (match_operand:HI 0 "general_operand" "=g")
                    400:        (sign_extend:HI (match_operand:QI 1 "nonimmediate_operand" "g")))]
                    401:   ""
                    402:   "cvtbw %1,%0")
                    403: 
                    404: (define_insn "extendqisi2"
                    405:   [(set (match_operand:SI 0 "general_operand" "=g")
                    406:        (sign_extend:SI (match_operand:QI 1 "nonimmediate_operand" "g")))]
                    407:   ""
                    408:   "cvtbl %1,%0")
                    409: 
                    410: (define_insn "extendsfdf2"
                    411:   [(set (match_operand:DF 0 "general_operand" "=g")
                    412:        (float_extend:DF (match_operand:SF 1 "general_operand" "gF")))]
                    413:   ""
                    414:   "cvtf%# %1,%0")
                    415: 
                    416: (define_insn "truncdfsf2"
                    417:   [(set (match_operand:SF 0 "general_operand" "=g")
                    418:        (float_truncate:SF (match_operand:DF 1 "general_operand" "gF")))]
                    419:   ""
                    420:   "cvt%#f %1,%0")
                    421: 
                    422: (define_insn "zero_extendhisi2"
                    423:   [(set (match_operand:SI 0 "general_operand" "=g")
                    424:        (zero_extend:SI (match_operand:HI 1 "nonimmediate_operand" "g")))]
                    425:   ""
                    426:   "movzwl %1,%0")
                    427: 
                    428: (define_insn "zero_extendqihi2"
                    429:   [(set (match_operand:HI 0 "general_operand" "=g")
                    430:        (zero_extend:HI (match_operand:QI 1 "nonimmediate_operand" "g")))]
                    431:   ""
                    432:   "movzbw %1,%0")
                    433: 
                    434: (define_insn "zero_extendqisi2"
                    435:   [(set (match_operand:SI 0 "general_operand" "=g")
                    436:        (zero_extend:SI (match_operand:QI 1 "nonimmediate_operand" "g")))]
                    437:   ""
                    438:   "movzbl %1,%0")
                    439: 
                    440: ;; Fix-to-float conversion insns.
                    441: 
                    442: (define_insn "floatsisf2"
                    443:   [(set (match_operand:SF 0 "general_operand" "=g")
                    444:        (float:SF (match_operand:SI 1 "nonimmediate_operand" "g")))]
                    445:   ""
                    446:   "cvtlf %1,%0")
                    447: 
                    448: (define_insn "floatsidf2"
                    449:   [(set (match_operand:DF 0 "general_operand" "=g")
                    450:        (float:DF (match_operand:SI 1 "nonimmediate_operand" "g")))]
                    451:   ""
                    452:   "cvtl%# %1,%0")
                    453: 
                    454: (define_insn "floathisf2"
                    455:   [(set (match_operand:SF 0 "general_operand" "=g")
                    456:        (float:SF (match_operand:HI 1 "nonimmediate_operand" "g")))]
                    457:   ""
                    458:   "cvtwf %1,%0")
                    459: 
                    460: (define_insn "floathidf2"
                    461:   [(set (match_operand:DF 0 "general_operand" "=g")
                    462:        (float:DF (match_operand:HI 1 "nonimmediate_operand" "g")))]
                    463:   ""
                    464:   "cvtw%# %1,%0")
                    465: 
                    466: (define_insn "floatqisf2"
                    467:   [(set (match_operand:SF 0 "general_operand" "=g")
                    468:        (float:SF (match_operand:QI 1 "nonimmediate_operand" "g")))]
                    469:   ""
                    470:   "cvtbf %1,%0")
                    471: 
                    472: (define_insn "floatqidf2"
                    473:   [(set (match_operand:DF 0 "general_operand" "=g")
                    474:        (float:DF (match_operand:QI 1 "nonimmediate_operand" "g")))]
                    475:   ""
                    476:   "cvtb%# %1,%0")
                    477: 
                    478: ;; Float-to-fix conversion insns.
                    479: 
                    480: (define_insn "fix_truncsfqi2"
                    481:   [(set (match_operand:QI 0 "general_operand" "=g")
                    482:        (fix:QI (fix:SF (match_operand:SF 1 "general_operand" "gF"))))]
                    483:   ""
                    484:   "cvtfb %1,%0")
                    485: 
                    486: (define_insn "fix_truncsfhi2"
                    487:   [(set (match_operand:HI 0 "general_operand" "=g")
                    488:        (fix:HI (fix:SF (match_operand:SF 1 "general_operand" "gF"))))]
                    489:   ""
                    490:   "cvtfw %1,%0")
                    491: 
                    492: (define_insn "fix_truncsfsi2"
                    493:   [(set (match_operand:SI 0 "general_operand" "=g")
                    494:        (fix:SI (fix:SF (match_operand:SF 1 "general_operand" "gF"))))]
                    495:   ""
                    496:   "cvtfl %1,%0")
                    497: 
                    498: (define_insn "fix_truncdfqi2"
                    499:   [(set (match_operand:QI 0 "general_operand" "=g")
                    500:        (fix:QI (fix:DF (match_operand:DF 1 "general_operand" "gF"))))]
                    501:   ""
                    502:   "cvt%#b %1,%0")
                    503: 
                    504: (define_insn "fix_truncdfhi2"
                    505:   [(set (match_operand:HI 0 "general_operand" "=g")
                    506:        (fix:HI (fix:DF (match_operand:DF 1 "general_operand" "gF"))))]
                    507:   ""
                    508:   "cvt%#w %1,%0")
                    509: 
                    510: (define_insn "fix_truncdfsi2"
                    511:   [(set (match_operand:SI 0 "general_operand" "=g")
                    512:        (fix:SI (fix:DF (match_operand:DF 1 "general_operand" "gF"))))]
                    513:   ""
                    514:   "cvt%#l %1,%0")
                    515: 
                    516: ;;- All kinds of add instructions.
                    517: 
                    518: (define_insn "adddf3"
                    519:   [(set (match_operand:DF 0 "general_operand" "=g,g,g")
                    520:        (plus:DF (match_operand:DF 1 "general_operand" "0,gF,gF")
                    521:                 (match_operand:DF 2 "general_operand" "gF,0,gF")))]
                    522:   ""
                    523:   "@
                    524:    add%#2 %2,%0
                    525:    add%#2 %1,%0
                    526:    add%#3 %1,%2,%0")
                    527: 
                    528: (define_insn "addsf3"
                    529:   [(set (match_operand:SF 0 "general_operand" "=g,g,g")
                    530:        (plus:SF (match_operand:SF 1 "general_operand" "0,gF,gF")
                    531:                 (match_operand:SF 2 "general_operand" "gF,0,gF")))]
                    532:   ""
                    533:   "@
                    534:    addf2 %2,%0
                    535:    addf2 %1,%0
                    536:    addf3 %1,%2,%0")
                    537: 
                    538: /* The space-time-opcode tradeoffs for addition vary by model of VAX.
                    539: 
                    540:    On a VAX 3 "movab (r1)[r2],r3" is faster than "addl3 r1,r2,r3",
                    541:    but it not faster on other models.
                    542: 
                    543:    "movab #(r1),r2" is usually shorter than "addl3 #,r1,r2", and is
                    544:    faster on a VAX 3, but some VAXes (e.g. VAX 9000) will stall if
                    545:    a register is used in an address too soon after it is set.
                    546:    Compromise by using movab only when it is shorter than the add
                    547:    or the base register in the address is one of sp, ap, and fp,
                    548:    which are not modified very often.  */
                    549: 
                    550: 
                    551: (define_insn "addsi3"
                    552:   [(set (match_operand:SI 0 "general_operand" "=g")
                    553:        (plus:SI (match_operand:SI 1 "general_operand" "g")
                    554:                 (match_operand:SI 2 "general_operand" "g")))]
                    555:   ""
                    556:   "*
                    557: {
                    558:   if (rtx_equal_p (operands[0], operands[1]))
                    559:     {
                    560:       if (operands[2] == const1_rtx)
                    561:        return \"incl %0\";
                    562:       if (operands[2] == constm1_rtx)
                    563:        return \"decl %0\";
                    564:       if (GET_CODE (operands[2]) == CONST_INT
                    565:          && (unsigned) (- INTVAL (operands[2])) < 64)
                    566:        return \"subl2 $%n2,%0\";
                    567:       if (GET_CODE (operands[2]) == CONST_INT
                    568:          && (unsigned) INTVAL (operands[2]) >= 64
                    569:          && GET_CODE (operands[1]) == REG
                    570:          && ((INTVAL (operands[2]) < 32767 && INTVAL (operands[2]) > -32768)
                    571:              || REGNO (operands[1]) > 11))
                    572:        return \"movab %c2(%1),%0\";
                    573:       return \"addl2 %2,%0\";
                    574:     }
                    575:   if (rtx_equal_p (operands[0], operands[2]))
                    576:     return \"addl2 %1,%0\";
                    577: 
                    578:   if (GET_CODE (operands[2]) == CONST_INT
                    579:       && INTVAL (operands[2]) < 32767
                    580:       && INTVAL (operands[2]) > -32768
                    581:       && GET_CODE (operands[1]) == REG
                    582:       && push_operand (operands[0], SImode))
                    583:     return \"pushab %c2(%1)\";
                    584: 
                    585:   if (GET_CODE (operands[2]) == CONST_INT
                    586:       && (unsigned) (- INTVAL (operands[2])) < 64)
                    587:     return \"subl3 $%n2,%1,%0\";
                    588: 
                    589:   if (GET_CODE (operands[2]) == CONST_INT
                    590:       && (unsigned) INTVAL (operands[2]) >= 64
                    591:       && GET_CODE (operands[1]) == REG
                    592:       && ((INTVAL (operands[2]) < 32767 && INTVAL (operands[2]) > -32768)
                    593:          || REGNO (operands[1]) > 11))
                    594:     return \"movab %c2(%1),%0\";
                    595: 
                    596:   /* Add this if using gcc on a VAX 3xxx:
                    597:   if (REG_P (operands[1]) && REG_P (operands[2]))
                    598:     return \"movab (%1)[%2],%0\";
                    599:   */
                    600:   return \"addl3 %1,%2,%0\";
                    601: }")
                    602: 
                    603: (define_insn "addhi3"
                    604:   [(set (match_operand:HI 0 "general_operand" "=g")
                    605:        (plus:HI (match_operand:HI 1 "general_operand" "g")
                    606:                 (match_operand:HI 2 "general_operand" "g")))]
                    607:   ""
                    608:   "*
                    609: {
                    610:   if (rtx_equal_p (operands[0], operands[1]))
                    611:     {
                    612:       if (operands[2] == const1_rtx)
                    613:        return \"incw %0\";
                    614:       if (operands[2] == constm1_rtx)
                    615:        return \"decw %0\";
                    616:       if (GET_CODE (operands[2]) == CONST_INT
                    617:          && (unsigned) (- INTVAL (operands[2])) < 64)
                    618:        return \"subw2 $%n2,%0\";
                    619:       return \"addw2 %2,%0\";
                    620:     }
                    621:   if (rtx_equal_p (operands[0], operands[2]))
                    622:     return \"addw2 %1,%0\";
                    623:   if (GET_CODE (operands[2]) == CONST_INT
                    624:       && (unsigned) (- INTVAL (operands[2])) < 64)
                    625:     return \"subw3 $%n2,%1,%0\";
                    626:   return \"addw3 %1,%2,%0\";
                    627: }")
                    628: 
                    629: (define_insn "addqi3"
                    630:   [(set (match_operand:QI 0 "general_operand" "=g")
                    631:        (plus:QI (match_operand:QI 1 "general_operand" "g")
                    632:                 (match_operand:QI 2 "general_operand" "g")))]
                    633:   ""
                    634:   "*
                    635: {
                    636:   if (rtx_equal_p (operands[0], operands[1]))
                    637:     {
                    638:       if (operands[2] == const1_rtx)
                    639:        return \"incb %0\";
                    640:       if (operands[2] == constm1_rtx)
                    641:        return \"decb %0\";
                    642:       if (GET_CODE (operands[2]) == CONST_INT
                    643:          && (unsigned) (- INTVAL (operands[2])) < 64)
                    644:        return \"subb2 $%n2,%0\";
                    645:       return \"addb2 %2,%0\";
                    646:     }
                    647:   if (rtx_equal_p (operands[0], operands[2]))
                    648:     return \"addb2 %1,%0\";
                    649:   if (GET_CODE (operands[2]) == CONST_INT
                    650:       && (unsigned) (- INTVAL (operands[2])) < 64)
                    651:     return \"subb3 $%n2,%1,%0\";
                    652:   return \"addb3 %1,%2,%0\";
                    653: }")
                    654: 
                    655: ;; The add-with-carry (adwc) instruction only accepts two operands.
                    656: (define_insn "adddi3"
                    657:   [(set (match_operand:DI 0 "general_operand" "=ro>,ro>")
                    658:        (plus:DI (match_operand:DI 1 "general_operand" "%0,ro>")
                    659:                 (match_operand:DI 2 "general_operand" "Fro,F")))]
                    660:   ""
                    661:   "*
                    662: {
                    663:   rtx low[3];
                    664:   char *pattern;
                    665:   int carry = 1;
                    666: 
                    667:   split_quadword_operands (operands, low, 3);
                    668:   /* Add low parts.  */
                    669:   if (rtx_equal_p (operands[0], operands[1]))
                    670:     {
                    671:       if (low[2] == const0_rtx)
                    672:        /* Should examine operand, punt if not POST_INC.  */
                    673:        pattern = \"tstl %0\", carry = 0;
                    674:       else if (low[2] == const1_rtx)
                    675:         pattern = \"incl %0\";
                    676:       else
                    677:         pattern = \"addl2 %2,%0\";
                    678:     }
                    679:   else
                    680:     {
                    681:       if (low[2] == const0_rtx)
                    682:        pattern = \"movl %1,%0\", carry = 0;
                    683:       else
                    684:        pattern = \"addl3 %2,%1,%0\";
                    685:     }
                    686:   if (pattern)
                    687:     output_asm_insn (pattern, low);
                    688:   if (!carry)
                    689:     /* If CARRY is 0, we don't have any carry value to worry about.  */
                    690:     return OUT_FCN (CODE_FOR_addsi3) (operands, insn);
                    691:   /* %0 = C + %1 + %2 */
                    692:   if (!rtx_equal_p (operands[0], operands[1]))
                    693:     output_asm_insn ((operands[1] == const0_rtx
                    694:                      ? \"clrl %0\"
                    695:                      : \"movl %1,%0\"), operands);
                    696:   return \"adwc %2,%0\";
                    697: }")
                    698: 
                    699: ;;- All kinds of subtract instructions.
                    700: 
                    701: (define_insn "subdf3"
                    702:   [(set (match_operand:DF 0 "general_operand" "=g,g")
                    703:        (minus:DF (match_operand:DF 1 "general_operand" "0,gF")
                    704:                  (match_operand:DF 2 "general_operand" "gF,gF")))]
                    705:   ""
                    706:   "@
                    707:    sub%#2 %2,%0
                    708:    sub%#3 %2,%1,%0")
                    709: 
                    710: (define_insn "subsf3"
                    711:   [(set (match_operand:SF 0 "general_operand" "=g,g")
                    712:        (minus:SF (match_operand:SF 1 "general_operand" "0,gF")
                    713:                  (match_operand:SF 2 "general_operand" "gF,gF")))]
                    714:   ""
                    715:   "@
                    716:    subf2 %2,%0
                    717:    subf3 %2,%1,%0")
                    718: 
                    719: (define_insn "subsi3"
                    720:   [(set (match_operand:SI 0 "general_operand" "=g,g")
                    721:        (minus:SI (match_operand:SI 1 "general_operand" "0,g")
                    722:                  (match_operand:SI 2 "general_operand" "g,g")))]
                    723:   ""
                    724:   "@
                    725:    subl2 %2,%0
                    726:    subl3 %2,%1,%0")
                    727: 
                    728: (define_insn "subhi3"
                    729:   [(set (match_operand:HI 0 "general_operand" "=g,g")
                    730:        (minus:HI (match_operand:HI 1 "general_operand" "0,g")
                    731:                  (match_operand:HI 2 "general_operand" "g,g")))]
                    732:   ""
                    733:   "@
                    734:    subw2 %2,%0
                    735:    subw3 %2,%1,%0")
                    736: 
                    737: (define_insn "subqi3"
                    738:   [(set (match_operand:QI 0 "general_operand" "=g,g")
                    739:        (minus:QI (match_operand:QI 1 "general_operand" "0,g")
                    740:                  (match_operand:QI 2 "general_operand" "g,g")))]
                    741:   ""
                    742:   "@
                    743:    subb2 %2,%0
                    744:    subb3 %2,%1,%0")
                    745: 
                    746: ;; The subtract-with-carry (sbwc) instruction only takes two operands.
                    747: (define_insn "subdi3"
                    748:   [(set (match_operand:DI 0 "general_operand" "=or>,or>")
                    749:        (minus:DI (match_operand:DI 1 "general_operand" "0,or>")
                    750:                  (match_operand:DI 2 "general_operand" "For,F")))]
                    751:   ""
                    752:   "*
                    753: {
                    754:   rtx low[3];
                    755:   char *pattern;
                    756:   int carry = 1;
                    757: 
                    758:   split_quadword_operands (operands, low, 3);
                    759:   /* Subtract low parts.  */
                    760:   if (rtx_equal_p (operands[0], operands[1]))
                    761:     {
                    762:       if (low[2] == const0_rtx)
                    763:        pattern = 0, carry = 0;
                    764:       else if (low[2] == constm1_rtx)
                    765:        pattern = \"decl %0\";
                    766:       else
                    767:        pattern = \"subl2 %2,%0\";
                    768:     }
                    769:   else
                    770:     {
                    771:       if (low[2] == constm1_rtx)
                    772:        pattern = \"decl %0\";
                    773:       else if (low[2] == const0_rtx)
                    774:        pattern = OUT_FCN (CODE_FOR_movsi) (low, insn), carry = 0;
                    775:       else
                    776:        pattern = \"subl3 %2,%1,%0\";
                    777:     }
                    778:   if (pattern)
                    779:     output_asm_insn (pattern, low);
                    780:   if (carry)
                    781:     {
                    782:       if (!rtx_equal_p (operands[0], operands[1]))
                    783:        return \"movl %1,%0\;sbwc %2,%0\";
                    784:       return \"sbwc %2,%0\";
                    785:       /* %0 = %2 - %1 - C */
                    786:     }
                    787:   return OUT_FCN (CODE_FOR_subsi3) (operands, insn);
                    788: }")
                    789: 
                    790: ;;- Multiply instructions.
                    791: 
                    792: (define_insn "muldf3"
                    793:   [(set (match_operand:DF 0 "general_operand" "=g,g,g")
                    794:        (mult:DF (match_operand:DF 1 "general_operand" "0,gF,gF")
                    795:                 (match_operand:DF 2 "general_operand" "gF,0,gF")))]
                    796:   ""
                    797:   "@
                    798:    mul%#2 %2,%0
                    799:    mul%#2 %1,%0
                    800:    mul%#3 %1,%2,%0")
                    801: 
                    802: (define_insn "mulsf3"
                    803:   [(set (match_operand:SF 0 "general_operand" "=g,g,g")
                    804:        (mult:SF (match_operand:SF 1 "general_operand" "0,gF,gF")
                    805:                 (match_operand:SF 2 "general_operand" "gF,0,gF")))]
                    806:   ""
                    807:   "@
                    808:    mulf2 %2,%0
                    809:    mulf2 %1,%0
                    810:    mulf3 %1,%2,%0")
                    811: 
                    812: (define_insn "mulsi3"
                    813:   [(set (match_operand:SI 0 "general_operand" "=g,g,g")
                    814:        (mult:SI (match_operand:SI 1 "general_operand" "0,g,g")
                    815:                 (match_operand:SI 2 "general_operand" "g,0,g")))]
                    816:   ""
                    817:   "@
                    818:    mull2 %2,%0
                    819:    mull2 %1,%0
                    820:    mull3 %1,%2,%0")
                    821: 
                    822: (define_insn "mulhi3"
                    823:   [(set (match_operand:HI 0 "general_operand" "=g,g,")
                    824:        (mult:HI (match_operand:HI 1 "general_operand" "0,g,g")
                    825:                 (match_operand:HI 2 "general_operand" "g,0,g")))]
                    826:   ""
                    827:   "@
                    828:    mulw2 %2,%0
                    829:    mulw2 %1,%0
                    830:    mulw3 %1,%2,%0")
                    831: 
                    832: (define_insn "mulqi3"
                    833:   [(set (match_operand:QI 0 "general_operand" "=g,g,g")
                    834:        (mult:QI (match_operand:QI 1 "general_operand" "0,g,g")
                    835:                 (match_operand:QI 2 "general_operand" "g,0,g")))]
                    836:   ""
                    837:   "@
                    838:    mulb2 %2,%0
                    839:    mulb2 %1,%0
                    840:    mulb3 %1,%2,%0")
                    841: 
                    842: (define_insn "mulsidi3"
                    843:   [(set (match_operand:DI 0 "general_operand" "=g")
                    844:        (mult:DI (sign_extend:DI
                    845:                  (match_operand:SI 1 "nonimmediate_operand" "g"))
                    846:                 (sign_extend:DI
                    847:                  (match_operand:SI 2 "nonimmediate_operand" "g"))))]
                    848:   ""
                    849:   "emul %1,%2,$0,%0")
                    850: 
                    851: (define_insn ""
                    852:   [(set (match_operand:DI 0 "general_operand" "=g")
                    853:        (plus:DI
                    854:         (mult:DI (sign_extend:DI
                    855:                   (match_operand:SI 1 "nonimmediate_operand" "g"))
                    856:                  (sign_extend:DI
                    857:                   (match_operand:SI 2 "nonimmediate_operand" "g")))
                    858:         (sign_extend:DI (match_operand:SI 3 "nonimmediate_operand" "g"))))]
                    859:   ""
                    860:   "emul %1,%2,%3,%0")
                    861: 
                    862: ;; 'F' constraint means type CONST_DOUBLE
                    863: (define_insn ""
                    864:   [(set (match_operand:DI 0 "general_operand" "=g")
                    865:        (plus:DI
                    866:         (mult:DI (sign_extend:DI
                    867:                   (match_operand:SI 1 "nonimmediate_operand" "g"))
                    868:                  (sign_extend:DI
                    869:                   (match_operand:SI 2 "nonimmediate_operand" "g")))
                    870:         (match_operand:DI 3 "immediate_operand" "F")))]
                    871:   "GET_CODE (operands[3]) == CONST_DOUBLE 
                    872:     && CONST_DOUBLE_HIGH (operands[3]) == (CONST_DOUBLE_LOW (operands[3]) >> 31)"
                    873:   "*
                    874: {
                    875:   if (CONST_DOUBLE_HIGH (operands[3]))
                    876:     operands[3] = gen_rtx (CONST_INT, VOIDmode, CONST_DOUBLE_LOW (operands[3]));
                    877:   return \"emul %1,%2,%3,%0\";
                    878: }")
                    879: 
                    880: ;;- Divide instructions.
                    881: 
                    882: (define_insn "divdf3"
                    883:   [(set (match_operand:DF 0 "general_operand" "=g,g")
                    884:        (div:DF (match_operand:DF 1 "general_operand" "0,gF")
                    885:                (match_operand:DF 2 "general_operand" "gF,gF")))]
                    886:   ""
                    887:   "@
                    888:    div%#2 %2,%0
                    889:    div%#3 %2,%1,%0")
                    890: 
                    891: (define_insn "divsf3"
                    892:   [(set (match_operand:SF 0 "general_operand" "=g,g")
                    893:        (div:SF (match_operand:SF 1 "general_operand" "0,gF")
                    894:                (match_operand:SF 2 "general_operand" "gF,gF")))]
                    895:   ""
                    896:   "@
                    897:    divf2 %2,%0
                    898:    divf3 %2,%1,%0")
                    899: 
                    900: (define_insn "divsi3"
                    901:   [(set (match_operand:SI 0 "general_operand" "=g,g")
                    902:        (div:SI (match_operand:SI 1 "general_operand" "0,g")
                    903:                (match_operand:SI 2 "general_operand" "g,g")))]
                    904:   ""
                    905:   "@
                    906:    divl2 %2,%0
                    907:    divl3 %2,%1,%0")
                    908: 
                    909: (define_insn "divhi3"
                    910:   [(set (match_operand:HI 0 "general_operand" "=g,g")
                    911:        (div:HI (match_operand:HI 1 "general_operand" "0,g")
                    912:                (match_operand:HI 2 "general_operand" "g,g")))]
                    913:   ""
                    914:   "@
                    915:    divw2 %2,%0
                    916:    divw3 %2,%1,%0")
                    917: 
                    918: (define_insn "divqi3"
                    919:   [(set (match_operand:QI 0 "general_operand" "=g,g")
                    920:        (div:QI (match_operand:QI 1 "general_operand" "0,g")
                    921:                (match_operand:QI 2 "general_operand" "g,g")))]
                    922:   ""
                    923:   "@
                    924:    divb2 %2,%0
                    925:    divb3 %2,%1,%0")
                    926: 
                    927: ;This is left out because it is very slow;
                    928: ;we are better off programming around the "lack" of this insn.
                    929: ;(define_insn "divmoddisi4"
                    930: ;  [(set (match_operand:SI 0 "general_operand" "=g")
                    931: ;      (div:SI (match_operand:DI 1 "general_operand" "g")
                    932: ;              (match_operand:SI 2 "general_operand" "g")))
                    933: ;   (set (match_operand:SI 3 "general_operand" "=g")
                    934: ;      (mod:SI (match_operand:DI 1 "general_operand" "g")
                    935: ;              (match_operand:SI 2 "general_operand" "g")))]
                    936: ;  ""
                    937: ;  "ediv %2,%1,%0,%3")
                    938: 
                    939: ;; Bit-and on the vax is done with a clear-bits insn.
                    940: (define_expand "andsi3"
                    941:   [(set (match_operand:SI 0 "general_operand" "=g")
                    942:        (and:SI (not:SI (match_operand:SI 1 "general_operand" "g"))
                    943:                (match_operand:SI 2 "general_operand" "g")))]
                    944:   ""
                    945:   "
                    946: {
                    947:   rtx op1 = operands[1];
                    948: 
                    949:   /* If there is a constant argument, complement that one.  */
                    950:   if (GET_CODE (operands[2]) == CONST_INT && GET_CODE (op1) != CONST_INT)
                    951:     {
                    952:       operands[1] = operands[2];
                    953:       operands[2] = op1;
                    954:       op1 = operands[1];
                    955:     }
                    956: 
                    957:   if (GET_CODE (op1) == CONST_INT)
                    958:     operands[1] = gen_rtx (CONST_INT, VOIDmode, ~INTVAL (op1));
                    959:   else
                    960:     operands[1] = expand_unop (SImode, one_cmpl_optab, op1, 0, 1);
                    961: }")
                    962: 
                    963: (define_expand "andhi3"
                    964:   [(set (match_operand:HI 0 "general_operand" "=g")
                    965:        (and:HI (not:HI (match_operand:HI 1 "general_operand" "g"))
                    966:                (match_operand:HI 2 "general_operand" "g")))]
                    967:   ""
                    968:   "
                    969: {
                    970:   rtx op1 = operands[1];
                    971: 
                    972:   if (GET_CODE (operands[2]) == CONST_INT && GET_CODE (op1) != CONST_INT)
                    973:     {
                    974:       operands[1] = operands[2];
                    975:       operands[2] = op1;
                    976:       op1 = operands[1];
                    977:     }
                    978: 
                    979:   if (GET_CODE (op1) == CONST_INT)
                    980:     operands[1] = gen_rtx (CONST_INT, VOIDmode, 65535 & ~INTVAL (op1));
                    981:   else
                    982:     operands[1] = expand_unop (HImode, one_cmpl_optab, op1, 0, 1);
                    983: }")
                    984: 
                    985: (define_expand "andqi3"
                    986:   [(set (match_operand:QI 0 "general_operand" "=g")
                    987:        (and:QI (not:QI (match_operand:QI 1 "general_operand" "g"))
                    988:                (match_operand:QI 2 "general_operand" "g")))]
                    989:   ""
                    990:   "
                    991: {
                    992:   rtx op1 = operands[1];
                    993: 
                    994:   if (GET_CODE (operands[2]) == CONST_INT && GET_CODE (op1) != CONST_INT)
                    995:     {
                    996:      operands[1] = operands[2];
                    997:      operands[2] = op1;
                    998:      op1 = operands[1];
                    999:    }
                   1000: 
                   1001:   if (GET_CODE (op1) == CONST_INT)
                   1002:     operands[1] = gen_rtx (CONST_INT, VOIDmode, 255 & ~INTVAL (op1));
                   1003:   else
                   1004:     operands[1] = expand_unop (QImode, one_cmpl_optab, op1, 0, 1);
                   1005: }")
                   1006: 
                   1007: (define_insn ""
                   1008:   [(set (match_operand:SI 0 "general_operand" "=g,g")
                   1009:        (and:SI (not:SI (match_operand:SI 1 "general_operand" "g,g"))
                   1010:                (match_operand:SI 2 "general_operand" "0,g")))]
                   1011:   ""
                   1012:   "@
                   1013:    bicl2 %1,%0
                   1014:    bicl3 %1,%2,%0")
                   1015: 
                   1016: (define_insn ""
                   1017:   [(set (match_operand:HI 0 "general_operand" "=g,g")
                   1018:        (and:HI (not:HI (match_operand:HI 1 "general_operand" "g,g"))
                   1019:                (match_operand:HI 2 "general_operand" "0,g")))]
                   1020:   ""
                   1021:   "@
                   1022:    bicw2 %1,%0
                   1023:    bicw3 %1,%2,%0")
                   1024: 
                   1025: (define_insn ""
                   1026:   [(set (match_operand:QI 0 "general_operand" "=g,g")
                   1027:        (and:QI (not:QI (match_operand:QI 1 "general_operand" "g,g"))
                   1028:                (match_operand:QI 2 "general_operand" "0,g")))]
                   1029:   ""
                   1030:   "@
                   1031:    bicb2 %1,%0
                   1032:    bicb3 %1,%2,%0")
                   1033: 
                   1034: ;; The following used to be needed because constant propagation can
                   1035: ;; create them starting from the bic insn patterns above.  This is no
                   1036: ;; longer a problem.  However, having these patterns allows optimization
                   1037: ;; opportunities in combine.c.
                   1038: 
                   1039: (define_insn ""
                   1040:   [(set (match_operand:SI 0 "general_operand" "=g,g")
                   1041:        (and:SI (match_operand:SI 1 "general_operand" "0,g")
                   1042:                (match_operand:SI 2 "const_int_operand" "n,n")))]
                   1043:   ""
                   1044:   "@
                   1045:    bicl2 %N2,%0
                   1046:    bicl3 %N2,%1,%0")
                   1047: 
                   1048: (define_insn ""
                   1049:   [(set (match_operand:HI 0 "general_operand" "=g,g")
                   1050:        (and:HI (match_operand:HI 1 "general_operand" "0,g")
                   1051:                (match_operand:HI 2 "const_int_operand" "n,n")))]
                   1052:   ""
                   1053:   "@
                   1054:    bicw2 %H2,%0
                   1055:    bicw3 %H2,%1,%0")
                   1056: 
                   1057: (define_insn ""
                   1058:   [(set (match_operand:QI 0 "general_operand" "=g,g")
                   1059:        (and:QI (match_operand:QI 1 "general_operand" "0,g")
                   1060:                (match_operand:QI 2 "const_int_operand" "n,n")))]
                   1061:   ""
                   1062:   "@
                   1063:    bicb2 %B2,%0
                   1064:    bicb3 %B2,%1,%0")
                   1065: 
                   1066: ;;- Bit set instructions.
                   1067: 
                   1068: (define_insn "iorsi3"
                   1069:   [(set (match_operand:SI 0 "general_operand" "=g,g,g")
                   1070:        (ior:SI (match_operand:SI 1 "general_operand" "0,g,g")
                   1071:                (match_operand:SI 2 "general_operand" "g,0,g")))]
                   1072:   ""
                   1073:   "@
                   1074:    bisl2 %2,%0
                   1075:    bisl2 %1,%0
                   1076:    bisl3 %2,%1,%0")
                   1077: 
                   1078: (define_insn "iorhi3"
                   1079:   [(set (match_operand:HI 0 "general_operand" "=g,g,g")
                   1080:        (ior:HI (match_operand:HI 1 "general_operand" "0,g,g")
                   1081:                (match_operand:HI 2 "general_operand" "g,0,g")))]
                   1082:   ""
                   1083:   "@
                   1084:    bisw2 %2,%0
                   1085:    bisw2 %1,%0
                   1086:    bisw3 %2,%1,%0")
                   1087: 
                   1088: (define_insn "iorqi3"
                   1089:   [(set (match_operand:QI 0 "general_operand" "=g,g,g")
                   1090:        (ior:QI (match_operand:QI 1 "general_operand" "0,g,g")
                   1091:                (match_operand:QI 2 "general_operand" "g,0,g")))]
                   1092:   ""
                   1093:   "@
                   1094:    bisb2 %2,%0
                   1095:    bisb2 %1,%0
                   1096:    bisb3 %2,%1,%0")
                   1097: 
                   1098: ;;- xor instructions.
                   1099: 
                   1100: (define_insn "xorsi3"
                   1101:   [(set (match_operand:SI 0 "general_operand" "=g,g,g")
                   1102:        (xor:SI (match_operand:SI 1 "general_operand" "0,g,g")
                   1103:                (match_operand:SI 2 "general_operand" "g,0,g")))]
                   1104:   ""
                   1105:   "@
                   1106:    xorl2 %2,%0
                   1107:    xorl2 %1,%0
                   1108:    xorl3 %2,%1,%0")
                   1109: 
                   1110: (define_insn "xorhi3"
                   1111:   [(set (match_operand:HI 0 "general_operand" "=g,g,g")
                   1112:        (xor:HI (match_operand:HI 1 "general_operand" "0,g,g")
                   1113:                (match_operand:HI 2 "general_operand" "g,0,g")))]
                   1114:   ""
                   1115:   "@
                   1116:    xorw2 %2,%0
                   1117:    xorw2 %1,%0
                   1118:    xorw3 %2,%1,%0")
                   1119: 
                   1120: (define_insn "xorqi3"
                   1121:   [(set (match_operand:QI 0 "general_operand" "=g,g,g")
                   1122:        (xor:QI (match_operand:QI 1 "general_operand" "0,g,g")
                   1123:                (match_operand:QI 2 "general_operand" "g,0,g")))]
                   1124:   ""
                   1125:   "@
                   1126:    xorb2 %2,%0
                   1127:    xorb2 %1,%0
                   1128:    xorb3 %2,%1,%0")
                   1129: 
                   1130: (define_insn "negdf2"
                   1131:   [(set (match_operand:DF 0 "general_operand" "=g")
                   1132:        (neg:DF (match_operand:DF 1 "general_operand" "gF")))]
                   1133:   ""
                   1134:   "mneg%# %1,%0")
                   1135: 
                   1136: (define_insn "negsf2"
                   1137:   [(set (match_operand:SF 0 "general_operand" "=g")
                   1138:        (neg:SF (match_operand:SF 1 "general_operand" "gF")))]
                   1139:   ""
                   1140:   "mnegf %1,%0")
                   1141: 
                   1142: (define_insn "negsi2"
                   1143:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1144:        (neg:SI (match_operand:SI 1 "general_operand" "g")))]
                   1145:   ""
                   1146:   "mnegl %1,%0")
                   1147: 
                   1148: (define_insn "neghi2"
                   1149:   [(set (match_operand:HI 0 "general_operand" "=g")
                   1150:        (neg:HI (match_operand:HI 1 "general_operand" "g")))]
                   1151:   ""
                   1152:   "mnegw %1,%0")
                   1153: 
                   1154: (define_insn "negqi2"
                   1155:   [(set (match_operand:QI 0 "general_operand" "=g")
                   1156:        (neg:QI (match_operand:QI 1 "general_operand" "g")))]
                   1157:   ""
                   1158:   "mnegb %1,%0")
                   1159: 
                   1160: (define_insn "one_cmplsi2"
                   1161:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1162:        (not:SI (match_operand:SI 1 "general_operand" "g")))]
                   1163:   ""
                   1164:   "mcoml %1,%0")
                   1165: 
                   1166: (define_insn "one_cmplhi2"
                   1167:   [(set (match_operand:HI 0 "general_operand" "=g")
                   1168:        (not:HI (match_operand:HI 1 "general_operand" "g")))]
                   1169:   ""
                   1170:   "mcomw %1,%0")
                   1171: 
                   1172: (define_insn "one_cmplqi2"
                   1173:   [(set (match_operand:QI 0 "general_operand" "=g")
                   1174:        (not:QI (match_operand:QI 1 "general_operand" "g")))]
                   1175:   ""
                   1176:   "mcomb %1,%0")
                   1177: 
                   1178: ;; Arithmetic right shift on the vax works by negating the shift count,
                   1179: ;; then emitting a right shift with the shift count negated.  This means
                   1180: ;; that all actual shift counts in the RTL will be positive.  This 
                   1181: ;; prevents converting shifts to ZERO_EXTRACTs with negative positions,
                   1182: ;; which isn't valid.
                   1183: (define_expand "ashrsi3"
                   1184:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1185:        (ashiftrt:SI (match_operand:SI 1 "general_operand" "g")
                   1186:                   (match_operand:QI 2 "general_operand" "g")))]
                   1187:   ""
                   1188:   "
                   1189: {
                   1190:   if (GET_CODE (operands[2]) != CONST_INT)
                   1191:     operands[2] = gen_rtx (NEG, QImode, negate_rtx (QImode, operands[2]));
                   1192: }")
                   1193: 
                   1194: (define_insn ""
                   1195:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1196:        (ashiftrt:SI (match_operand:SI 1 "general_operand" "g")
                   1197:                     (match_operand:QI 2 "const_int_operand" "n")))]
                   1198:   ""
                   1199:   "ashl $%n2,%1,%0")
                   1200: 
                   1201: (define_insn ""
                   1202:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1203:        (ashiftrt:SI (match_operand:SI 1 "general_operand" "g")
                   1204:                     (neg:QI (match_operand:QI 2 "general_operand" "g"))))]
                   1205:   ""
                   1206:   "ashl %2,%1,%0")
                   1207: 
                   1208: (define_insn "ashlsi3"
                   1209:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1210:        (ashift:SI (match_operand:SI 1 "general_operand" "g")
                   1211:                   (match_operand:QI 2 "general_operand" "g")))]
                   1212:   ""
                   1213:   "*
                   1214: {
                   1215:   if (operands[2] == const1_rtx && rtx_equal_p (operands[0], operands[1]))
                   1216:     return \"addl2 %0,%0\";
                   1217:   if (GET_CODE (operands[1]) == REG
                   1218:       && GET_CODE (operands[2]) == CONST_INT)
                   1219:     {
                   1220:       int i = INTVAL (operands[2]);
                   1221:       if (i == 1)
                   1222:        return \"addl3 %1,%1,%0\";
                   1223:       if (i == 2)
                   1224:        return \"moval 0[%1],%0\";
                   1225:       if (i == 3)
                   1226:        return \"movad 0[%1],%0\";
                   1227:     }
                   1228:   return \"ashl %2,%1,%0\";
                   1229: }")
                   1230: 
                   1231: ;; Arithmetic right shift on the vax works by negating the shift count.
                   1232: (define_expand "ashrdi3"
                   1233:   [(set (match_operand:DI 0 "general_operand" "=g")
                   1234:        (ashiftrt:DI (match_operand:DI 1 "general_operand" "g")
                   1235:                     (match_operand:QI 2 "general_operand" "g")))]
                   1236:   ""
                   1237:   "
                   1238: {
                   1239:   operands[2] = gen_rtx (NEG, QImode, negate_rtx (QImode, operands[2]));
                   1240: }")
                   1241: 
                   1242: (define_insn "ashldi3"
                   1243:   [(set (match_operand:DI 0 "general_operand" "=g")
                   1244:        (ashift:DI (match_operand:DI 1 "general_operand" "g")
                   1245:                   (match_operand:QI 2 "general_operand" "g")))]
                   1246:   ""
                   1247:   "ashq %2,%1,%0")
                   1248: 
                   1249: (define_insn ""
                   1250:   [(set (match_operand:DI 0 "general_operand" "=g")
                   1251:        (ashiftrt:DI (match_operand:DI 1 "general_operand" "g")
                   1252:                     (neg:QI (match_operand:QI 2 "general_operand" "g"))))]
                   1253:   ""
                   1254:   "ashq %2,%1,%0")
                   1255: 
                   1256: ;; Rotate right on the vax works by negating the shift count.
                   1257: (define_expand "rotrsi3"
                   1258:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1259:        (rotatert:SI (match_operand:SI 1 "general_operand" "g")
                   1260:                     (match_operand:QI 2 "general_operand" "g")))]
                   1261:   ""
                   1262:   "
                   1263: {
                   1264:   if (GET_CODE (operands[2]) != CONST_INT)
                   1265:     operands[2] = gen_rtx (NEG, QImode, negate_rtx (QImode, operands[2]));
                   1266: }")
                   1267: 
                   1268: (define_insn "rotlsi3"
                   1269:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1270:        (rotate:SI (match_operand:SI 1 "general_operand" "g")
                   1271:                   (match_operand:QI 2 "general_operand" "g")))]
                   1272:   ""
                   1273:   "rotl %2,%1,%0")
                   1274: 
                   1275: (define_insn ""
                   1276:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1277:        (rotatert:SI (match_operand:SI 1 "general_operand" "g")
                   1278:                     (match_operand:QI 2 "const_int_operand" "n")))]
                   1279:   ""
                   1280:   "rotl $%R2,%1,%0")
                   1281: 
                   1282: (define_insn ""
                   1283:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1284:        (rotatert:SI (match_operand:SI 1 "general_operand" "g")
                   1285:                     (neg:QI (match_operand:QI 2 "general_operand" "g"))))]
                   1286:   ""
                   1287:   "rotl %2,%1,%0")
                   1288: 
                   1289: ;This insn is probably slower than a multiply and an add.
                   1290: ;(define_insn ""
                   1291: ;  [(set (match_operand:SI 0 "general_operand" "=g")
                   1292: ;      (mult:SI (plus:SI (match_operand:SI 1 "general_operand" "g")
                   1293: ;                        (match_operand:SI 2 "general_operand" "g"))
                   1294: ;               (match_operand:SI 3 "general_operand" "g")))]
                   1295: ;  ""
                   1296: ;  "index %1,$0x80000000,$0x7fffffff,%3,%2,%0")
                   1297: 
                   1298: ;; Special cases of bit-field insns which we should
                   1299: ;; recognize in preference to the general case.
                   1300: ;; These handle aligned 8-bit and 16-bit fields,
                   1301: ;; which can usually be done with move instructions.
                   1302: 
                   1303: (define_insn ""
                   1304:   [(set (zero_extract:SI (match_operand:SI 0 "general_operand" "+ro")
                   1305:                         (match_operand:QI 1 "const_int_operand" "n")
                   1306:                         (match_operand:SI 2 "const_int_operand" "n"))
                   1307:        (match_operand:SI 3 "general_operand" "g"))]
                   1308:    "(INTVAL (operands[1]) == 8 || INTVAL (operands[1]) == 16)
                   1309:    && INTVAL (operands[2]) % INTVAL (operands[1]) == 0
                   1310:    && (GET_CODE (operands[0]) == REG
                   1311:        || ! mode_dependent_address_p (XEXP (operands[0], 0)))"
                   1312:   "*
                   1313: {
                   1314:   if (REG_P (operands[0]))
                   1315:     {
                   1316:       if (INTVAL (operands[2]) != 0)
                   1317:        return \"insv %3,%2,%1,%0\";
                   1318:     }
                   1319:   else
                   1320:     operands[0]
                   1321:       = adj_offsettable_operand (operands[0], INTVAL (operands[2]) / 8);
                   1322: 
                   1323:   if (INTVAL (operands[1]) == 8)
                   1324:     return \"movb %3,%0\";
                   1325:   return \"movw %3,%0\";
                   1326: }")
                   1327: 
                   1328: (define_insn ""
                   1329:   [(set (match_operand:SI 0 "general_operand" "=&g")
                   1330:        (zero_extract:SI (match_operand:SI 1 "general_operand" "ro")
                   1331:                         (match_operand:QI 2 "const_int_operand" "n")
                   1332:                         (match_operand:SI 3 "const_int_operand" "n")))]
                   1333:   "(INTVAL (operands[2]) == 8 || INTVAL (operands[2]) == 16)
                   1334:    && INTVAL (operands[3]) % INTVAL (operands[2]) == 0
                   1335:    && (GET_CODE (operands[1]) == REG
                   1336:        || ! mode_dependent_address_p (XEXP (operands[1], 0)))"
                   1337:   "*
                   1338: {
                   1339:   if (REG_P (operands[1]))
                   1340:     {
                   1341:       if (INTVAL (operands[3]) != 0)
                   1342:        return \"extzv %3,%2,%1,%0\";
                   1343:     }
                   1344:   else
                   1345:     operands[1]
                   1346:       = adj_offsettable_operand (operands[1], INTVAL (operands[3]) / 8);
                   1347: 
                   1348:   if (INTVAL (operands[2]) == 8)
                   1349:     return \"movzbl %1,%0\";
                   1350:   return \"movzwl %1,%0\";
                   1351: }")
                   1352: 
                   1353: (define_insn ""
                   1354:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1355:        (sign_extract:SI (match_operand:SI 1 "general_operand" "ro")
                   1356:                         (match_operand:QI 2 "const_int_operand" "n")
                   1357:                         (match_operand:SI 3 "const_int_operand" "n")))]
                   1358:   "(INTVAL (operands[2]) == 8 || INTVAL (operands[2]) == 16)
                   1359:    && INTVAL (operands[3]) % INTVAL (operands[2]) == 0
                   1360:    && (GET_CODE (operands[1]) == REG
                   1361:        || ! mode_dependent_address_p (XEXP (operands[1], 0)))"
                   1362:   "*
                   1363: {
                   1364:   if (REG_P (operands[1]))
                   1365:     {
                   1366:       if (INTVAL (operands[3]) != 0)
                   1367:        return \"extv %3,%2,%1,%0\";
                   1368:     }
                   1369:   else
                   1370:     operands[1]
                   1371:       = adj_offsettable_operand (operands[1], INTVAL (operands[3]) / 8);
                   1372: 
                   1373:   if (INTVAL (operands[2]) == 8)
                   1374:     return \"cvtbl %1,%0\";
                   1375:   return \"cvtwl %1,%0\";
                   1376: }")
                   1377: 
                   1378: ;; Register-only SImode cases of bit-field insns.
                   1379: 
                   1380: (define_insn ""
                   1381:   [(set (cc0)
                   1382:        (compare
                   1383:         (sign_extract:SI (match_operand:SI 0 "nonmemory_operand" "r")
                   1384:                          (match_operand:QI 1 "general_operand" "g")
                   1385:                          (match_operand:SI 2 "general_operand" "g"))
                   1386:         (match_operand:SI 3 "general_operand" "g")))]
                   1387:   ""
                   1388:   "cmpv %2,%1,%0,%3")
                   1389: 
                   1390: (define_insn ""
                   1391:   [(set (cc0)
                   1392:        (compare
                   1393:         (zero_extract:SI (match_operand:SI 0 "nonmemory_operand" "r")
                   1394:                          (match_operand:QI 1 "general_operand" "g")
                   1395:                          (match_operand:SI 2 "general_operand" "g"))
                   1396:         (match_operand:SI 3 "general_operand" "g")))]
                   1397:   ""
                   1398:   "cmpzv %2,%1,%0,%3")
                   1399: 
                   1400: ;; When the field position and size are constant and the destination
                   1401: ;; is a register, extv and extzv are much slower than a rotate followed
                   1402: ;; by a bicl or sign extension.
                   1403: 
                   1404: (define_insn ""
                   1405:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1406:        (sign_extract:SI (match_operand:SI 1 "nonmemory_operand" "r")
                   1407:                         (match_operand:QI 2 "general_operand" "g")
                   1408:                         (match_operand:SI 3 "general_operand" "g")))]
                   1409:   ""
                   1410:   "*
                   1411: {
                   1412:   if (GET_CODE (operands[3]) != CONST_INT || GET_CODE (operands[2]) != CONST_INT
                   1413:       || GET_CODE (operands[0]) != REG
                   1414:       || (INTVAL (operands[2]) != 8 && INTVAL (operands[2]) != 16))
                   1415:     return \"extv %3,%2,%1,%0\";
                   1416:   if (INTVAL (operands[2]) == 8)
                   1417:     return \"rotl %R3,%1,%0\;cvtbl %0,%0\";
                   1418:   return \"rotl %R3,%1,%0\;cvtwl %0,%0\";
                   1419: }")
                   1420: 
                   1421: (define_insn ""
                   1422:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1423:        (zero_extract:SI (match_operand:SI 1 "nonmemory_operand" "r")
                   1424:                         (match_operand:QI 2 "general_operand" "g")
                   1425:                         (match_operand:SI 3 "general_operand" "g")))]
                   1426:   ""
                   1427:   "*
                   1428: {
                   1429:   if (GET_CODE (operands[3]) != CONST_INT || GET_CODE (operands[2]) != CONST_INT
                   1430:       || GET_CODE (operands[0]) != REG)
                   1431:     return \"extzv %3,%2,%1,%0\";
                   1432:   if (INTVAL (operands[2]) == 8)
                   1433:     return \"rotl %R3,%1,%0\;movzbl %0,%0\";
                   1434:   if (INTVAL (operands[2]) == 16)
                   1435:     return \"rotl %R3,%1,%0\;movzwl %0,%0\";
                   1436:   if (INTVAL (operands[3]) & 31)
                   1437:     return \"rotl %R3,%1,%0\;bicl2 %M2,%0\";
                   1438:   if (rtx_equal_p (operands[0], operands[1]))
                   1439:     return \"bicl2 %M2,%0\";
                   1440:   return \"bicl3 %M2,%1,%0\";
                   1441: }")
                   1442: 
                   1443: ;; Non-register cases.
                   1444: ;; nonimmediate_operand is used to make sure that mode-ambiguous cases
                   1445: ;; don't match these (and therefore match the cases above instead).
                   1446: 
                   1447: (define_insn ""
                   1448:   [(set (cc0)
                   1449:        (compare
                   1450:         (sign_extract:SI (match_operand:QI 0 "nonimmediate_operand" "rm")
                   1451:                          (match_operand:QI 1 "general_operand" "g")
                   1452:                          (match_operand:SI 2 "general_operand" "g"))
                   1453:         (match_operand:SI 3 "general_operand" "g")))]
                   1454:   ""
                   1455:   "cmpv %2,%1,%0,%3")
                   1456: 
                   1457: (define_insn ""
                   1458:   [(set (cc0)
                   1459:        (compare
                   1460:         (zero_extract:SI (match_operand:QI 0 "nonimmediate_operand" "rm")
                   1461:                          (match_operand:QI 1 "general_operand" "g")
                   1462:                          (match_operand:SI 2 "general_operand" "g"))
                   1463:         (match_operand:SI 3 "general_operand" "g")))]
                   1464:   ""
                   1465:   "cmpzv %2,%1,%0,%3")
                   1466: 
                   1467: (define_insn "extv"
                   1468:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1469:        (sign_extract:SI (match_operand:QI 1 "nonimmediate_operand" "rm")
                   1470:                         (match_operand:QI 2 "general_operand" "g")
                   1471:                         (match_operand:SI 3 "general_operand" "g")))]
                   1472:   ""
                   1473:   "*
                   1474: {
                   1475:   if (GET_CODE (operands[0]) != REG || GET_CODE (operands[2]) != CONST_INT
                   1476:       || GET_CODE (operands[3]) != CONST_INT
                   1477:       || (INTVAL (operands[2]) != 8 && INTVAL (operands[2]) != 16)
                   1478:       || side_effects_p (operands[1])
                   1479:       || (GET_CODE (operands[1]) == MEM
                   1480:          && mode_dependent_address_p (XEXP (operands[1], 0))))
                   1481:     return \"extv %3,%2,%1,%0\";
                   1482:   if (INTVAL (operands[2]) == 8)
                   1483:     return \"rotl %R3,%1,%0\;cvtbl %0,%0\";
                   1484:   return \"rotl %R3,%1,%0\;cvtwl %0,%0\";
                   1485: }")
                   1486: 
                   1487: (define_insn "extzv"
                   1488:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1489:        (zero_extract:SI (match_operand:QI 1 "nonimmediate_operand" "rm")
                   1490:                         (match_operand:QI 2 "general_operand" "g")
                   1491:                         (match_operand:SI 3 "general_operand" "g")))]
                   1492:   ""
                   1493:   "*
                   1494: {
                   1495:   if (GET_CODE (operands[0]) != REG || GET_CODE (operands[2]) != CONST_INT
                   1496:       || GET_CODE (operands[3]) != CONST_INT
                   1497:       || side_effects_p (operands[1])
                   1498:       || (GET_CODE (operands[1]) == MEM
                   1499:          && mode_dependent_address_p (XEXP (operands[1], 0))))
                   1500:     return \"extzv %3,%2,%1,%0\";
                   1501:   if (INTVAL (operands[2]) == 8)
                   1502:     return \"rotl %R3,%1,%0\;movzbl %0,%0\";
                   1503:   if (INTVAL (operands[2]) == 16)
                   1504:     return \"rotl %R3,%1,%0\;movzwl %0,%0\";
                   1505:   return \"rotl %R3,%1,%0\;bicl2 %M2,%0\";
                   1506: }")
                   1507: 
                   1508: (define_insn "insv"
                   1509:   [(set (zero_extract:SI (match_operand:QI 0 "general_operand" "+g")
                   1510:                         (match_operand:QI 1 "general_operand" "g")
                   1511:                         (match_operand:SI 2 "general_operand" "g"))
                   1512:        (match_operand:SI 3 "general_operand" "g"))]
                   1513:   ""
                   1514:   "insv %3,%2,%1,%0")
                   1515: 
                   1516: (define_insn ""
                   1517:   [(set (zero_extract:SI (match_operand:SI 0 "register_operand" "+r")
                   1518:                         (match_operand:QI 1 "general_operand" "g")
                   1519:                         (match_operand:SI 2 "general_operand" "g"))
                   1520:        (match_operand:SI 3 "general_operand" "g"))]
                   1521:   ""
                   1522:   "insv %3,%2,%1,%0")
                   1523: 
                   1524: (define_insn "jump"
                   1525:   [(set (pc)
                   1526:        (label_ref (match_operand 0 "" "")))]
                   1527:   ""
                   1528:   "jbr %l0")
                   1529: 
                   1530: (define_insn "beq"
                   1531:   [(set (pc)
                   1532:        (if_then_else (eq (cc0)
                   1533:                          (const_int 0))
                   1534:                      (label_ref (match_operand 0 "" ""))
                   1535:                      (pc)))]
                   1536:   ""
                   1537:   "jeql %l0")
                   1538: 
                   1539: (define_insn "bne"
                   1540:   [(set (pc)
                   1541:        (if_then_else (ne (cc0)
                   1542:                          (const_int 0))
                   1543:                      (label_ref (match_operand 0 "" ""))
                   1544:                      (pc)))]
                   1545:   ""
                   1546:   "jneq %l0")
                   1547: 
                   1548: (define_insn "bgt"
                   1549:   [(set (pc)
                   1550:        (if_then_else (gt (cc0)
                   1551:                          (const_int 0))
                   1552:                      (label_ref (match_operand 0 "" ""))
                   1553:                      (pc)))]
                   1554:   ""
                   1555:   "jgtr %l0")
                   1556: 
                   1557: (define_insn "bgtu"
                   1558:   [(set (pc)
                   1559:        (if_then_else (gtu (cc0)
                   1560:                           (const_int 0))
                   1561:                      (label_ref (match_operand 0 "" ""))
                   1562:                      (pc)))]
                   1563:   ""
                   1564:   "jgtru %l0")
                   1565: 
                   1566: (define_insn "blt"
                   1567:   [(set (pc)
                   1568:        (if_then_else (lt (cc0)
                   1569:                          (const_int 0))
                   1570:                      (label_ref (match_operand 0 "" ""))
                   1571:                      (pc)))]
                   1572:   ""
                   1573:   "jlss %l0")
                   1574: 
                   1575: (define_insn "bltu"
                   1576:   [(set (pc)
                   1577:        (if_then_else (ltu (cc0)
                   1578:                           (const_int 0))
                   1579:                      (label_ref (match_operand 0 "" ""))
                   1580:                      (pc)))]
                   1581:   ""
                   1582:   "jlssu %l0")
                   1583: 
                   1584: (define_insn "bge"
                   1585:   [(set (pc)
                   1586:        (if_then_else (ge (cc0)
                   1587:                          (const_int 0))
                   1588:                      (label_ref (match_operand 0 "" ""))
                   1589:                      (pc)))]
                   1590:   ""
                   1591:   "jgeq %l0")
                   1592: 
                   1593: (define_insn "bgeu"
                   1594:   [(set (pc)
                   1595:        (if_then_else (geu (cc0)
                   1596:                           (const_int 0))
                   1597:                      (label_ref (match_operand 0 "" ""))
                   1598:                      (pc)))]
                   1599:   ""
                   1600:   "jgequ %l0")
                   1601: 
                   1602: (define_insn "ble"
                   1603:   [(set (pc)
                   1604:        (if_then_else (le (cc0)
                   1605:                          (const_int 0))
                   1606:                      (label_ref (match_operand 0 "" ""))
                   1607:                      (pc)))]
                   1608:   ""
                   1609:   "jleq %l0")
                   1610: 
                   1611: (define_insn "bleu"
                   1612:   [(set (pc)
                   1613:        (if_then_else (leu (cc0)
                   1614:                           (const_int 0))
                   1615:                      (label_ref (match_operand 0 "" ""))
                   1616:                      (pc)))]
                   1617:   ""
                   1618:   "jlequ %l0")
                   1619: 
                   1620: ;; Recognize reversed jumps.
                   1621: (define_insn ""
                   1622:   [(set (pc)
                   1623:        (if_then_else (match_operator 0 "comparison_operator"
                   1624:                                      [(cc0)
                   1625:                                       (const_int 0)])
                   1626:                      (pc)
                   1627:                      (label_ref (match_operand 1 "" ""))))]
                   1628:   ""
                   1629:   "j%C0 %l1") ; %C0 negates condition
                   1630: 
                   1631: ;; Recognize jbs, jlbs, jbc and jlbc instructions.  Note that the operand
                   1632: ;; of jlbs and jlbc insns are SImode in the hardware.  However, if it is
                   1633: ;; memory, we use QImode in the insn.  So we can't use those instructions
                   1634: ;; for mode-dependent addresses.
                   1635: 
                   1636: (define_insn ""
                   1637:   [(set (pc)
                   1638:        (if_then_else
                   1639:         (ne (zero_extract:SI (match_operand:QI 0 "nonimmediate_operand" "rQ,g")
                   1640:                              (const_int 1)
                   1641:                              (match_operand:SI 1 "general_operand" "I,g"))
                   1642:             (const_int 0))
                   1643:         (label_ref (match_operand 2 "" ""))
                   1644:         (pc)))]
                   1645:   ""
                   1646:   "@
                   1647:    jlbs %0,%l2
                   1648:    jbs %1,%0,%l2")
                   1649: 
                   1650: (define_insn ""
                   1651:   [(set (pc)
                   1652:        (if_then_else
                   1653:         (eq (zero_extract:SI (match_operand:QI 0 "nonimmediate_operand" "rQ,g")
                   1654:                              (const_int 1)
                   1655:                              (match_operand:SI 1 "general_operand" "I,g"))
                   1656:             (const_int 0))
                   1657:         (label_ref (match_operand 2 "" ""))
                   1658:         (pc)))]
                   1659:   ""
                   1660:   "@
                   1661:    jlbc %0,%l2
                   1662:    jbc %1,%0,%l2")
                   1663: 
                   1664: (define_insn ""
                   1665:   [(set (pc)
                   1666:        (if_then_else
                   1667:         (ne (zero_extract:SI (match_operand:SI 0 "register_operand" "r,r")
                   1668:                              (const_int 1)
                   1669:                              (match_operand:SI 1 "general_operand" "I,g"))
                   1670:             (const_int 0))
                   1671:         (label_ref (match_operand 2 "" ""))
                   1672:         (pc)))]
                   1673:   ""
                   1674:   "@
                   1675:    jlbs %0,%l2
                   1676:    jbs %1,%0,%l2")
                   1677: 
                   1678: (define_insn ""
                   1679:   [(set (pc)
                   1680:        (if_then_else
                   1681:         (eq (zero_extract:SI (match_operand:SI 0 "register_operand" "r,r")
                   1682:                              (const_int 1)
                   1683:                              (match_operand:SI 1 "general_operand" "I,g"))
                   1684:             (const_int 0))
                   1685:         (label_ref (match_operand 2 "" ""))
                   1686:         (pc)))]
                   1687:   ""
                   1688:   "@
                   1689:    jlbc %0,%l2
                   1690:    jbc %1,%0,%l2")
                   1691: 
                   1692: ;; Subtract-and-jump and Add-and-jump insns.
                   1693: ;; These are not used when output is for the Unix assembler
                   1694: ;; because it does not know how to modify them to reach far.
                   1695: 
                   1696: ;; Normal sob insns.
                   1697: 
                   1698: (define_insn ""
                   1699:   [(set (pc)
                   1700:        (if_then_else
                   1701:         (gt (plus:SI (match_operand:SI 0 "general_operand" "+g")
                   1702:                      (const_int -1))
                   1703:             (const_int 0))
                   1704:         (label_ref (match_operand 1 "" ""))
                   1705:         (pc)))
                   1706:    (set (match_dup 0)
                   1707:        (plus:SI (match_dup 0)
                   1708:                 (const_int -1)))]
                   1709:   "!TARGET_UNIX_ASM"
                   1710:   "jsobgtr %0,%l1")
                   1711: 
                   1712: (define_insn ""
                   1713:   [(set (pc)
                   1714:        (if_then_else
                   1715:         (ge (plus:SI (match_operand:SI 0 "general_operand" "+g")
                   1716:                      (const_int -1))
                   1717:             (const_int 0))
                   1718:         (label_ref (match_operand 1 "" ""))
                   1719:         (pc)))
                   1720:    (set (match_dup 0)
                   1721:        (plus:SI (match_dup 0)
                   1722:                 (const_int -1)))]
                   1723:   "!TARGET_UNIX_ASM"
                   1724:   "jsobgeq %0,%l1")
                   1725: 
                   1726: ;; Normal aob insns.  Define a version for when operands[1] is a constant.
                   1727: (define_insn ""
                   1728:   [(set (pc)
                   1729:        (if_then_else
                   1730:         (lt (plus:SI (match_operand:SI 0 "general_operand" "+g")
                   1731:                      (const_int 1))
                   1732:             (match_operand:SI 1 "general_operand" "g"))
                   1733:         (label_ref (match_operand 2 "" ""))
                   1734:         (pc)))
                   1735:    (set (match_dup 0)
                   1736:        (plus:SI (match_dup 0)
                   1737:                 (const_int 1)))]
                   1738:   "!TARGET_UNIX_ASM"
                   1739:   "jaoblss %1,%0,%l2")
                   1740: 
                   1741: (define_insn ""
                   1742:   [(set (pc)
                   1743:        (if_then_else
                   1744:         (lt (match_operand:SI 0 "general_operand" "+g")
                   1745:             (match_operand:SI 1 "general_operand" "g"))
                   1746:         (label_ref (match_operand 2 "" ""))
                   1747:         (pc)))
                   1748:    (set (match_dup 0)
                   1749:        (plus:SI (match_dup 0)
                   1750:                 (const_int 1)))]
                   1751:   "!TARGET_UNIX_ASM && GET_CODE (operands[1]) == CONST_INT"
                   1752:   "jaoblss %P1,%0,%l2")
                   1753: 
                   1754: (define_insn ""
                   1755:   [(set (pc)
                   1756:        (if_then_else
                   1757:         (le (plus:SI (match_operand:SI 0 "general_operand" "+g")
                   1758:                      (const_int 1))
                   1759:             (match_operand:SI 1 "general_operand" "g"))
                   1760:         (label_ref (match_operand 2 "" ""))
                   1761:         (pc)))
                   1762:    (set (match_dup 0)
                   1763:        (plus:SI (match_dup 0)
                   1764:                 (const_int 1)))]
                   1765:   "!TARGET_UNIX_ASM"
                   1766:   "jaobleq %1,%0,%l2")
                   1767: 
                   1768: (define_insn ""
                   1769:   [(set (pc)
                   1770:        (if_then_else
                   1771:         (le (match_operand:SI 0 "general_operand" "+g")
                   1772:             (match_operand:SI 1 "general_operand" "g"))
                   1773:         (label_ref (match_operand 2 "" ""))
                   1774:         (pc)))
                   1775:    (set (match_dup 0)
                   1776:        (plus:SI (match_dup 0)
                   1777:                 (const_int 1)))]
                   1778:   "!TARGET_UNIX_ASM && GET_CODE (operands[1]) == CONST_INT"
                   1779:   "jaobleq %P1,%0,%l2")
                   1780: 
                   1781: ;; Something like a sob insn, but compares against -1.
                   1782: ;; This finds `while (foo--)' which was changed to `while (--foo != -1)'.
                   1783: 
                   1784: (define_insn ""
                   1785:   [(set (pc)
                   1786:        (if_then_else
                   1787:         (ne (match_operand:SI 0 "general_operand" "g")
                   1788:             (const_int 0))
                   1789:         (label_ref (match_operand 1 "" ""))
                   1790:         (pc)))
                   1791:    (set (match_dup 0)
                   1792:        (plus:SI (match_dup 0)
                   1793:                 (const_int -1)))]
                   1794:   ""
                   1795:   "decl %0\;jgequ %l1")
                   1796: 
                   1797: ;; Note that operand 1 is total size of args, in bytes,
                   1798: ;; and what the call insn wants is the number of words.
                   1799: (define_insn "call_pop"
                   1800:   [(call (match_operand:QI 0 "memory_operand" "m")
                   1801:         (match_operand:QI 1 "general_operand" "g"))
                   1802:    (set (reg:SI 14) (plus:SI (reg:SI 14)
                   1803:                             (match_operand:SI 3 "immediate_operand" "i")))]
                   1804:   ""
                   1805:   "*
                   1806:   if (GET_CODE (operands[1]) != CONST_INT || INTVAL (operands[1]) > 255 * 4)
                   1807:     /* Vax `calls' really uses only one byte of #args, so pop explicitly.  */
                   1808:     return \"calls $0,%0\;addl2 %1,sp\";
                   1809:   operands[1] = gen_rtx (CONST_INT, VOIDmode, (INTVAL (operands[1]) + 3)/ 4);
                   1810:   return \"calls %1,%0\";
                   1811: ")
                   1812: 
                   1813: (define_insn "call_value_pop"
                   1814:   [(set (match_operand 0 "" "=g")
                   1815:        (call (match_operand:QI 1 "memory_operand" "m")
                   1816:              (match_operand:QI 2 "general_operand" "g")))
                   1817:    (set (reg:SI 14) (plus:SI (reg:SI 14)
                   1818:                             (match_operand:SI 4 "immediate_operand" "i")))]
                   1819:   ""
                   1820:   "*
                   1821:   if (GET_CODE (operands[2]) != CONST_INT || INTVAL (operands[2]) > 255 * 4)
                   1822:     /* Vax `calls' really uses only one byte of #args, so pop explicitly.  */
                   1823:     return \"calls $0,%1\;addl2 %2,sp\";
                   1824:   operands[2] = gen_rtx (CONST_INT, VOIDmode, (INTVAL (operands[2]) + 3)/ 4);
                   1825:   return \"calls %2,%1\";
                   1826: ")
                   1827: 
                   1828: ;; Define another set of these for the case of functions with no
                   1829: ;; operands.  In that case, combine may simplify the adjustment of sp.
                   1830: (define_insn ""
                   1831:   [(call (match_operand:QI 0 "memory_operand" "m")
                   1832:         (match_operand:QI 1 "general_operand" "g"))
                   1833:    (set (reg:SI 14) (reg:SI 14))]
                   1834:   ""
                   1835:   "*
                   1836:   if (GET_CODE (operands[1]) != CONST_INT || INTVAL (operands[1]) > 255 * 4)
                   1837:     /* Vax `calls' really uses only one byte of #args, so pop explicitly.  */
                   1838:     return \"calls $0,%0\;addl2 %1,sp\";
                   1839:   operands[1] = gen_rtx (CONST_INT, VOIDmode, (INTVAL (operands[1]) + 3)/ 4);
                   1840:   return \"calls %1,%0\";
                   1841: ")
                   1842: 
                   1843: (define_insn ""
                   1844:   [(set (match_operand 0 "" "=g")
                   1845:        (call (match_operand:QI 1 "memory_operand" "m")
                   1846:              (match_operand:QI 2 "general_operand" "g")))
                   1847:    (set (reg:SI 14) (reg:SI 14))]
                   1848:   ""
                   1849:   "*
                   1850:   if (GET_CODE (operands[2]) != CONST_INT || INTVAL (operands[2]) > 255 * 4)
                   1851:     /* Vax `calls' really uses only one byte of #args, so pop explicitly.  */
                   1852:     return \"calls $0,%1\;addl2 %2,sp\";
                   1853:   operands[2] = gen_rtx (CONST_INT, VOIDmode, (INTVAL (operands[2]) + 3)/ 4);
                   1854:   return \"calls %2,%1\";
                   1855: ")
                   1856: 
                   1857: ;; Call subroutine returning any type.
                   1858: 
                   1859: (define_expand "untyped_call"
                   1860:   [(parallel [(call (match_operand 0 "" "")
                   1861:                   (const_int 0))
                   1862:             (match_operand 1 "" "")
                   1863:             (match_operand 2 "" "")])]
                   1864:   ""
                   1865:   "
                   1866: {
                   1867:   int i;
                   1868: 
                   1869:   emit_call_insn (gen_call_pop (operands[0], const0_rtx, NULL, const0_rtx));
                   1870: 
                   1871:   for (i = 0; i < XVECLEN (operands[2], 0); i++)
                   1872:     {
                   1873:       rtx set = XVECEXP (operands[2], 0, i);
                   1874:       emit_move_insn (SET_DEST (set), SET_SRC (set));
                   1875:     }
                   1876: 
                   1877:   /* The optimizer does not know that the call sets the function value
                   1878:      registers we stored in the result block.  We avoid problems by
                   1879:      claiming that all hard registers are used and clobbered at this
                   1880:      point.  */
                   1881:   emit_insn (gen_blockage ());
                   1882: 
                   1883:   DONE;
                   1884: }")
                   1885: 
                   1886: ;; UNSPEC_VOLATILE is considered to use and clobber all hard registers and
                   1887: ;; all of memory.  This blocks insns from being moved across this point.
                   1888: 
                   1889: (define_insn "blockage"
                   1890:   [(unspec_volatile [(const_int 0)] 0)]
                   1891:   ""
                   1892:   "")
                   1893: 
                   1894: (define_insn "return"
                   1895:   [(return)]
                   1896:   ""
                   1897:   "ret")
                   1898: 
                   1899: (define_insn "nop"
                   1900:   [(const_int 0)]
                   1901:   ""
                   1902:   "nop")
                   1903: 
                   1904: ;; This had a wider constraint once, and it had trouble.
                   1905: ;; If you are tempted to try `g', please don't--it's not worth
                   1906: ;; the risk we will reopen the same bug.
                   1907: (define_insn "indirect_jump"
                   1908:   [(set (pc) (match_operand:SI 0 "general_operand" "r"))]
                   1909:   ""
                   1910:   "jmp (%0)")
                   1911: 
                   1912: ;; This is here to accept 5 arguments (as passed by expand_end_case)
                   1913: ;; and pass the first 4 along to the casesi1 pattern that really does the work.
                   1914: (define_expand "casesi"
                   1915:   [(set (pc)
                   1916:        (if_then_else (leu (minus:SI (match_operand:SI 0 "general_operand" "g")
                   1917:                                     (match_operand:SI 1 "general_operand" "g"))
                   1918:                           (match_operand:SI 2 "general_operand" "g"))
                   1919:                      (plus:SI (sign_extend:SI
                   1920:                                (mem:HI
                   1921:                                 (plus:SI (pc)
                   1922:                                          (mult:SI (minus:SI (match_dup 0)
                   1923:                                                             (match_dup 1))
                   1924:                                                   (const_int 2)))))
                   1925:                               (label_ref:SI (match_operand 3 "" "")))
                   1926:                      (pc)))
                   1927:    (match_operand 4 "" "")]
                   1928:   ""
                   1929:   "
                   1930:   emit_insn (gen_casesi1 (operands[0], operands[1], operands[2], operands[3]));
                   1931:   DONE;
                   1932: ")
                   1933: 
                   1934: (define_insn "casesi1"
                   1935:   [(set (pc)
                   1936:        (if_then_else (leu (minus:SI (match_operand:SI 0 "general_operand" "g")
                   1937:                                     (match_operand:SI 1 "general_operand" "g"))
                   1938:                           (match_operand:SI 2 "general_operand" "g"))
                   1939:                      (plus:SI (sign_extend:SI
                   1940:                                (mem:HI
                   1941:                                 (plus:SI (pc)
                   1942:                                          (mult:SI (minus:SI (match_dup 0)
                   1943:                                                             (match_dup 1))
                   1944:                                                   (const_int 2)))))
                   1945:                               (label_ref:SI (match_operand 3 "" "")))
                   1946:                      (pc)))]
                   1947:   ""
                   1948:   "casel %0,%1,%2")
                   1949: 
                   1950: ;; This used to arise from the preceding by simplification
                   1951: ;; if operand 1 is zero.  Perhaps it is no longer necessary.
                   1952: (define_insn ""
                   1953:   [(set (pc)
                   1954:        (if_then_else (leu (match_operand:SI 0 "general_operand" "g")
                   1955:                           (match_operand:SI 1 "general_operand" "g"))
                   1956:                      (plus:SI (sign_extend:SI
                   1957:                                (mem:HI
                   1958:                                 (plus:SI (pc)
                   1959:                                          (mult:SI (minus:SI (match_dup 0)
                   1960:                                                             (const_int 0))
                   1961:                                                   (const_int 2)))))
                   1962:                               (label_ref:SI (match_operand 3 "" "")))
                   1963:                      (pc)))]
                   1964:   ""
                   1965:   "casel %0,$0,%1")
                   1966: 
                   1967: ;;- load or push effective address 
                   1968: ;; These come after the move and add/sub patterns
                   1969: ;; because we don't want pushl $1 turned into pushad 1.
                   1970: ;; or addl3 r1,r2,r3 turned into movab 0(r1)[r2],r3.
                   1971: 
                   1972: ;; It does not work to use constraints to distinguish pushes from moves,
                   1973: ;; because < matches any autodecrement, not just a push.
                   1974: 
                   1975: (define_insn ""
                   1976:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1977:        (match_operand:QI 1 "address_operand" "p"))]
                   1978:   ""
                   1979:   "*
                   1980: {
                   1981:   if (push_operand (operands[0], SImode))
                   1982:     return \"pushab %a1\";
                   1983:   else
                   1984:     return \"movab %a1,%0\";
                   1985: }")
                   1986: 
                   1987: (define_insn ""
                   1988:   [(set (match_operand:SI 0 "general_operand" "=g")
                   1989:        (match_operand:HI 1 "address_operand" "p"))]
                   1990:   ""
                   1991:   "*
                   1992: {
                   1993:   if (push_operand (operands[0], SImode))
                   1994:     return \"pushaw %a1\";
                   1995:   else
                   1996:     return \"movaw %a1,%0\";
                   1997: }")
                   1998: 
                   1999: (define_insn ""
                   2000:   [(set (match_operand:SI 0 "general_operand" "=g")
                   2001:        (match_operand:SI 1 "address_operand" "p"))]
                   2002:   ""
                   2003:   "*
                   2004: {
                   2005:   if (push_operand (operands[0], SImode))
                   2006:     return \"pushal %a1\";
                   2007:   else
                   2008:     return \"moval %a1,%0\";
                   2009: }")
                   2010: 
                   2011: (define_insn ""
                   2012:   [(set (match_operand:SI 0 "general_operand" "=g")
                   2013:        (match_operand:DI 1 "address_operand" "p"))]
                   2014:   ""
                   2015:   "*
                   2016: {
                   2017:   if (push_operand (operands[0], SImode))
                   2018:     return \"pushaq %a1\";
                   2019:   else
                   2020:     return \"movaq %a1,%0\";
                   2021: }")
                   2022: 
                   2023: (define_insn ""
                   2024:   [(set (match_operand:SI 0 "general_operand" "=g")
                   2025:        (match_operand:SF 1 "address_operand" "p"))]
                   2026:   ""
                   2027:   "*
                   2028: {
                   2029:   if (push_operand (operands[0], SImode))
                   2030:     return \"pushaf %a1\";
                   2031:   else
                   2032:     return \"movaf %a1,%0\";
                   2033: }")
                   2034: 
                   2035: (define_insn ""
                   2036:   [(set (match_operand:SI 0 "general_operand" "=g")
                   2037:        (match_operand:DF 1 "address_operand" "p"))]
                   2038:   ""
                   2039:   "*
                   2040: {
                   2041:   if (push_operand (operands[0], SImode))
                   2042:     return \"pushad %a1\";
                   2043:   else
                   2044:     return \"movad %a1,%0\";
                   2045: }")
                   2046: 
                   2047: ;; These used to be peepholes, but it is more straightforward to do them
                   2048: ;; as single insns.  However, we must force the output to be a register
                   2049: ;; if it is not an offsettable address so that we know that we can assign
                   2050: ;; to it twice. 
                   2051: 
                   2052: ;; If we had a good way of evaluating the relative costs, these could be
                   2053: ;; machine-independent.
                   2054: 
                   2055: ;; Optimize   extzv ...,z;    andl2 ...,z
                   2056: ;; or        ashl ...,z;     andl2 ...,z
                   2057: ;; with other operands constant.  This is what the combiner converts the
                   2058: ;; above sequences to before attempting to recognize the new insn.
                   2059: 
                   2060: (define_insn ""
                   2061:   [(set (match_operand:SI 0 "general_operand" "=ro")
                   2062:        (and:SI (ashiftrt:SI (match_operand:SI 1 "general_operand" "g")
                   2063:                             (match_operand:QI 2 "const_int_operand" "n"))
                   2064:                (match_operand:SI 3 "const_int_operand" "n")))]
                   2065:   "(INTVAL (operands[3]) & ~((1 << (32 - INTVAL (operands[2]))) - 1)) == 0"
                   2066:   "*
                   2067: {
                   2068:   unsigned long mask1 = INTVAL (operands[3]);
                   2069:   unsigned long mask2 = (1 << (32 - INTVAL (operands[2]))) - 1;
                   2070: 
                   2071:   if ((mask1 & mask2) != mask1)
                   2072:     operands[3] = gen_rtx (CONST_INT, VOIDmode, mask1 & mask2);
                   2073: 
                   2074:   return \"rotl %R2,%1,%0\;bicl2 %N3,%0\";
                   2075: }")
                   2076: 
                   2077: ;; left-shift and mask
                   2078: ;; The only case where `ashl' is better is if the mask only turns off
                   2079: ;; bits that the ashl would anyways, in which case it should have been
                   2080: ;; optimized away.
                   2081: 
                   2082: (define_insn ""
                   2083:   [(set (match_operand:SI 0 "general_operand" "=ro")
                   2084:        (and:SI (ashift:SI (match_operand:SI 1 "general_operand" "g")
                   2085:                           (match_operand:QI 2 "const_int_operand" "n"))
                   2086:                (match_operand:SI 3 "const_int_operand" "n")))]
                   2087:   ""
                   2088:   "*
                   2089: {
                   2090:   operands[3] = gen_rtx (CONST_INT, VOIDmode,
                   2091:                         INTVAL (operands[3]) & ~((1 << INTVAL (operands[2])) - 1));
                   2092:   return \"rotl %2,%1,%0\;bicl2 %N3,%0\";
                   2093: }")

unix.superglobalmegacorp.com

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