Annotation of GNUtools/cc/gcc.info-15, revision 1.1

1.1     ! root        1: This is Info file gcc.info, produced by Makeinfo-1.54 from the input
        !             2: file gcc.texi.
        !             3: 
        !             4:    This file documents the use and the internals of the GNU compiler.
        !             5: 
        !             6:    Published by the Free Software Foundation 675 Massachusetts Avenue
        !             7: Cambridge, MA 02139 USA
        !             8: 
        !             9:    Copyright (C) 1988, 1989, 1992, 1993 Free Software Foundation, Inc.
        !            10: 
        !            11:    Permission is granted to make and distribute verbatim copies of this
        !            12: manual provided the copyright notice and this permission notice are
        !            13: preserved on all copies.
        !            14: 
        !            15:    Permission is granted to copy and distribute modified versions of
        !            16: this manual under the conditions for verbatim copying, provided also
        !            17: that the sections entitled "GNU General Public License" and "Protect
        !            18: Your Freedom--Fight `Look And Feel'" are included exactly as in the
        !            19: original, and provided that the entire resulting derived work is
        !            20: distributed under the terms of a permission notice identical to this
        !            21: one.
        !            22: 
        !            23:    Permission is granted to copy and distribute translations of this
        !            24: manual into another language, under the above conditions for modified
        !            25: versions, except that the sections entitled "GNU General Public
        !            26: License" and "Protect Your Freedom--Fight `Look And Feel'", and this
        !            27: permission notice, may be included in translations approved by the Free
        !            28: Software Foundation instead of in the original English.
        !            29: 
        !            30: 
        !            31: File: gcc.info,  Node: Standard Names,  Next: Pattern Ordering,  Prev: Constraints,  Up: Machine Desc
        !            32: 
        !            33: Standard Pattern Names For Generation
        !            34: =====================================
        !            35: 
        !            36:    Here is a table of the instruction names that are meaningful in the
        !            37: RTL generation pass of the compiler.  Giving one of these names to an
        !            38: instruction pattern tells the RTL generation pass that it can use the
        !            39: pattern in to accomplish a certain task.
        !            40: 
        !            41: `movM'
        !            42:      Here M stands for a two-letter machine mode name, in lower case.
        !            43:      This instruction pattern moves data with that machine mode from
        !            44:      operand 1 to operand 0.  For example, `movsi' moves full-word data.
        !            45: 
        !            46:      If operand 0 is a `subreg' with mode M of a register whose own
        !            47:      mode is wider than M, the effect of this instruction is to store
        !            48:      the specified value in the part of the register that corresponds
        !            49:      to mode M.  The effect on the rest of the register is undefined.
        !            50: 
        !            51:      This class of patterns is special in several ways.  First of all,
        !            52:      each of these names *must* be defined, because there is no other
        !            53:      way to copy a datum from one place to another.
        !            54: 
        !            55:      Second, these patterns are not used solely in the RTL generation
        !            56:      pass.  Even the reload pass can generate move insns to copy values
        !            57:      from stack slots into temporary registers.  When it does so, one
        !            58:      of the operands is a hard register and the other is an operand
        !            59:      that can need to be reloaded into a register.
        !            60: 
        !            61:      Therefore, when given such a pair of operands, the pattern must
        !            62:      generate RTL which needs no reloading and needs no temporary
        !            63:      registers--no registers other than the operands.  For example, if
        !            64:      you support the pattern with a `define_expand', then in such a
        !            65:      case the `define_expand' mustn't call `force_reg' or any other such
        !            66:      function which might generate new pseudo registers.
        !            67: 
        !            68:      This requirement exists even for subword modes on a RISC machine
        !            69:      where fetching those modes from memory normally requires several
        !            70:      insns and some temporary registers.  Look in `spur.md' to see how
        !            71:      the requirement can be satisfied.
        !            72: 
        !            73:      During reload a memory reference with an invalid address may be
        !            74:      passed as an operand.  Such an address will be replaced with a
        !            75:      valid address later in the reload pass.  In this case, nothing may
        !            76:      be done with the address except to use it as it stands.  If it is
        !            77:      copied, it will not be replaced with a valid address.  No attempt
        !            78:      should be made to make such an address into a valid address and no
        !            79:      routine (such as `change_address') that will do so may be called.
        !            80:      Note that `general_operand' will fail when applied to such an
        !            81:      address.
        !            82: 
        !            83:      The global variable `reload_in_progress' (which must be explicitly
        !            84:      declared if required) can be used to determine whether such special
        !            85:      handling is required.
        !            86: 
        !            87:      The variety of operands that have reloads depends on the rest of
        !            88:      the machine description, but typically on a RISC machine these can
        !            89:      only be pseudo registers that did not get hard registers, while on
        !            90:      other machines explicit memory references will get optional
        !            91:      reloads.
        !            92: 
        !            93:      If a scratch register is required to move an object to or from
        !            94:      memory, it can be allocated using `gen_reg_rtx' prior to reload.
        !            95:      But this is impossible during and after reload.  If there are
        !            96:      cases needing scratch registers after reload, you must define
        !            97:      `SECONDARY_INPUT_RELOAD_CLASS' and perhaps also
        !            98:      `SECONDARY_OUTPUT_RELOAD_CLASS' to detect them, and provide
        !            99:      patterns `reload_inM' or `reload_outM' to handle them.  *Note
        !           100:      Register Classes::.
        !           101: 
        !           102:      The constraints on a `moveM' must permit moving any hard register
        !           103:      to any other hard register provided that `HARD_REGNO_MODE_OK'
        !           104:      permits mode M in both registers and `REGISTER_MOVE_COST' applied
        !           105:      to their classes returns a value of 2.
        !           106: 
        !           107:      It is obligatory to support floating point `moveM' instructions
        !           108:      into and out of any registers that can hold fixed point values,
        !           109:      because unions and structures (which have modes `SImode' or
        !           110:      `DImode') can be in those registers and they may have floating
        !           111:      point members.
        !           112: 
        !           113:      There may also be a need to support fixed point `moveM'
        !           114:      instructions in and out of floating point registers.
        !           115:      Unfortunately, I have forgotten why this was so, and I don't know
        !           116:      whether it is still true.  If `HARD_REGNO_MODE_OK' rejects fixed
        !           117:      point values in floating point registers, then the constraints of
        !           118:      the fixed point `moveM' instructions must be designed to avoid
        !           119:      ever trying to reload into a floating point register.
        !           120: 
        !           121: `reload_inM'
        !           122: `reload_outM'
        !           123:      Like `movM', but used when a scratch register is required to move
        !           124:      between operand 0 and operand 1.  Operand 2 describes the scratch
        !           125:      register.  See the discussion of the `SECONDARY_RELOAD_CLASS'
        !           126:      macro in *note Register Classes::..
        !           127: 
        !           128: `movstrictM'
        !           129:      Like `movM' except that if operand 0 is a `subreg' with mode M of
        !           130:      a register whose natural mode is wider, the `movstrictM'
        !           131:      instruction is guaranteed not to alter any of the register except
        !           132:      the part which belongs to mode M.
        !           133: 
        !           134: `load_multiple'
        !           135:      Load several consecutive memory locations into consecutive
        !           136:      registers.  Operand 0 is the first of the consecutive registers,
        !           137:      operand 1 is the first memory location, and operand 2 is a
        !           138:      constant: the number of consecutive registers.
        !           139: 
        !           140:      Define this only if the target machine really has such an
        !           141:      instruction; do not define this if the most efficient way of
        !           142:      loading consecutive registers from memory is to do them one at a
        !           143:      time.
        !           144: 
        !           145:      On some machines, there are restrictions as to which consecutive
        !           146:      registers can be stored into memory, such as particular starting or
        !           147:      ending register numbers or only a range of valid counts.  For those
        !           148:      machines, use a `define_expand' (*note Expander Definitions::.)
        !           149:      and make the pattern fail if the restrictions are not met.
        !           150: 
        !           151:      Write the generated insn as a `parallel' with elements being a
        !           152:      `set' of one register from the appropriate memory location (you may
        !           153:      also need `use' or `clobber' elements).  Use a `match_parallel'
        !           154:      (*note RTL Template::.) to recognize the insn.  See `a29k.md' and
        !           155:      `rs6000.md' for examples of the use of this insn pattern.
        !           156: 
        !           157: `store_multiple'
        !           158:      Similar to `load_multiple', but store several consecutive registers
        !           159:      into consecutive memory locations.  Operand 0 is the first of the
        !           160:      consecutive memory locations, operand 1 is the first register, and
        !           161:      operand 2 is a constant: the number of consecutive registers.
        !           162: 
        !           163: `addM3'
        !           164:      Add operand 2 and operand 1, storing the result in operand 0.  All
        !           165:      operands must have mode M.  This can be used even on two-address
        !           166:      machines, by means of constraints requiring operands 1 and 0 to be
        !           167:      the same location.
        !           168: 
        !           169: `subM3', `mulM3'
        !           170: `divM3', `udivM3', `modM3', `umodM3'
        !           171: `sminM3', `smaxM3', `uminM3', `umaxM3'
        !           172: `andM3', `iorM3', `xorM3'
        !           173:      Similar, for other arithmetic operations.
        !           174: 
        !           175: `mulhisi3'
        !           176:      Multiply operands 1 and 2, which have mode `HImode', and store a
        !           177:      `SImode' product in operand 0.
        !           178: 
        !           179: `mulqihi3', `mulsidi3'
        !           180:      Similar widening-multiplication instructions of other widths.
        !           181: 
        !           182: `umulqihi3', `umulhisi3', `umulsidi3'
        !           183:      Similar widening-multiplication instructions that do unsigned
        !           184:      multiplication.
        !           185: 
        !           186: `divmodM4'
        !           187:      Signed division that produces both a quotient and a remainder.
        !           188:      Operand 1 is divided by operand 2 to produce a quotient stored in
        !           189:      operand 0 and a remainder stored in operand 3.
        !           190: 
        !           191:      For machines with an instruction that produces both a quotient and
        !           192:      a remainder, provide a pattern for `divmodM4' but do not provide
        !           193:      patterns for `divM3' and `modM3'.  This allows optimization in the
        !           194:      relatively common case when both the quotient and remainder are
        !           195:      computed.
        !           196: 
        !           197:      If an instruction that just produces a quotient or just a remainder
        !           198:      exists and is more efficient than the instruction that produces
        !           199:      both, write the output routine of `divmodM4' to call
        !           200:      `find_reg_note' and look for a `REG_UNUSED' note on the quotient
        !           201:      or remainder and generate the appropriate instruction.
        !           202: 
        !           203: `udivmodM4'
        !           204:      Similar, but does unsigned division.
        !           205: 
        !           206: `ashlM3'
        !           207:      Arithmetic-shift operand 1 left by a number of bits specified by
        !           208:      operand 2, and store the result in operand 0.  Here M is the mode
        !           209:      of operand 0 and operand 1; operand 2's mode is specified by the
        !           210:      instruction pattern, and the compiler will convert the operand to
        !           211:      that mode before generating the instruction.
        !           212: 
        !           213: `ashrM3', `lshlM3', `lshrM3', `rotlM3', `rotrM3'
        !           214:      Other shift and rotate instructions, analogous to the `ashlM3'
        !           215:      instructions.
        !           216: 
        !           217:      Logical and arithmetic left shift are the same.  Machines that do
        !           218:      not allow negative shift counts often have only one instruction for
        !           219:      shifting left.  On such machines, you should define a pattern named
        !           220:      `ashlM3' and leave `lshlM3' undefined.
        !           221: 
        !           222: `negM2'
        !           223:      Negate operand 1 and store the result in operand 0.
        !           224: 
        !           225: `absM2'
        !           226:      Store the absolute value of operand 1 into operand 0.
        !           227: 
        !           228: `sqrtM2'
        !           229:      Store the square root of operand 1 into operand 0.
        !           230: 
        !           231:      The `sqrt' built-in function of C always uses the mode which
        !           232:      corresponds to the C data type `double'.
        !           233: 
        !           234: `ffsM2'
        !           235:      Store into operand 0 one plus the index of the least significant
        !           236:      1-bit of operand 1.  If operand 1 is zero, store zero.  M is the
        !           237:      mode of operand 0; operand 1's mode is specified by the instruction
        !           238:      pattern, and the compiler will convert the operand to that mode
        !           239:      before generating the instruction.
        !           240: 
        !           241:      The `ffs' built-in function of C always uses the mode which
        !           242:      corresponds to the C data type `int'.
        !           243: 
        !           244: `one_cmplM2'
        !           245:      Store the bitwise-complement of operand 1 into operand 0.
        !           246: 
        !           247: `cmpM'
        !           248:      Compare operand 0 and operand 1, and set the condition codes.  The
        !           249:      RTL pattern should look like this:
        !           250: 
        !           251:           (set (cc0) (compare (match_operand:M 0 ...)
        !           252:                               (match_operand:M 1 ...)))
        !           253: 
        !           254: `tstM'
        !           255:      Compare operand 0 against zero, and set the condition codes.  The
        !           256:      RTL pattern should look like this:
        !           257: 
        !           258:           (set (cc0) (match_operand:M 0 ...))
        !           259: 
        !           260:      `tstM' patterns should not be defined for machines that do not use
        !           261:      `(cc0)'.  Doing so would confuse the optimizer since it would no
        !           262:      longer be clear which `set' operations were comparisons.  The
        !           263:      `cmpM' patterns should be used instead.
        !           264: 
        !           265: `movstrM'
        !           266:      Block move instruction.  The addresses of the destination and
        !           267:      source strings are the first two operands, and both are in mode
        !           268:      `Pmode'.  The number of bytes to move is the third operand, in
        !           269:      mode M.
        !           270: 
        !           271:      The fourth operand is the known shared alignment of the source and
        !           272:      destination, in the form of a `const_int' rtx.  Thus, if the
        !           273:      compiler knows that both source and destination are word-aligned,
        !           274:      it may provide the value 4 for this operand.
        !           275: 
        !           276:      These patterns need not give special consideration to the
        !           277:      possibility that the source and destination strings might overlap.
        !           278: 
        !           279: `cmpstrM'
        !           280:      Block compare instruction, with five operands.  Operand 0 is the
        !           281:      output; it has mode M.  The remaining four operands are like the
        !           282:      operands of `movstrM'.  The two memory blocks specified are
        !           283:      compared byte by byte in lexicographic order.  The effect of the
        !           284:      instruction is to store a value in operand 0 whose sign indicates
        !           285:      the result of the comparison.
        !           286: 
        !           287:      Compute the length of a string, with three operands.  Operand 0 is
        !           288:      the result (of mode M), operand 1 is a `mem' referring to the
        !           289:      first character of the string, operand 2 is the character to
        !           290:      search for (normally zero), and operand 3 is a constant describing
        !           291:      the known alignment of the beginning of the string.
        !           292: 
        !           293: `floatMN2'
        !           294:      Convert signed integer operand 1 (valid for fixed point mode M) to
        !           295:      floating point mode N and store in operand 0 (which has mode N).
        !           296: 
        !           297: `floatunsMN2'
        !           298:      Convert unsigned integer operand 1 (valid for fixed point mode M)
        !           299:      to floating point mode N and store in operand 0 (which has mode N).
        !           300: 
        !           301: `fixMN2'
        !           302:      Convert operand 1 (valid for floating point mode M) to fixed point
        !           303:      mode N as a signed number and store in operand 0 (which has mode
        !           304:      N).  This instruction's result is defined only when the value of
        !           305:      operand 1 is an integer.
        !           306: 
        !           307: `fixunsMN2'
        !           308:      Convert operand 1 (valid for floating point mode M) to fixed point
        !           309:      mode N as an unsigned number and store in operand 0 (which has
        !           310:      mode N).  This instruction's result is defined only when the value
        !           311:      of operand 1 is an integer.
        !           312: 
        !           313: `ftruncM2'
        !           314:      Convert operand 1 (valid for floating point mode M) to an integer
        !           315:      value, still represented in floating point mode M, and store it in
        !           316:      operand 0 (valid for floating point mode M).
        !           317: 
        !           318: `fix_truncMN2'
        !           319:      Like `fixMN2' but works for any floating point value of mode M by
        !           320:      converting the value to an integer.
        !           321: 
        !           322: `fixuns_truncMN2'
        !           323:      Like `fixunsMN2' but works for any floating point value of mode M
        !           324:      by converting the value to an integer.
        !           325: 
        !           326: `truncMN'
        !           327:      Truncate operand 1 (valid for mode M) to mode N and store in
        !           328:      operand 0 (which has mode N).  Both modes must be fixed point or
        !           329:      both floating point.
        !           330: 
        !           331: `extendMN'
        !           332:      Sign-extend operand 1 (valid for mode M) to mode N and store in
        !           333:      operand 0 (which has mode N).  Both modes must be fixed point or
        !           334:      both floating point.
        !           335: 
        !           336: `zero_extendMN'
        !           337:      Zero-extend operand 1 (valid for mode M) to mode N and store in
        !           338:      operand 0 (which has mode N).  Both modes must be fixed point.
        !           339: 
        !           340: `extv'
        !           341:      Extract a bit field from operand 1 (a register or memory operand),
        !           342:      where operand 2 specifies the width in bits and operand 3 the
        !           343:      starting bit, and store it in operand 0.  Operand 0 must have mode
        !           344:      `word_mode'.  Operand 1 may have mode `byte_mode' or `word_mode';
        !           345:      often `word_mode' is allowed only for registers.  Operands 2 and 3
        !           346:      must be valid for `word_mode'.
        !           347: 
        !           348:      The RTL generation pass generates this instruction only with
        !           349:      constants for operands 2 and 3.
        !           350: 
        !           351:      The bit-field value is sign-extended to a full word integer before
        !           352:      it is stored in operand 0.
        !           353: 
        !           354: `extzv'
        !           355:      Like `extv' except that the bit-field value is zero-extended.
        !           356: 
        !           357: `insv'
        !           358:      Store operand 3 (which must be valid for `word_mode') into a bit
        !           359:      field in operand 0, where operand 1 specifies the width in bits and
        !           360:      operand 2 the starting bit.  Operand 0 may have mode `byte_mode' or
        !           361:      `word_mode'; often `word_mode' is allowed only for registers.
        !           362:      Operands 1 and 2 must be valid for `word_mode'.
        !           363: 
        !           364:      The RTL generation pass generates this instruction only with
        !           365:      constants for operands 1 and 2.
        !           366: 
        !           367: `sCOND'
        !           368:      Store zero or nonzero in the operand according to the condition
        !           369:      codes.  Value stored is nonzero iff the condition COND is true.
        !           370:      cOND is the name of a comparison operation expression code, such
        !           371:      as `eq', `lt' or `leu'.
        !           372: 
        !           373:      You specify the mode that the operand must have when you write the
        !           374:      `match_operand' expression.  The compiler automatically sees which
        !           375:      mode you have used and supplies an operand of that mode.
        !           376: 
        !           377:      The value stored for a true condition must have 1 as its low bit,
        !           378:      or else must be negative.  Otherwise the instruction is not
        !           379:      suitable and you should omit it from the machine description.  You
        !           380:      describe to the compiler exactly which value is stored by defining
        !           381:      the macro `STORE_FLAG_VALUE' (*note Misc::.).  If a description
        !           382:      cannot be found that can be used for all the `sCOND' patterns, you
        !           383:      should omit those operations from the machine description.
        !           384: 
        !           385:      These operations may fail, but should do so only in relatively
        !           386:      uncommon cases; if they would fail for common cases involving
        !           387:      integer comparisons, it is best to omit these patterns.
        !           388: 
        !           389:      If these operations are omitted, the compiler will usually
        !           390:      generate code that copies the constant one to the target and
        !           391:      branches around an assignment of zero to the target.  If this code
        !           392:      is more efficient than the potential instructions used for the
        !           393:      `sCOND' pattern followed by those required to convert the result
        !           394:      into a 1 or a zero in `SImode', you should omit the `sCOND'
        !           395:      operations from the machine description.
        !           396: 
        !           397: `bCOND'
        !           398:      Conditional branch instruction.  Operand 0 is a `label_ref' that
        !           399:      refers to the label to jump to.  Jump if the condition codes meet
        !           400:      condition COND.
        !           401: 
        !           402:      Some machines do not follow the model assumed here where a
        !           403:      comparison instruction is followed by a conditional branch
        !           404:      instruction.  In that case, the `cmpM' (and `tstM') patterns should
        !           405:      simply store the operands away and generate all the required insns
        !           406:      in a `define_expand' (*note Expander Definitions::.) for the
        !           407:      conditional branch operations.  All calls to expand `bCOND'
        !           408:      patterns are immediately preceded by calls to expand either a
        !           409:      `cmpM' pattern or a `tstM' pattern.
        !           410: 
        !           411:      Machines that use a pseudo register for the condition code value,
        !           412:      or where the mode used for the comparison depends on the condition
        !           413:      being tested, should also use the above mechanism.  *Note Jump
        !           414:      Patterns::
        !           415: 
        !           416:      The above discussion also applies to `sCOND' patterns.
        !           417: 
        !           418: `call'
        !           419:      Subroutine call instruction returning no value.  Operand 0 is the
        !           420:      function to call; operand 1 is the number of bytes of arguments
        !           421:      pushed (in mode `SImode', except it is normally a `const_int');
        !           422:      operand 2 is the number of registers used as operands.
        !           423: 
        !           424:      On most machines, operand 2 is not actually stored into the RTL
        !           425:      pattern.  It is supplied for the sake of some RISC machines which
        !           426:      need to put this information into the assembler code; they can put
        !           427:      it in the RTL instead of operand 1.
        !           428: 
        !           429:      Operand 0 should be a `mem' RTX whose address is the address of the
        !           430:      function.  Note, however, that this address can be a `symbol_ref'
        !           431:      expression even if it would not be a legitimate memory address on
        !           432:      the target machine.  If it is also not a valid argument for a call
        !           433:      instruction, the pattern for this operation should be a
        !           434:      `define_expand' (*note Expander Definitions::.) that places the
        !           435:      address into a register and uses that register in the call
        !           436:      instruction.
        !           437: 
        !           438: `call_value'
        !           439:      Subroutine call instruction returning a value.  Operand 0 is the
        !           440:      hard register in which the value is returned.  There are three more
        !           441:      operands, the same as the three operands of the `call' instruction
        !           442:      (but with numbers increased by one).
        !           443: 
        !           444:      Subroutines that return `BLKmode' objects use the `call' insn.
        !           445: 
        !           446: `call_pop', `call_value_pop'
        !           447:      Similar to `call' and `call_value', except used if defined and if
        !           448:      `RETURN_POPS_ARGS' is non-zero.  They should emit a `parallel'
        !           449:      that contains both the function call and a `set' to indicate the
        !           450:      adjustment made to the frame pointer.
        !           451: 
        !           452:      For machines where `RETURN_POPS_ARGS' can be non-zero, the use of
        !           453:      these patterns increases the number of functions for which the
        !           454:      frame pointer can be eliminated, if desired.
        !           455: 
        !           456: `untyped_call'
        !           457:      Subroutine call instruction returning a value of any type.
        !           458:      Operand 0 is the function to call; operand 1 is a memory location
        !           459:      where the result of calling the function is to be stored; operand
        !           460:      2 is a `parallel' expression where each element is a `set'
        !           461:      expression that indicates the saving of a function return value
        !           462:      into the result block.
        !           463: 
        !           464:      This instruction pattern should be defined to support
        !           465:      `__builtin_apply' on machines where special instructions are needed
        !           466:      to call a subroutine with arbitrary arguments or to save the value
        !           467:      returned.  This instruction pattern is required on machines that
        !           468:      have multiple registers that can hold a return value (i.e.
        !           469:      `FUNCTION_VALUE_REGNO_P' is true for more than one register).
        !           470: 
        !           471: `return'
        !           472:      Subroutine return instruction.  This instruction pattern name
        !           473:      should be defined only if a single instruction can do all the work
        !           474:      of returning from a function.
        !           475: 
        !           476:      Like the `movM' patterns, this pattern is also used after the RTL
        !           477:      generation phase.  In this case it is to support machines where
        !           478:      multiple instructions are usually needed to return from a
        !           479:      function, but some class of functions only requires one
        !           480:      instruction to implement a return.  Normally, the applicable
        !           481:      functions are those which do not need to save any registers or
        !           482:      allocate stack space.
        !           483: 
        !           484:      For such machines, the condition specified in this pattern should
        !           485:      only be true when `reload_completed' is non-zero and the function's
        !           486:      epilogue would only be a single instruction.  For machines with
        !           487:      register windows, the routine `leaf_function_p' may be used to
        !           488:      determine if a register window push is required.
        !           489: 
        !           490:      Machines that have conditional return instructions should define
        !           491:      patterns such as
        !           492: 
        !           493:           (define_insn ""
        !           494:             [(set (pc)
        !           495:                   (if_then_else (match_operator
        !           496:                                    0 "comparison_operator"
        !           497:                                    [(cc0) (const_int 0)])
        !           498:                                 (return)
        !           499:                                 (pc)))]
        !           500:             "CONDITION"
        !           501:             "...")
        !           502: 
        !           503:      where CONDITION would normally be the same condition specified on
        !           504:      the named `return' pattern.
        !           505: 
        !           506: `untyped_return'
        !           507:      Untyped subroutine return instruction.  This instruction pattern
        !           508:      should be defined to support `__builtin_return' on machines where
        !           509:      special instructions are needed to return a value of any type.
        !           510: 
        !           511:      Operand 0 is a memory location where the result of calling a
        !           512:      function with `__builtin_apply' is stored; operand 1 is a
        !           513:      `parallel' expression where each element is a `set' expression
        !           514:      that indicates the restoring of a function return value from the
        !           515:      result block.
        !           516: 
        !           517: `nop'
        !           518:      No-op instruction.  This instruction pattern name should always be
        !           519:      defined to output a no-op in assembler code.  `(const_int 0)' will
        !           520:      do as an RTL pattern.
        !           521: 
        !           522: `indirect_jump'
        !           523:      An instruction to jump to an address which is operand zero.  This
        !           524:      pattern name is mandatory on all machines.
        !           525: 
        !           526: `casesi'
        !           527:      Instruction to jump through a dispatch table, including bounds
        !           528:      checking.  This instruction takes five operands:
        !           529: 
        !           530:        1. The index to dispatch on, which has mode `SImode'.
        !           531: 
        !           532:        2. The lower bound for indices in the table, an integer constant.
        !           533: 
        !           534:        3. The total range of indices in the table--the largest index
        !           535:           minus the smallest one (both inclusive).
        !           536: 
        !           537:        4. A label that precedes the table itself.
        !           538: 
        !           539:        5. A label to jump to if the index has a value outside the
        !           540:           bounds.  (If the machine-description macro
        !           541:           `CASE_DROPS_THROUGH' is defined, then an out-of-bounds index
        !           542:           drops through to the code following the jump table instead of
        !           543:           jumping to this label.  In that case, this label is not
        !           544:           actually used by the `casesi' instruction, but it is always
        !           545:           provided as an operand.)
        !           546: 
        !           547:      The table is a `addr_vec' or `addr_diff_vec' inside of a
        !           548:      `jump_insn'.  The number of elements in the table is one plus the
        !           549:      difference between the upper bound and the lower bound.
        !           550: 
        !           551: `tablejump'
        !           552:      Instruction to jump to a variable address.  This is a low-level
        !           553:      capability which can be used to implement a dispatch table when
        !           554:      there is no `casesi' pattern.
        !           555: 
        !           556:      This pattern requires two operands: the address or offset, and a
        !           557:      label which should immediately precede the jump table.  If the
        !           558:      macro `CASE_VECTOR_PC_RELATIVE' is defined then the first operand
        !           559:      is an offset which counts from the address of the table;
        !           560:      otherwise, it is an absolute address to jump to.  In either case,
        !           561:      the first operand has mode `Pmode'.
        !           562: 
        !           563:      The `tablejump' insn is always the last insn before the jump table
        !           564:      it uses.  Its assembler code normally has no need to use the
        !           565:      second operand, but you should incorporate it in the RTL pattern so
        !           566:      that the jump optimizer will not delete the table as unreachable
        !           567:      code.
        !           568: 
        !           569: `save_stack_block'
        !           570: `save_stack_function'
        !           571: `save_stack_nonlocal'
        !           572: `restore_stack_block'
        !           573: `restore_stack_function'
        !           574: `restore_stack_nonlocal'
        !           575:      Most machines save and restore the stack pointer by copying it to
        !           576:      or from an object of mode `Pmode'.  Do not define these patterns on
        !           577:      such machines.
        !           578: 
        !           579:      Some machines require special handling for stack pointer saves and
        !           580:      restores.  On those machines, define the patterns corresponding to
        !           581:      the non-standard cases by using a `define_expand' (*note Expander
        !           582:      Definitions::.) that produces the required insns.  The three types
        !           583:      of saves and restores are:
        !           584: 
        !           585:        1. `save_stack_block' saves the stack pointer at the start of a
        !           586:           block that allocates a variable-sized object, and
        !           587:           `restore_stack_block' restores the stack pointer when the
        !           588:           block is exited.
        !           589: 
        !           590:        2. `save_stack_function' and `restore_stack_function' do a
        !           591:           similar job for the outermost block of a function and are
        !           592:           used when the function allocates variable-sized objects or
        !           593:           calls `alloca'.  Only the epilogue uses the restored stack
        !           594:           pointer, allowing a simpler save or restore sequence on some
        !           595:           machines.
        !           596: 
        !           597:        3. `save_stack_nonlocal' is used in functions that contain labels
        !           598:           branched to by nested functions.  It saves the stack pointer
        !           599:           in such a way that the inner function can use
        !           600:           `restore_stack_nonlocal' to restore the stack pointer.  The
        !           601:           compiler generates code to restore the frame and argument
        !           602:           pointer registers, but some machines require saving and
        !           603:           restoring additional data such as register window information
        !           604:           or stack backchains.  Place insns in these patterns to save
        !           605:           and restore any such required data.
        !           606: 
        !           607:      When saving the stack pointer, operand 0 is the save area and
        !           608:      operand 1 is the stack pointer.  The mode used to allocate the
        !           609:      save area is the mode of operand 0.  You must specify an integral
        !           610:      mode, or `VOIDmode' if no save area is needed for a particular
        !           611:      type of save (either because no save is needed or because a
        !           612:      machine-specific save area can be used).  Operand 0 is the stack
        !           613:      pointer and operand 1 is the save area for restore operations.  If
        !           614:      `save_stack_block' is defined, operand 0 must not be `VOIDmode'
        !           615:      since these saves can be arbitrarily nested.
        !           616: 
        !           617:      A save area is a `mem' that is at a constant offset from
        !           618:      `virtual_stack_vars_rtx' when the stack pointer is saved for use by
        !           619:      nonlocal gotos and a `reg' in the other two cases.
        !           620: 
        !           621: `allocate_stack'
        !           622:      Subtract (or add if `STACK_GROWS_DOWNWARD' is undefined) operand 0
        !           623:      from the stack pointer to create space for dynamically allocated
        !           624:      data.
        !           625: 
        !           626:      Do not define this pattern if all that must be done is the
        !           627:      subtraction.  Some machines require other operations such as stack
        !           628:      probes or maintaining the back chain.  Define this pattern to emit
        !           629:      those operations in addition to updating the stack pointer.
        !           630: 
        !           631: 
        !           632: File: gcc.info,  Node: Pattern Ordering,  Next: Dependent Patterns,  Prev: Standard Names,  Up: Machine Desc
        !           633: 
        !           634: When the Order of Patterns Matters
        !           635: ==================================
        !           636: 
        !           637:    Sometimes an insn can match more than one instruction pattern.  Then
        !           638: the pattern that appears first in the machine description is the one
        !           639: used.  Therefore, more specific patterns (patterns that will match
        !           640: fewer things) and faster instructions (those that will produce better
        !           641: code when they do match) should usually go first in the description.
        !           642: 
        !           643:    In some cases the effect of ordering the patterns can be used to hide
        !           644: a pattern when it is not valid.  For example, the 68000 has an
        !           645: instruction for converting a fullword to floating point and another for
        !           646: converting a byte to floating point.  An instruction converting an
        !           647: integer to floating point could match either one.  We put the pattern
        !           648: to convert the fullword first to make sure that one will be used rather
        !           649: than the other.  (Otherwise a large integer might be generated as a
        !           650: single-byte immediate quantity, which would not work.) Instead of using
        !           651: this pattern ordering it would be possible to make the pattern for
        !           652: convert-a-byte smart enough to deal properly with any constant value.
        !           653: 
        !           654: 
        !           655: File: gcc.info,  Node: Dependent Patterns,  Next: Jump Patterns,  Prev: Pattern Ordering,  Up: Machine Desc
        !           656: 
        !           657: Interdependence of Patterns
        !           658: ===========================
        !           659: 
        !           660:    Every machine description must have a named pattern for each of the
        !           661: conditional branch names `bCOND'.  The recognition template must always
        !           662: have the form
        !           663: 
        !           664:      (set (pc)
        !           665:           (if_then_else (COND (cc0) (const_int 0))
        !           666:                         (label_ref (match_operand 0 "" ""))
        !           667:                         (pc)))
        !           668: 
        !           669: In addition, every machine description must have an anonymous pattern
        !           670: for each of the possible reverse-conditional branches.  Their templates
        !           671: look like
        !           672: 
        !           673:      (set (pc)
        !           674:           (if_then_else (COND (cc0) (const_int 0))
        !           675:                         (pc)
        !           676:                         (label_ref (match_operand 0 "" ""))))
        !           677: 
        !           678: They are necessary because jump optimization can turn direct-conditional
        !           679: branches into reverse-conditional branches.
        !           680: 
        !           681:    It is often convenient to use the `match_operator' construct to
        !           682: reduce the number of patterns that must be specified for branches.  For
        !           683: example,
        !           684: 
        !           685:      (define_insn ""
        !           686:        [(set (pc)
        !           687:              (if_then_else (match_operator 0 "comparison_operator"
        !           688:                                            [(cc0) (const_int 0)])
        !           689:                            (pc)
        !           690:                            (label_ref (match_operand 1 "" ""))))]
        !           691:        "CONDITION"
        !           692:        "...")
        !           693: 
        !           694:    In some cases machines support instructions identical except for the
        !           695: machine mode of one or more operands.  For example, there may be
        !           696: "sign-extend halfword" and "sign-extend byte" instructions whose
        !           697: patterns are
        !           698: 
        !           699:      (set (match_operand:SI 0 ...)
        !           700:           (extend:SI (match_operand:HI 1 ...)))
        !           701:      
        !           702:      (set (match_operand:SI 0 ...)
        !           703:           (extend:SI (match_operand:QI 1 ...)))
        !           704: 
        !           705: Constant integers do not specify a machine mode, so an instruction to
        !           706: extend a constant value could match either pattern.  The pattern it
        !           707: actually will match is the one that appears first in the file.  For
        !           708: correct results, this must be the one for the widest possible mode
        !           709: (`HImode', here).  If the pattern matches the `QImode' instruction, the
        !           710: results will be incorrect if the constant value does not actually fit
        !           711: that mode.
        !           712: 
        !           713:    Such instructions to extend constants are rarely generated because
        !           714: they are optimized away, but they do occasionally happen in nonoptimized
        !           715: compilations.
        !           716: 
        !           717:    If a constraint in a pattern allows a constant, the reload pass may
        !           718: replace a register with a constant permitted by the constraint in some
        !           719: cases.  Similarly for memory references.  You must ensure that the
        !           720: predicate permits all objects allowed by the constraints to prevent the
        !           721: compiler from crashing.
        !           722: 
        !           723:    Because of this substitution, you should not provide separate
        !           724: patterns for increment and decrement instructions.  Instead, they
        !           725: should be generated from the same pattern that supports
        !           726: register-register add insns by examining the operands and generating
        !           727: the appropriate machine instruction.
        !           728: 
        !           729: 
        !           730: File: gcc.info,  Node: Jump Patterns,  Next: Insn Canonicalizations,  Prev: Dependent Patterns,  Up: Machine Desc
        !           731: 
        !           732: Defining Jump Instruction Patterns
        !           733: ==================================
        !           734: 
        !           735:    For most machines, GNU CC assumes that the machine has a condition
        !           736: code.  A comparison insn sets the condition code, recording the results
        !           737: of both signed and unsigned comparison of the given operands.  A
        !           738: separate branch insn tests the condition code and branches or not
        !           739: according its value.  The branch insns come in distinct signed and
        !           740: unsigned flavors.  Many common machines, such as the Vax, the 68000 and
        !           741: the 32000, work this way.
        !           742: 
        !           743:    Some machines have distinct signed and unsigned compare
        !           744: instructions, and only one set of conditional branch instructions.  The
        !           745: easiest way to handle these machines is to treat them just like the
        !           746: others until the final stage where assembly code is written.  At this
        !           747: time, when outputting code for the compare instruction, peek ahead at
        !           748: the following branch using `next_cc0_user (insn)'.  (The variable
        !           749: `insn' refers to the insn being output, in the output-writing code in
        !           750: an instruction pattern.)  If the RTL says that is an unsigned branch,
        !           751: output an unsigned compare; otherwise output a signed compare.  When
        !           752: the branch itself is output, you can treat signed and unsigned branches
        !           753: identically.
        !           754: 
        !           755:    The reason you can do this is that GNU CC always generates a pair of
        !           756: consecutive RTL insns, possibly separated by `note' insns, one to set
        !           757: the condition code and one to test it, and keeps the pair inviolate
        !           758: until the end.
        !           759: 
        !           760:    To go with this technique, you must define the machine-description
        !           761: macro `NOTICE_UPDATE_CC' to do `CC_STATUS_INIT'; in other words, no
        !           762: compare instruction is superfluous.
        !           763: 
        !           764:    Some machines have compare-and-branch instructions and no condition
        !           765: code.  A similar technique works for them.  When it is time to "output"
        !           766: a compare instruction, record its operands in two static variables.
        !           767: When outputting the branch-on-condition-code instruction that follows,
        !           768: actually output a compare-and-branch instruction that uses the
        !           769: remembered operands.
        !           770: 
        !           771:    It also works to define patterns for compare-and-branch instructions.
        !           772: In optimizing compilation, the pair of compare and branch instructions
        !           773: will be combined according to these patterns.  But this does not happen
        !           774: if optimization is not requested.  So you must use one of the solutions
        !           775: above in addition to any special patterns you define.
        !           776: 
        !           777:    In many RISC machines, most instructions do not affect the condition
        !           778: code and there may not even be a separate condition code register.  On
        !           779: these machines, the restriction that the definition and use of the
        !           780: condition code be adjacent insns is not necessary and can prevent
        !           781: important optimizations.  For example, on the IBM RS/6000, there is a
        !           782: delay for taken branches unless the condition code register is set three
        !           783: instructions earlier than the conditional branch.  The instruction
        !           784: scheduler cannot perform this optimization if it is not permitted to
        !           785: separate the definition and use of the condition code register.
        !           786: 
        !           787:    On these machines, do not use `(cc0)', but instead use a register to
        !           788: represent the condition code.  If there is a specific condition code
        !           789: register in the machine, use a hard register.  If the condition code or
        !           790: comparison result can be placed in any general register, or if there are
        !           791: multiple condition registers, use a pseudo register.
        !           792: 
        !           793:    On some machines, the type of branch instruction generated may
        !           794: depend on the way the condition code was produced; for example, on the
        !           795: 68k and Sparc, setting the condition code directly from an add or
        !           796: subtract instruction does not clear the overflow bit the way that a test
        !           797: instruction does, so a different branch instruction must be used for
        !           798: some conditional branches.  For machines that use `(cc0)', the set and
        !           799: use of the condition code must be adjacent (separated only by `note'
        !           800: insns) allowing flags in `cc_status' to be used.  (*Note Condition
        !           801: Code::.)  Also, the comparison and branch insns can be located from
        !           802: each other by using the functions `prev_cc0_setter' and `next_cc0_user'.
        !           803: 
        !           804:    However, this is not true on machines that do not use `(cc0)'.  On
        !           805: those machines, no assumptions can be made about the adjacency of the
        !           806: compare and branch insns and the above methods cannot be used.  Instead,
        !           807: we use the machine mode of the condition code register to record
        !           808: different formats of the condition code register.
        !           809: 
        !           810:    Registers used to store the condition code value should have a mode
        !           811: that is in class `MODE_CC'.  Normally, it will be `CCmode'.  If
        !           812: additional modes are required (as for the add example mentioned above in
        !           813: the Sparc), define the macro `EXTRA_CC_MODES' to list the additional
        !           814: modes required (*note Condition Code::.).  Also define `EXTRA_CC_NAMES'
        !           815: to list the names of those modes and `SELECT_CC_MODE' to choose a mode
        !           816: given an operand of a compare.
        !           817: 
        !           818:    If it is known during RTL generation that a different mode will be
        !           819: required (for example, if the machine has separate compare instructions
        !           820: for signed and unsigned quantities, like most IBM processors), they can
        !           821: be specified at that time.
        !           822: 
        !           823:    If the cases that require different modes would be made by
        !           824: instruction combination, the macro `SELECT_CC_MODE' determines which
        !           825: machine mode should be used for the comparison result.  The patterns
        !           826: should be written using that mode.  To support the case of the add on
        !           827: the Sparc discussed above, we have the pattern
        !           828: 
        !           829:      (define_insn ""
        !           830:        [(set (reg:CC_NOOV 0)
        !           831:              (compare:CC_NOOV
        !           832:                (plus:SI (match_operand:SI 0 "register_operand" "%r")
        !           833:                         (match_operand:SI 1 "arith_operand" "rI"))
        !           834:                (const_int 0)))]
        !           835:        ""
        !           836:        "...")
        !           837: 
        !           838:    The `SELECT_CC_MODE' macro on the Sparc returns `CC_NOOVmode' for
        !           839: comparisons whose argument is a `plus'.
        !           840: 
        !           841: 
        !           842: File: gcc.info,  Node: Insn Canonicalizations,  Next: Peephole Definitions,  Prev: Jump Patterns,  Up: Machine Desc
        !           843: 
        !           844: Canonicalization of Instructions
        !           845: ================================
        !           846: 
        !           847:    There are often cases where multiple RTL expressions could represent
        !           848: an operation performed by a single machine instruction.  This situation
        !           849: is most commonly encountered with logical, branch, and
        !           850: multiply-accumulate instructions.  In such cases, the compiler attempts
        !           851: to convert these multiple RTL expressions into a single canonical form
        !           852: to reduce the number of insn patterns required.
        !           853: 
        !           854:    In addition to algebraic simplifications, following canonicalizations
        !           855: are performed:
        !           856: 
        !           857:    * For commutative and comparison operators, a constant is always
        !           858:      made the second operand.  If a machine only supports a constant as
        !           859:      the second operand, only patterns that match a constant in the
        !           860:      second operand need be supplied.
        !           861: 
        !           862:      For these operators, if only one operand is a `neg', `not',
        !           863:      `mult', `plus', or `minus' expression, it will be the first
        !           864:      operand.
        !           865: 
        !           866:    * For the `compare' operator, a constant is always the second operand
        !           867:      on machines where `cc0' is used (*note Jump Patterns::.).  On other
        !           868:      machines, there are rare cases where the compiler might want to
        !           869:      construct a `compare' with a constant as the first operand.
        !           870:      However, these cases are not common enough for it to be worthwhile
        !           871:      to provide a pattern matching a constant as the first operand
        !           872:      unless the machine actually has such an instruction.
        !           873: 
        !           874:      An operand of `neg', `not', `mult', `plus', or `minus' is made the
        !           875:      first operand under the same conditions as above.
        !           876: 
        !           877:    * `(minus X (const_int N))' is converted to `(plus X (const_int
        !           878:      -N))'.
        !           879: 
        !           880:    * Within address computations (i.e., inside `mem'), a left shift is
        !           881:      converted into the appropriate multiplication by a power of two.
        !           882: 
        !           883:      De`Morgan's Law is used to move bitwise negation inside a bitwise
        !           884:      logical-and or logical-or operation.  If this results in only one
        !           885:      operand being a `not' expression, it will be the first one.
        !           886: 
        !           887:      A machine that has an instruction that performs a bitwise
        !           888:      logical-and of one operand with the bitwise negation of the other
        !           889:      should specify the pattern for that instruction as
        !           890: 
        !           891:           (define_insn ""
        !           892:             [(set (match_operand:M 0 ...)
        !           893:                   (and:M (not:M (match_operand:M 1 ...))
        !           894:                                (match_operand:M 2 ...)))]
        !           895:             "..."
        !           896:             "...")
        !           897: 
        !           898:      Similarly, a pattern for a "NAND" instruction should be written
        !           899: 
        !           900:           (define_insn ""
        !           901:             [(set (match_operand:M 0 ...)
        !           902:                   (ior:M (not:M (match_operand:M 1 ...))
        !           903:                                (not:M (match_operand:M 2 ...))))]
        !           904:             "..."
        !           905:             "...")
        !           906: 
        !           907:      In both cases, it is not necessary to include patterns for the many
        !           908:      logically equivalent RTL expressions.
        !           909: 
        !           910:    * The only possible RTL expressions involving both bitwise
        !           911:      exclusive-or and bitwise negation are `(xor:M X Y)' and `(not:M
        !           912:      (xor:M X Y))'.
        !           913: 
        !           914:    * The sum of three items, one of which is a constant, will only
        !           915:      appear in the form
        !           916: 
        !           917:           (plus:M (plus:M X Y) CONSTANT)
        !           918: 
        !           919:    * On machines that do not use `cc0', `(compare X (const_int 0))'
        !           920:      will be converted to X.
        !           921: 
        !           922:    * Equality comparisons of a group of bits (usually a single bit)
        !           923:      with zero will be written using `zero_extract' rather than the
        !           924:      equivalent `and' or `sign_extract' operations.
        !           925: 
        !           926: 
        !           927: File: gcc.info,  Node: Peephole Definitions,  Next: Expander Definitions,  Prev: Insn Canonicalizations,  Up: Machine Desc
        !           928: 
        !           929: Machine-Specific Peephole Optimizers
        !           930: ====================================
        !           931: 
        !           932:    In addition to instruction patterns the `md' file may contain
        !           933: definitions of machine-specific peephole optimizations.
        !           934: 
        !           935:    The combiner does not notice certain peephole optimizations when the
        !           936: data flow in the program does not suggest that it should try them.  For
        !           937: example, sometimes two consecutive insns related in purpose can be
        !           938: combined even though the second one does not appear to use a register
        !           939: computed in the first one.  A machine-specific peephole optimizer can
        !           940: detect such opportunities.
        !           941: 
        !           942:    A definition looks like this:
        !           943: 
        !           944:      (define_peephole
        !           945:        [INSN-PATTERN-1
        !           946:         INSN-PATTERN-2
        !           947:         ...]
        !           948:        "CONDITION"
        !           949:        "TEMPLATE"
        !           950:        "OPTIONAL INSN-ATTRIBUTES")
        !           951: 
        !           952: The last string operand may be omitted if you are not using any
        !           953: machine-specific information in this machine description.  If present,
        !           954: it must obey the same rules as in a `define_insn'.
        !           955: 
        !           956:    In this skeleton, INSN-PATTERN-1 and so on are patterns to match
        !           957: consecutive insns.  The optimization applies to a sequence of insns when
        !           958: INSN-PATTERN-1 matches the first one, INSN-PATTERN-2 matches the next,
        !           959: and so on.
        !           960: 
        !           961:    Each of the insns matched by a peephole must also match a
        !           962: `define_insn'.  Peepholes are checked only at the last stage just
        !           963: before code generation, and only optionally.  Therefore, any insn which
        !           964: would match a peephole but no `define_insn' will cause a crash in code
        !           965: generation in an unoptimized compilation, or at various optimization
        !           966: stages.
        !           967: 
        !           968:    The operands of the insns are matched with `match_operands',
        !           969: `match_operator', and `match_dup', as usual.  What is not usual is that
        !           970: the operand numbers apply to all the insn patterns in the definition.
        !           971: So, you can check for identical operands in two insns by using
        !           972: `match_operand' in one insn and `match_dup' in the other.
        !           973: 
        !           974:    The operand constraints used in `match_operand' patterns do not have
        !           975: any direct effect on the applicability of the peephole, but they will
        !           976: be validated afterward, so make sure your constraints are general enough
        !           977: to apply whenever the peephole matches.  If the peephole matches but
        !           978: the constraints are not satisfied, the compiler will crash.
        !           979: 
        !           980:    It is safe to omit constraints in all the operands of the peephole;
        !           981: or you can write constraints which serve as a double-check on the
        !           982: criteria previously tested.
        !           983: 
        !           984:    Once a sequence of insns matches the patterns, the CONDITION is
        !           985: checked.  This is a C expression which makes the final decision whether
        !           986: to perform the optimization (we do so if the expression is nonzero).  If
        !           987: CONDITION is omitted (in other words, the string is empty) then the
        !           988: optimization is applied to every sequence of insns that matches the
        !           989: patterns.
        !           990: 
        !           991:    The defined peephole optimizations are applied after register
        !           992: allocation is complete.  Therefore, the peephole definition can check
        !           993: which operands have ended up in which kinds of registers, just by
        !           994: looking at the operands.
        !           995: 
        !           996:    The way to refer to the operands in CONDITION is to write
        !           997: `operands[I]' for operand number I (as matched by `(match_operand I
        !           998: ...)').  Use the variable `insn' to refer to the last of the insns
        !           999: being matched; use `prev_nonnote_insn' to find the preceding insns.
        !          1000: 
        !          1001:    When optimizing computations with intermediate results, you can use
        !          1002: CONDITION to match only when the intermediate results are not used
        !          1003: elsewhere.  Use the C expression `dead_or_set_p (INSN, OP)', where INSN
        !          1004: is the insn in which you expect the value to be used for the last time
        !          1005: (from the value of `insn', together with use of `prev_nonnote_insn'),
        !          1006: and OP is the intermediate value (from `operands[I]').
        !          1007: 
        !          1008:    Applying the optimization means replacing the sequence of insns with
        !          1009: one new insn.  The TEMPLATE controls ultimate output of assembler code
        !          1010: for this combined insn.  It works exactly like the template of a
        !          1011: `define_insn'.  Operand numbers in this template are the same ones used
        !          1012: in matching the original sequence of insns.
        !          1013: 
        !          1014:    The result of a defined peephole optimizer does not need to match
        !          1015: any of the insn patterns in the machine description; it does not even
        !          1016: have an opportunity to match them.  The peephole optimizer definition
        !          1017: itself serves as the insn pattern to control how the insn is output.
        !          1018: 
        !          1019:    Defined peephole optimizers are run as assembler code is being
        !          1020: output, so the insns they produce are never combined or rearranged in
        !          1021: any way.
        !          1022: 
        !          1023:    Here is an example, taken from the 68000 machine description:
        !          1024: 
        !          1025:      (define_peephole
        !          1026:        [(set (reg:SI 15) (plus:SI (reg:SI 15) (const_int 4)))
        !          1027:         (set (match_operand:DF 0 "register_operand" "=f")
        !          1028:              (match_operand:DF 1 "register_operand" "ad"))]
        !          1029:        "FP_REG_P (operands[0]) && ! FP_REG_P (operands[1])"
        !          1030:        "*
        !          1031:      {
        !          1032:        rtx xoperands[2];
        !          1033:        xoperands[1] = gen_rtx (REG, SImode, REGNO (operands[1]) + 1);
        !          1034:      #ifdef MOTOROLA
        !          1035:        output_asm_insn (\"move.l %1,(sp)\", xoperands);
        !          1036:        output_asm_insn (\"move.l %1,-(sp)\", operands);
        !          1037:        return \"fmove.d (sp)+,%0\";
        !          1038:      #else
        !          1039:        output_asm_insn (\"movel %1,sp@\", xoperands);
        !          1040:        output_asm_insn (\"movel %1,sp@-\", operands);
        !          1041:        return \"fmoved sp@+,%0\";
        !          1042:      #endif
        !          1043:      }
        !          1044:      ")
        !          1045: 
        !          1046:    The effect of this optimization is to change
        !          1047: 
        !          1048:      jbsr _foobar
        !          1049:      addql #4,sp
        !          1050:      movel d1,sp@-
        !          1051:      movel d0,sp@-
        !          1052:      fmoved sp@+,fp0
        !          1053: 
        !          1054: into
        !          1055: 
        !          1056:      jbsr _foobar
        !          1057:      movel d1,sp@
        !          1058:      movel d0,sp@-
        !          1059:      fmoved sp@+,fp0
        !          1060: 
        !          1061:    INSN-PATTERN-1 and so on look *almost* like the second operand of
        !          1062: `define_insn'.  There is one important difference: the second operand
        !          1063: of `define_insn' consists of one or more RTX's enclosed in square
        !          1064: brackets.  Usually, there is only one: then the same action can be
        !          1065: written as an element of a `define_peephole'.  But when there are
        !          1066: multiple actions in a `define_insn', they are implicitly enclosed in a
        !          1067: `parallel'.  Then you must explicitly write the `parallel', and the
        !          1068: square brackets within it, in the `define_peephole'.  Thus, if an insn
        !          1069: pattern looks like this,
        !          1070: 
        !          1071:      (define_insn "divmodsi4"
        !          1072:        [(set (match_operand:SI 0 "general_operand" "=d")
        !          1073:              (div:SI (match_operand:SI 1 "general_operand" "0")
        !          1074:                      (match_operand:SI 2 "general_operand" "dmsK")))
        !          1075:         (set (match_operand:SI 3 "general_operand" "=d")
        !          1076:              (mod:SI (match_dup 1) (match_dup 2)))]
        !          1077:        "TARGET_68020"
        !          1078:        "divsl%.l %2,%3:%0")
        !          1079: 
        !          1080: then the way to mention this insn in a peephole is as follows:
        !          1081: 
        !          1082:      (define_peephole
        !          1083:        [...
        !          1084:         (parallel
        !          1085:          [(set (match_operand:SI 0 "general_operand" "=d")
        !          1086:                (div:SI (match_operand:SI 1 "general_operand" "0")
        !          1087:                        (match_operand:SI 2 "general_operand" "dmsK")))
        !          1088:           (set (match_operand:SI 3 "general_operand" "=d")
        !          1089:                (mod:SI (match_dup 1) (match_dup 2)))])
        !          1090:         ...]
        !          1091:        ...)
        !          1092: 

unix.superglobalmegacorp.com

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