Annotation of GNUtools/cc/config/pyr/pyr.h, revision 1.1.1.1

1.1       root        1: /* Definitions of target machine parameters for GNU compiler,
                      2:    for Pyramid 90x, 9000, and MIServer Series.
                      3:    Copyright (C) 1989 Free Software Foundation, Inc.
                      4: 
                      5: This file is part of GNU CC.
                      6: 
                      7: GNU CC is free software; you can redistribute it and/or modify
                      8: it under the terms of the GNU General Public License as published by
                      9: the Free Software Foundation; either version 2, or (at your option)
                     10: any later version.
                     11: 
                     12: GNU CC is distributed in the hope that it will be useful,
                     13: but WITHOUT ANY WARRANTY; without even the implied warranty of
                     14: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     15: GNU General Public License for more details.
                     16: 
                     17: You should have received a copy of the GNU General Public License
                     18: along with GNU CC; see the file COPYING.  If not, write to
                     19: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
                     20: 
                     21: /*
                     22:  * If you're going to change this, and you haven't already,
                     23:  * you should get and read
                     24:  *     ``OSx Operating System Porting Guide'',
                     25:  *       publication number 4100-0066-A
                     26:  *       Revision A
                     27:  *       Pyramid Technology Corporation.
                     28:  *
                     29:  * or whatever the most recent version is.  In any case, page and
                     30:  * section number references given herein refer to this document.
                     31:  *
                     32:  *  The instruction table for gdb lists the available insns and
                     33:  *  the valid addressing modes.
                     34:  *
                     35:  *  Any other information on the Pyramid architecture is proprietary
                     36:  *  and hard to get. (Pyramid cc -S and adb are also useful.)
                     37:  *
                     38:  */
                     39: 
                     40: /*** Run-time compilation parameters selecting different hardware subsets. ***/
                     41: 
                     42: /* Names to predefine in the preprocessor for this target machine.  */
                     43: 
                     44: #define CPP_PREDEFINES "-Dpyr -Dunix -Asystem(unix) -Acpu(pyr) -Amachine(pyr)"
                     45: 
                     46: /* Print subsidiary information on the compiler version in use.  */
                     47: 
                     48: #define TARGET_VERSION fprintf (stderr, " (pyr)");
                     49: 
                     50: extern int target_flags;
                     51: 
                     52: /* Nonzero if compiling code that Unix assembler can assemble.  */
                     53: #define TARGET_UNIX_ASM (target_flags & 1)
                     54: 
                     55: /* Implement stdarg in the same fashion used on all other machines.  */
                     56: #define TARGET_GNU_STDARG   (target_flags & 2)
                     57: 
                     58: /* Compile using RETD to pop off the args.
                     59:    This will not work unless you use prototypes at least
                     60:    for all functions that can take varying numbers of args.
                     61:    This contravenes the Pyramid calling convention, so we don't
                     62:    do it yet.  */
                     63: 
                     64: #define TARGET_RETD (target_flags & 4)
                     65: 
                     66: /* Macros used in the machine description to test the flags.  */
                     67: 
                     68: /* Macro to define tables used to set the flags.
                     69:    This is a list in braces of pairs in braces,
                     70:    each pair being { "NAME", VALUE }
                     71:    where VALUE is the bits to set or minus the bits to clear.
                     72:    An empty string NAME is used to identify the default VALUE.
                     73: 
                     74:    -mgnu will be useful if we ever have GAS on a pyramid.  */
                     75: 
                     76: #define TARGET_SWITCHES  \
                     77:   { {"unix", 1},               \
                     78:     {"gnu", -1},               \
                     79:     {"gnu-stdarg", 2},         \
                     80:     {"nognu-stdarg", -2},      \
                     81:     {"retd", 4},               \
                     82:     {"no-retd", -4},           \
                     83:     { "", TARGET_DEFAULT}}
                     84: 
                     85: /* Default target_flags if no switches specified.
                     86: 
                     87:    (equivalent to "-munix -mindex -mgnu-stdarg")  */
                     88: 
                     89: #ifndef TARGET_DEFAULT
                     90: #define TARGET_DEFAULT (1 + 2)
                     91: #endif
                     92: 
                     93: /* Make GCC agree with types.h.  */
                     94: #ifdef SIZE_TYPE
                     95: #undef SIZE_TYPE
                     96: #endif
                     97: #define        SIZE_TYPE       "unsigned int"
                     98: 
                     99: /* Assembler does not permit $ in labels */
                    100: 
                    101: #define        NO_DOLLAR_IN_LABEL
                    102: 
                    103: /* Maybe it doesn't permit dot either.  */
                    104: #define NO_DOT_IN_LABEL
                    105: 
                    106: /* Never allow $ in identifiers */
                    107: 
                    108: #define DOLLARS_IN_IDENTIFIERS 0
                    109: 
                    110: /*** Target machine storage layout ***/
                    111: 
                    112: /* Define this to non-zero if most significant bit is lowest
                    113:    numbered in instructions that operate on numbered bit-fields.
                    114:    This is not true on the pyramid.  */
                    115: #define BITS_BIG_ENDIAN 0
                    116: 
                    117: /* Define this to non-zero if most significant byte of a word is
                    118:    the lowest numbered.  */
                    119: #define BYTES_BIG_ENDIAN 1
                    120: 
                    121: /* Define this to non-zero if most significant word of a multiword
                    122:    number is the lowest numbered.  */
                    123: #define WORDS_BIG_ENDIAN 1
                    124: 
                    125: /* Number of bits in an addressable storage unit */
                    126: #define BITS_PER_UNIT 8
                    127: 
                    128: /* Width in bits of a "word", which is the contents of a machine register.
                    129:    Note that this is not necessarily the width of data type `int';
                    130:    if using 16-bit ints on a 68000, this would still be 32.
                    131:    But on a machine with 16-bit registers, this would be 16.  */
                    132: #define BITS_PER_WORD 32
                    133: 
                    134: /* Width of a word, in units (bytes).  */
                    135: #define UNITS_PER_WORD 4
                    136: 
                    137: /* Width in bits of a pointer.
                    138:    See also the macro `Pmode' defined below.  */
                    139: #define POINTER_SIZE 32
                    140: 
                    141: /* Allocation boundary (in *bits*) for storing arguments in argument list.  */
                    142: #define PARM_BOUNDARY 32
                    143: 
                    144: /* Boundary (in *bits*) on which stack pointer should be aligned.  */
                    145: #define STACK_BOUNDARY 32
                    146: 
                    147: /* Allocation boundary (in *bits*) for the code of a function.  */
                    148: #define FUNCTION_BOUNDARY 32
                    149: 
                    150: /* Alignment of field after `int : 0' in a structure.  */
                    151: #define EMPTY_FIELD_BOUNDARY 32
                    152: 
                    153: /* Every structure's size must be a multiple of this.  */
                    154: #define STRUCTURE_SIZE_BOUNDARY 32
                    155: 
                    156: /* No data type wants to be aligned rounder than this.  */
                    157: #define BIGGEST_ALIGNMENT 32
                    158: 
                    159: /* Specified types of bitfields affect alignment of those fields
                    160:    and of the structure as a whole.  */
                    161: #define PCC_BITFIELD_TYPE_MATTERS 1
                    162: 
                    163: /* Make strings word-aligned so strcpy from constants will be faster. 
                    164:    Pyramid documentation says the best alignment is to align
                    165:    on the size of a cache line, which is 32 bytes.
                    166:    Newer pyrs have single insns that do strcmp() and strcpy(), so this
                    167:    may not actually win anything.   */
                    168: #define CONSTANT_ALIGNMENT(EXP, ALIGN)  \
                    169:   (TREE_CODE (EXP) == STRING_CST       \
                    170:    && (ALIGN) < BITS_PER_WORD ? BITS_PER_WORD : (ALIGN))
                    171: 
                    172: /* Make arrays of chars word-aligned for the same reasons.  */
                    173: #define DATA_ALIGNMENT(TYPE, ALIGN)            \
                    174:   (TREE_CODE (TYPE) == ARRAY_TYPE              \
                    175:    && TYPE_MODE (TREE_TYPE (TYPE)) == QImode   \
                    176:    && (ALIGN) < BITS_PER_WORD ? BITS_PER_WORD : (ALIGN))
                    177: 
                    178: /* Set this nonzero if move instructions will actually fail to work
                    179:    when given unaligned data.  */
                    180: #define STRICT_ALIGNMENT 1
                    181: 
                    182: /*** Standard register usage.  ***/
                    183: 
                    184: /* Number of actual hardware registers.
                    185:    The hardware registers are assigned numbers for the compiler
                    186:    from 0 to just below FIRST_PSEUDO_REGISTER.
                    187:    All registers that the compiler knows about must be given numbers,
                    188:    even those that are not normally considered general registers.  */
                    189: 
                    190: /* Nota Bene:
                    191:    Pyramids have 64 addressable 32-bit registers, arranged as four
                    192:    groups of sixteen registers each. Pyramid names the groups
                    193:    global, parameter, local, and temporary.
                    194: 
                    195:    The sixteen global registers are fairly conventional; the last
                    196:    four are overloaded with a PSW, frame pointer, stack pointer, and pc.
                    197:    The non-dedicated global registers used to be reserved for Pyramid
                    198:    operating systems, and still have cryptic and undocumented uses for
                    199:    certain library calls.  We do not use global registers gr0 through
                    200:    gr11.
                    201: 
                    202:    The parameter, local, and temporary registers provide register
                    203:    windowing.  Each procedure call has its own set of these 48
                    204:    registers, which constitute its call frame. (These frames are
                    205:    not allocated on the conventional stack, but contiguously
                    206:    on a separate stack called the control stack.)
                    207:    Register windowing is a facility whereby the temporary registers
                    208:    of frame n become the parameter registers of frame n+1, viz.:
                    209: 
                    210:                                       0         15 0         15 0         15
                    211:                                      +------------+------------+------------+
                    212: frame n+1                            |            |            |            |
                    213:                                      +------------+------------+------------+
                    214:                                         Parameter     Local       Temporary
                    215: 
                    216:                                           ^
                    217:                                           | These 16 regs are the same.
                    218:                                           v
                    219: 
                    220:             0         15 0         15 0         15
                    221:            +------------+------------+------------+
                    222: frame n    |            |            |            |
                    223:            +------------+------------+------------+
                    224:              Parameter     Local       Temporary
                    225: 
                    226:    New frames are automatically allocated on the control stack by the
                    227:    call instruction and de-allocated by the return insns "ret" and
                    228:    "retd".  The control-stack grows contiguously upward from a
                    229:    well-known address in memory; programs are free to allocate
                    230:    a variable sized, conventional frame on the data stack, which
                    231:    grows downwards in memory from just below the control stack.
                    232: 
                    233:    Temporary registers are used for parameter passing, and are not
                    234:    preserved across calls.  TR0 through TR11 correspond to
                    235:    gcc's ``input'' registers; PR0 through TR11 the ``output''
                    236:    registers. The call insn stores the PC and PSW in PR14 and PR15 of
                    237:    the frame it creates; the return insns restore these into the PC
                    238:    and PSW. The same is true for interrupts; TR14 and TR15 of the
                    239:    current frame are reserved and should never be used, since an
                    240:    interrupt may occur at any time and clobber them.
                    241: 
                    242:    An interesting quirk is the ability to take the address of a
                    243:    variable in a windowed register.  This done by adding the memory
                    244:    address of the base of the current window frame, to the offset
                    245:    within the frame of the desired register.  The resulting address
                    246:    can be treated just like any other pointer; if a quantity is stored
                    247:    into that address, the appropriate register also changes.
                    248:    GCC does not, and according to RMS will not, support this feature,
                    249:    even though some programs rely on this (mis)feature.
                    250:  */
                    251: 
                    252: #define PYR_GREG(n) (n)
                    253: #define PYR_PREG(n) (16+(n))
                    254: #define PYR_LREG(n) (32+(n))
                    255: #define PYR_TREG(n) (48+(n))
                    256: 
                    257: /* Define this macro if the target machine has "register windows".  This
                    258:    C expression returns the register number as seen by the called function
                    259:    corresponding to register number OUT as seen by the calling function.
                    260:    Return OUT if register number OUT is not an outbound register.  */
                    261: 
                    262: #define INCOMING_REGNO(OUT) \
                    263:  (((OUT) < 48 || (OUT) > 63) ? (OUT) : (OUT) - 32)
                    264: 
                    265: /* Define this macro if the target machine has "register windows".  This
                    266:    C expression returns the register number as seen by the calling function
                    267:    corresponding to register number IN as seen by the called function.
                    268:    Return IN if register number IN is not an inbound register.  */
                    269: 
                    270: #define OUTGOING_REGNO(IN) \
                    271:  (((IN) < 15 || (IN) > 31) ? (IN) : (IN) + 32)
                    272: 
                    273: #define FIRST_PSEUDO_REGISTER 64
                    274: 
                    275: /* 1 for registers that have pervasive standard uses
                    276:    and are not available for the register allocator.
                    277: 
                    278:    On the pyramid, these are LOGPSW, SP, and PC.  */
                    279: 
                    280: #define FIXED_REGISTERS \
                    281:   {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,     \
                    282:    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1,     \
                    283:    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,     \
                    284:    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1}
                    285: 
                    286: /* 1 for registers not available across function calls.
                    287:    These must include the FIXED_REGISTERS and also any
                    288:    registers that can be used without being saved.
                    289:    The latter must include the registers where values are returned
                    290:    and the register where structure-value addresses are passed.
                    291:    Aside from that, you can include as many other registers as you like.  */
                    292: #define CALL_USED_REGISTERS \
                    293:   {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,     \
                    294:    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1,     \
                    295:    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,     \
                    296:    1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1}
                    297: 
                    298: /* #define DEFAULT_CALLER_SAVES */
                    299: 
                    300: /* Return number of consecutive hard regs needed starting at reg REGNO
                    301:    to hold something of mode MODE.
                    302:    This is ordinarily the length in words of a value of mode MODE
                    303:    but can be less for certain modes in special long registers.
                    304:    On the pyramid, all registers are one word long.  */
                    305: #define HARD_REGNO_NREGS(REGNO, MODE)   \
                    306:  ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD)
                    307: 
                    308: /* Value is 1 if hard register REGNO can hold a value of machine-mode MODE.
                    309:    On the pyramid, all registers can hold all modes.  */
                    310: 
                    311: /* -->FIXME: this is not the case for 64-bit quantities in tr11/12 through
                    312:    --> TR14/15.  This should be fixed,  but to do it correctly, we also
                    313:    --> need to fix MODES_TIEABLE_P. Yuk.  We ignore this, since GCC should
                    314:    --> do the "right" thing due to FIXED_REGISTERS. */
                    315: #define HARD_REGNO_MODE_OK(REGNO, MODE) 1
                    316: 
                    317: /* Value is 1 if it is a good idea to tie two pseudo registers
                    318:    when one has mode MODE1 and one has mode MODE2.
                    319:    If HARD_REGNO_MODE_OK could produce different values for MODE1 and MODE2,
                    320:    for any hard reg, then this must be 0 for correct output.  */
                    321: #define MODES_TIEABLE_P(MODE1, MODE2) 1
                    322: 
                    323: /* Specify the registers used for certain standard purposes.
                    324:    The values of these macros are register numbers.  */
                    325: 
                    326: /* Pyramid pc is overloaded on global register 15.  */
                    327: #define PC_REGNUM PYR_GREG(15)
                    328: 
                    329: /* Register to use for pushing function arguments.
                    330:    --> on Pyramids, the data stack pointer. */
                    331: #define STACK_POINTER_REGNUM PYR_GREG(14)
                    332: 
                    333: /* Base register for access to local variables of the function.
                    334:    Pyramid uses CFP (GR13) as both frame pointer and argument pointer. */
                    335: #define FRAME_POINTER_REGNUM 13 /* pyr cpp fails on PYR_GREG(13) */
                    336: 
                    337: /* Value should be nonzero if functions must have frame pointers.
                    338:    Zero means the frame pointer need not be set up (and parms
                    339:    may be accessed via the stack pointer) in functions that seem suitable.
                    340:    This is computed in `reload', in reload1.c.
                    341: 
                    342:    Setting this to 1 can't break anything.  Since the Pyramid has
                    343:    register windows, I don't know if defining this to be zero can
                    344:    win anything.  It could changed later, if it wins. */
                    345: #define FRAME_POINTER_REQUIRED 1
                    346: 
                    347: /* Base register for access to arguments of the function.  */
                    348: #define ARG_POINTER_REGNUM 13 /* PYR_GREG(13) */
                    349: 
                    350: /* Register in which static-chain is passed to a function.  */
                    351: /* If needed, Pyramid says to use temporary register 12. */
                    352: #define STATIC_CHAIN_REGNUM PYR_TREG(12)
                    353: 
                    354: /* If register windows are used, STATIC_CHAIN_INCOMING_REGNUM
                    355:    is the register number as seen by the called function, while
                    356:    STATIC_CHAIN_REGNUM is the register number as seen by the calling
                    357:    function. */
                    358: #define STATIC_CHAIN_INCOMING_REGNUM PYR_PREG(12)
                    359: 
                    360: /* Register in which address to store a structure value
                    361:    is passed to a function.
                    362:    On a Pyramid, this is temporary register 0 (TR0).   */
                    363: 
                    364: #define STRUCT_VALUE_REGNUM PYR_TREG(0)
                    365: #define STRUCT_VALUE_INCOMING_REGNUM PYR_PREG(0)
                    366: 
                    367: /* Define the classes of registers for register constraints in the
                    368:    machine description.  Also define ranges of constants.
                    369: 
                    370:    One of the classes must always be named ALL_REGS and include all hard regs.
                    371:    If there is more than one class, another class must be named NO_REGS
                    372:    and contain no registers.
                    373: 
                    374:    The name GENERAL_REGS must be the name of a class (or an alias for
                    375:    another name such as ALL_REGS).  This is the class of registers
                    376:    that is allowed by "g" or "r" in a register constraint.
                    377:    Also, registers outside this class are allocated only when
                    378:    instructions express preferences for them.
                    379: 
                    380:    The classes must be numbered in nondecreasing order; that is,
                    381:    a larger-numbered class must never be contained completely
                    382:    in a smaller-numbered class.
                    383: 
                    384:    For any two classes, it is very desirable that there be another
                    385:    class that represents their union.  */
                    386: 
                    387: /* The pyramid has only one kind of registers, so NO_REGS and ALL_REGS
                    388:    are the only classes.  */
                    389: 
                    390: enum reg_class { NO_REGS, ALL_REGS, LIM_REG_CLASSES };
                    391: 
                    392: #define N_REG_CLASSES (int) LIM_REG_CLASSES
                    393: 
                    394: /* Since GENERAL_REGS is the same class as ALL_REGS,
                    395:    don't give it a different class number; just make it an alias.  */
                    396: 
                    397: #define GENERAL_REGS ALL_REGS
                    398: 
                    399: /* Give names of register classes as strings for dump file.   */
                    400: 
                    401: #define REG_CLASS_NAMES \
                    402:  {"NO_REGS", "ALL_REGS" }
                    403: 
                    404: /* Define which registers fit in which classes.
                    405:    This is an initializer for a vector of HARD_REG_SET
                    406:    of length N_REG_CLASSES.  */
                    407: 
                    408: #define REG_CLASS_CONTENTS {{0,0}, {0xffffffff,0xffffffff}}
                    409: 
                    410: /* The same information, inverted:
                    411:    Return the class number of the smallest class containing
                    412:    reg number REGNO.  This could be a conditional expression
                    413:    or could index an array.  */
                    414: 
                    415: #define REGNO_REG_CLASS(REGNO) ALL_REGS
                    416: 
                    417: /* The class value for index registers, and the one for base regs.  */
                    418: 
                    419: #define BASE_REG_CLASS ALL_REGS
                    420: #define INDEX_REG_CLASS ALL_REGS
                    421: 
                    422: /* Get reg_class from a letter such as appears in the machine description.  */
                    423: 
                    424: #define REG_CLASS_FROM_LETTER(C) NO_REGS
                    425: 
                    426: /* Given an rtx X being reloaded into a reg required to be
                    427:    in class CLASS, return the class of reg to actually use.
                    428:    In general this is just CLASS; but on some machines
                    429:    in some cases it is preferable to use a more restrictive class.  */
                    430: 
                    431: #define PREFERRED_RELOAD_CLASS(X,CLASS)  (CLASS)
                    432: 
                    433: /* Return the maximum number of consecutive registers
                    434:    needed to represent mode MODE in a register of class CLASS.  */
                    435: /* On the pyramid, this is always the size of MODE in words,
                    436:    since all registers are the same size.  */
                    437: #define CLASS_MAX_NREGS(CLASS, MODE)   \
                    438:  ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD)
                    439: 
                    440: /* The letters I, J, K, L and M in a register constraint string
                    441:    can be used to stand for particular ranges of immediate operands.
                    442:    This macro defines what the ranges are.
                    443:    C is the letter, and VALUE is a constant value.
                    444:    Return 1 if VALUE is in the range specified by C.
                    445: 
                    446:    --> For the Pyramid, 'I' can be used for the 6-bit signed integers
                    447:    --> (-32 to 31) allowed as immediate short operands in many
                    448:    --> instructions. 'J' cane be used for any value that doesn't fit
                    449:    --> in 6 bits.  */
                    450: 
                    451: #define CONST_OK_FOR_LETTER_P(VALUE, C)  \
                    452:   ((C) == 'I' ? (VALUE) >= -32 && (VALUE) < 32 : \
                    453:    (C) == 'J' ? (VALUE) < -32 || (VALUE) >= 32 : \
                    454:    (C) == 'K' ? (VALUE) == 0xff || (VALUE) == 0xffff : 0)
                    455: 
                    456: /* Similar, but for floating constants, and defining letters G and H.
                    457:    Here VALUE is the CONST_DOUBLE rtx itself.  */
                    458: 
                    459: #define CONST_DOUBLE_OK_FOR_LETTER_P(VALUE, C) 0
                    460: 
                    461: 
                    462: /*** Stack layout; function entry, exit and calling.  ***/
                    463: 
                    464: /* Define this if pushing a word on the stack
                    465:    makes the stack pointer a smaller address.  */
                    466: #define STACK_GROWS_DOWNWARD
                    467: 
                    468: /* Define this if the nominal address of the stack frame
                    469:    is at the high-address end of the local variables;
                    470:    that is, each additional local variable allocated
                    471:    goes at a more negative offset in the frame.  */
                    472: #define FRAME_GROWS_DOWNWARD
                    473: 
                    474: /* Offset within stack frame to start allocating local variables at.
                    475:    If FRAME_GROWS_DOWNWARD, this is the offset to the END of the
                    476:    first local allocated.  Otherwise, it is the offset to the BEGINNING
                    477:    of the first local allocated.  */
                    478: /* FIXME: this used to work when defined as 0.  But that makes gnu
                    479:    stdargs clobber the first arg.  What gives?? */
                    480: #define STARTING_FRAME_OFFSET 0
                    481: 
                    482: /* Offset of first parameter from the argument pointer register value.  */
                    483: #define FIRST_PARM_OFFSET(FNDECL) 0
                    484: 
                    485: /* Value is the number of bytes of arguments automatically
                    486:    popped when returning from a subroutine call.
                    487:    FUNTYPE is the data type of the function (as a tree),
                    488:    or for a library call it is an identifier node for the subroutine name.
                    489:    SIZE is the number of bytes of arguments passed on the stack.
                    490: 
                    491:    The Pyramid OSx Porting Guide says we are never to do this;
                    492:    using RETD in this way violates the Pyramid calling convention.
                    493:    We may nevertheless provide this as an option.   */
                    494: 
                    495: #define RETURN_POPS_ARGS(FUNTYPE,SIZE)   \
                    496:   ((TARGET_RETD && TREE_CODE (FUNTYPE) != IDENTIFIER_NODE      \
                    497:     && (TYPE_ARG_TYPES (FUNTYPE) == 0                          \
                    498:        || (TREE_VALUE (tree_last (TYPE_ARG_TYPES (FUNTYPE)))   \
                    499:            == void_type_node)))                                \
                    500:    ? (SIZE) : 0)
                    501: 
                    502: /* Define how to find the value returned by a function.
                    503:    VALTYPE is the data type of the value (as a tree).
                    504:    If the precise function being called is known, FUNC is its FUNCTION_DECL;
                    505:    otherwise, FUNC is 0.  */
                    506: 
                    507: /* --> Pyramid has register windows.
                    508:    --> The caller sees the return value is in TR0(/TR1) regardless of
                    509:    --> its type.   */
                    510: 
                    511: #define FUNCTION_VALUE(VALTYPE, FUNC)  \
                    512:   gen_rtx (REG, TYPE_MODE (VALTYPE), PYR_TREG(0))
                    513: 
                    514: /* --> but the callee has to leave it in PR0(/PR1) */
                    515: 
                    516: #define FUNCTION_OUTGOING_VALUE(VALTYPE, FUNC) \
                    517:   gen_rtx (REG, TYPE_MODE (VALTYPE), PYR_PREG(0))
                    518: 
                    519: /* Define how to find the value returned by a library function
                    520:    assuming the value has mode MODE.  */
                    521: 
                    522: /* --> On Pyramid the return value is in TR0/TR1 regardless.  */
                    523: 
                    524: #define LIBCALL_VALUE(MODE)  gen_rtx (REG, MODE, PYR_TREG(0))
                    525: 
                    526: /* Define this if PCC uses the nonreentrant convention for returning
                    527:    structure and union values.  */
                    528: 
                    529: #define PCC_STATIC_STRUCT_RETURN
                    530: 
                    531: /* 1 if N is a possible register number for a function value
                    532:    as seen by the caller.
                    533: 
                    534:   On the Pyramid, TR0 is the only register thus used.   */
                    535: 
                    536: #define FUNCTION_VALUE_REGNO_P(N) ((N) == PYR_TREG(0))
                    537: 
                    538: /* 1 if N is a possible register number for function argument passing.
                    539:    On the Pyramid, the first twelve temporary registers are available.  */
                    540: 
                    541: /* FIXME FIXME FIXME
                    542:    it's not clear whether this macro should be defined from the point
                    543:    of view of the caller or the callee.  Since it's never actually used
                    544:    in GNU CC, the point is somewhat moot :-).
                    545: 
                    546:    This definition is consistent with register usage in the md's for
                    547:    other register-window architectures (sparc and spur).
                    548:  */
                    549: #define FUNCTION_ARG_REGNO_P(N) ((PYR_TREG(0) <= (N)) && ((N) <= PYR_TREG(11)))
                    550: 
                    551: /*** Parameter passing: FUNCTION_ARG and FUNCTION_INCOMING_ARG ***/
                    552: 
                    553: /* Define a data type for recording info about an argument list
                    554:    during the scan of that argument list.  This data type should
                    555:    hold all necessary information about the function itself
                    556:    and about the args processed so far, enough to enable macros
                    557:    such as FUNCTION_ARG to determine where the next arg should go.
                    558: 
                    559:    On Pyramids, each parameter is passed either completely on the stack
                    560:    or completely in registers.  No parameter larger than a double may
                    561:    be passed in a register.  Also, no struct or union may be passed in
                    562:    a register, even if it would fit.
                    563: 
                    564:     So parameters are not necessarily passed "consecutively".
                    565:     Thus we need a vector data type: one element to record how many
                    566:     parameters have been passed in registers and on the stack,
                    567:     respectively.
                    568: 
                    569:     ((These constraints seem like a gross waste of registers. But if we
                    570:     ignore the constraint about structs & unions, we won`t be able to
                    571:     freely mix gcc-compiled code and pyr cc-compiled code.  It looks
                    572:     like better argument passing conventions, and a machine-dependent
                    573:     flag to enable them, might be a win.))   */
                    574: 
                    575: 
                    576: #define CUMULATIVE_ARGS int
                    577: 
                    578: /* Define the number of registers that can hold parameters.
                    579:    This macro is used only in other macro definitions below.   */
                    580: #define NPARM_REGS 12
                    581: 
                    582: /* Decide whether or not a parameter can be put in a register.
                    583:    (We may still have problems with libcalls. GCC doesn't seem
                    584:    to know about anything more than the machine mode.  I trust
                    585:    structures are never passed to a libcall...
                    586: 
                    587:    If compiling with -mgnu-stdarg, this definition should make
                    588:    functions using the gcc-supplied stdarg, and calls to such
                    589:    functions (declared with an arglist ending in"..."),  work.
                    590:    But such fns won't be able to call pyr cc-compiled
                    591:    varargs fns (eg, printf(), _doprnt.)
                    592: 
                    593:    If compiling with -mnognu-stdarg, this definition should make
                    594:    calls to pyr cc-compiled functions work.  Functions using
                    595:    the gcc-supplied stdarg will be utterly broken.
                    596:    There will be no better solution until RMS can be persuaded that
                    597:    one is needed.
                    598: 
                    599:    This macro is used only in other macro definitions below.
                    600:    (well, it may be used in pyr.c, because the damn pyramid cc
                    601:    can't handle the macro definition of PARAM_SAFE_FOR_REG_P !   */
                    602: 
                    603: 
                    604: #define INNER_PARAM_SAFE_HELPER(TYPE) \
                    605:  ((TARGET_GNU_STDARG ? (! TREE_ADDRESSABLE ((tree)TYPE)): 1)   \
                    606:    && (TREE_CODE ((tree)TYPE) != RECORD_TYPE)                  \
                    607:    && (TREE_CODE ((tree)TYPE) != UNION_TYPE))
                    608: 
                    609: #ifdef __GNUC__
                    610: #define PARAM_SAFE_HELPER(TYPE) \
                    611:   INNER_PARAM_SAFE_HELPER((TYPE))
                    612: #else
                    613: extern int inner_param_safe_helper();
                    614: #define PARAM_SAFE_HELPER(TYPE) \
                    615:   inner_param_safe_helper((tree)(TYPE))
                    616: #endif
                    617: 
                    618: /* Be careful with the expression (long) (TYPE) == 0.
                    619:    Writing it in more obvious/correct forms makes the Pyr cc
                    620:    dump core!   */
                    621: #define PARAM_SAFE_FOR_REG_P(MODE, TYPE, NAMED) \
                    622:   (((MODE) != BLKmode)                         \
                    623:    && ((TARGET_GNU_STDARG) ? (NAMED) : 1)      \
                    624:    && ((((long)(TYPE))==0) || PARAM_SAFE_HELPER((TYPE))))
                    625: 
                    626: /* Initialize a variable CUM of type CUMULATIVE_ARGS
                    627:    for a call to a function whose data type is FNTYPE.
                    628:    For a library call, FNTYPE is 0.   */
                    629: 
                    630: #define INIT_CUMULATIVE_ARGS(CUM,FNTYPE,LIBNAME)       \
                    631:   ((CUM) = (FNTYPE && !flag_pcc_struct_return          \
                    632:            && aggregate_value_p (TREE_TYPE (FNTYPE))))
                    633: 
                    634: /* Determine where to put an argument to a function.
                    635:    Value is zero to push the argument on the stack,
                    636:    or a hard register in which to store the argument.
                    637: 
                    638:    MODE is the argument's machine mode.
                    639:    TYPE is the data type of the argument (as a tree).
                    640:     This is null for libcalls where that information may
                    641:     not be available.
                    642:    CUM is a variable of type CUMULATIVE_ARGS which gives info about
                    643:     the preceding args and about the function being called.
                    644:    NAMED is nonzero if this argument is a named parameter
                    645:     (otherwise it is an extra parameter matching an ellipsis). */
                    646: 
                    647: #define FUNCTION_ARG_HELPER(CUM, MODE, TYPE, NAMED) \
                    648: (PARAM_SAFE_FOR_REG_P(MODE,TYPE,NAMED)                         \
                    649:  ? (NPARM_REGS >= ((CUM)                                       \
                    650:                   + ((MODE) == BLKmode                         \
                    651:                      ? (int_size_in_bytes (TYPE) + 3) / 4      \
                    652:                      : (GET_MODE_SIZE (MODE) + 3) / 4))        \
                    653:     ? gen_rtx (REG, (MODE), PYR_TREG(CUM))                     \
                    654:     : 0)                                                       \
                    655:  : 0)
                    656: #ifdef __GNUC__
                    657: #define FUNCTION_ARG(CUM, MODE, TYPE, NAMED) \
                    658:        FUNCTION_ARG_HELPER(CUM, MODE, TYPE, NAMED)
                    659: #else
                    660: /*****************  Avoid bug in Pyramid OSx compiler... ******************/
                    661: #define FUNCTION_ARG  (rtx) pyr_function_arg
                    662: extern void* pyr_function_arg ();
                    663: #endif
                    664: 
                    665: /* Define where a function finds its arguments.
                    666:    This is different from FUNCTION_ARG because of register windows.  */
                    667: 
                    668: #define FUNCTION_INCOMING_ARG(CUM, MODE, TYPE, NAMED) \
                    669: (PARAM_SAFE_FOR_REG_P(MODE,TYPE,NAMED)                 \
                    670:  ? (NPARM_REGS >= ((CUM)                               \
                    671:           + ((MODE) == BLKmode                         \
                    672:              ? (int_size_in_bytes (TYPE) + 3) / 4      \
                    673:              : (GET_MODE_SIZE (MODE) + 3) / 4))        \
                    674:     ? gen_rtx (REG, (MODE), PYR_PREG(CUM))             \
                    675:     : 0)                                               \
                    676:  : 0)
                    677: 
                    678: /* Update the data in CUM to advance over an argument
                    679:    of mode MODE and data type TYPE.
                    680:    (TYPE is null for libcalls where that information may not be available.)  */
                    681: 
                    682: #define FUNCTION_ARG_ADVANCE(CUM,MODE,TYPE,NAMED)  \
                    683: ((CUM) +=  (PARAM_SAFE_FOR_REG_P(MODE,TYPE,NAMED)      \
                    684:             ? ((MODE) != BLKmode                       \
                    685:                ? (GET_MODE_SIZE (MODE) + 3) / 4        \
                    686:                : (int_size_in_bytes (TYPE) + 3) / 4)   \
                    687:             : 0))
                    688: 
                    689: /* This macro generates the assembly code for function entry.
                    690:    FILE is a stdio stream to output the code to.
                    691:    SIZE is an int: how many units of temporary storage to allocate.
                    692:    Refer to the array `regs_ever_live' to determine which registers
                    693:    to save; `regs_ever_live[I]' is nonzero if register number I
                    694:    is ever used in the function.  This macro is responsible for
                    695:    knowing which registers should not be saved even if used.  */
                    696: 
                    697: #if FRAME_POINTER_REQUIRED
                    698: 
                    699: /* We always have frame pointers */
                    700: 
                    701: /* Don't set up a frame pointer if it's not referenced.  */
                    702: 
                    703: #define FUNCTION_PROLOGUE(FILE, SIZE) \
                    704: {                                                                      \
                    705:   int _size = (SIZE) + current_function_pretend_args_size;             \
                    706:   if (_size + current_function_args_size != 0                          \
                    707:       || current_function_calls_alloca)                                        \
                    708:     {                                                                  \
                    709:       fprintf (FILE, "\tadsf $%d\n", _size);                           \
                    710:       if (current_function_pretend_args_size > 0)                      \
                    711:       fprintf (FILE, "\tsubw $%d,cfp\n",                               \
                    712:          current_function_pretend_args_size);                          \
                    713:     }                                                                  \
                    714: }
                    715: 
                    716: #else /* !FRAME_POINTER_REQUIRED */
                    717: 
                    718: /* Don't set up a frame pointer if `frame_pointer_needed' tells us
                    719:    there is no need.  Also, don't set up a frame pointer if it's not
                    720:    referenced.  */
                    721: 
                    722: /* The definition used to be broken.  Write a new one.  */
                    723: 
                    724: #endif /* !FRAME_POINTER_REQUIRED */
                    725: 
                    726: /* the trampoline stuff was taken from convex.h - S.P. */
                    727: 
                    728: /* A C statement to output, on the stream FILE, assembler code for a
                    729:    block of data that contains the constant parts of a trampoline.  This
                    730:    code should not include a label - the label is taken care of
                    731:    automatically.
                    732:        We use TR12/PR12 for the static chain.
                    733:        movew $<STATIC>,pr12    # I2R
                    734:        jump $<func>            # S2R
                    735:  */
                    736: #define TRAMPOLINE_TEMPLATE(FILE) \
                    737: { ASM_OUTPUT_INT (FILE, gen_rtx (CONST_INT, VOIDmode, 0x2100001C));    \
                    738:   ASM_OUTPUT_INT (FILE, gen_rtx (CONST_INT, VOIDmode, 0x00000000));    \
                    739:   ASM_OUTPUT_INT (FILE, gen_rtx (CONST_INT, VOIDmode, 0x40000000));    \
                    740:   ASM_OUTPUT_INT (FILE, gen_rtx (CONST_INT, VOIDmode, 0x00000000)); }
                    741: 
                    742: #define TRAMPOLINE_SIZE                16
                    743: #define TRAMPOLINE_ALIGNMENT   32
                    744: 
                    745: /* Emit RTL insns to initialize the variable parts of a trampoline.
                    746:    FNADDR is an RTX for the address of the function's pure code.
                    747:    CXT is an RTX for the static chain value for the function.  */
                    748: 
                    749: #define INITIALIZE_TRAMPOLINE(TRAMP, FNADDR, CXT) \
                    750: { emit_move_insn (gen_rtx (MEM, Pmode, plus_constant (TRAMP, 4)), CXT);        \
                    751:   emit_move_insn (gen_rtx (MEM, Pmode, plus_constant (TRAMP, 12)), FNADDR); \
                    752:   emit_call_insn (gen_call (gen_rtx (MEM, QImode,                      \
                    753:                                     gen_rtx (SYMBOL_REF, Pmode,        \
                    754:                                              "__enable_execute_stack")), \
                    755:                            const0_rtx));                               \
                    756: }
                    757: 
                    758: /* Output assembler code to FILE to increment profiler label # LABELNO
                    759:    for profiling a function entry.  */
                    760: #define FUNCTION_PROFILER(FILE, LABELNO)  \
                    761:    fprintf (FILE, "\tmova LP%d,tr0\n\tcall mcount\n", (LABELNO));
                    762: 
                    763: /* Output assembler code to FILE to initialize this source file's
                    764:    basic block profiling info, if that has not already been done.
                    765:    Don't know if this works on Pyrs. */
                    766: 
                    767: #if 0 /* don't do basic_block profiling yet */
                    768: #define FUNCTION_BLOCK_PROFILER(FILE, LABELNO)  \
                    769:   fprintf (FILE, \
                    770:            "\tmtstw LPBX0,tr0\n\tbne LPI%d\n\tmova LP%d,TR0\n\tcall __bb_init_func\nLPI%d:\n", \
                    771:            LABELNO, LABELNO);
                    772: 
                    773: /* Output assembler code to increment the count associated with
                    774:    the basic block number BLOCKNO.  Not sure how to do this on pyrs. */
                    775: #define BLOCK_PROFILER(FILE, BLOCKNO)  \
                    776:     fprintf (FILE, "\taddw", 4 * BLOCKNO)
                    777: #endif /* don't do basic_block profiling yet */
                    778: 
                    779: /* When returning from a function, the stack pointer does not matter
                    780:    (as long as there is a frame pointer).  */
                    781: 
                    782: /* This should return non-zero when we really set up a frame pointer.
                    783:    Otherwise, GCC is directed to preserve sp by returning zero.  */
                    784: extern int current_function_pretend_args_size;
                    785: extern int current_function_args_size;
                    786: extern int current_function_calls_alloca;
                    787: #define EXIT_IGNORE_STACK \
                    788:   (get_frame_size () + current_function_pretend_args_size              \
                    789:    + current_function_args_size != 0                                   \
                    790:    || current_function_calls_alloca)                                   \
                    791: 
                    792: /* Store in the variable DEPTH the initial difference between the
                    793:    frame pointer reg contents and the stack pointer reg contents,
                    794:    as of the start of the function body.  This depends on the layout
                    795:    of the fixed parts of the stack frame and on how registers are saved.
                    796: 
                    797:    On the Pyramid, FRAME_POINTER_REQUIRED is always 1, so the definition
                    798:    of this macro doesn't matter.  But it must be defined.  */
                    799: 
                    800: #define INITIAL_FRAME_POINTER_OFFSET(DEPTH) (DEPTH) = 0;
                    801: 
                    802: /*** Addressing modes, and classification of registers for them.  ***/
                    803: 
                    804: /* #define HAVE_POST_INCREMENT */      /* pyramid has none of these */
                    805: /* #define HAVE_POST_DECREMENT */
                    806: 
                    807: /* #define HAVE_PRE_DECREMENT */
                    808: /* #define HAVE_PRE_INCREMENT */
                    809: 
                    810: /* Macros to check register numbers against specific register classes.  */
                    811: 
                    812: /* These assume that REGNO is a hard or pseudo reg number.
                    813:    They give nonzero only if REGNO is a hard reg of the suitable class
                    814:    or a pseudo reg currently allocated to a suitable hard reg.
                    815:    Since they use reg_renumber, they are safe only once reg_renumber
                    816:    has been allocated, which happens in local-alloc.c.  */
                    817: 
                    818: /* All registers except gr0 OK as index or base registers.  */
                    819: 
                    820: #define REGNO_OK_FOR_BASE_P(regno) \
                    821: ((regno) < FIRST_PSEUDO_REGISTER || reg_renumber[regno] >= 0)
                    822: 
                    823: #define REGNO_OK_FOR_INDEX_P(regno)  \
                    824: ((unsigned) (regno) - 1 < FIRST_PSEUDO_REGISTER - 1 \
                    825:  || reg_renumber[regno] > 0)
                    826: 
                    827: /* Maximum number of registers that can appear in a valid memory address.  */
                    828: 
                    829: #define MAX_REGS_PER_ADDRESS 2     /* check MAX_REGS_PER_ADDRESS */
                    830: 
                    831: /* 1 if X is an rtx for a constant that is a valid address.  */
                    832: 
                    833: #define CONSTANT_ADDRESS_P(X)   \
                    834:   (GET_CODE (X) == LABEL_REF || GET_CODE (X) == SYMBOL_REF             \
                    835:    || GET_CODE (X) == CONST_INT || GET_CODE (X) == CONST               \
                    836:    || GET_CODE (X) == HIGH)
                    837: 
                    838: /* Nonzero if the constant value X is a legitimate general operand.
                    839:    It is given that X satisfies CONSTANT_P or is a CONST_DOUBLE.  */
                    840: 
                    841: #define LEGITIMATE_CONSTANT_P(X) 1
                    842: 
                    843: /* The macros REG_OK_FOR..._P assume that the arg is a REG rtx
                    844:    and check its validity for a certain class.
                    845:    We have two alternate definitions for each of them.
                    846:    The usual definition accepts all pseudo regs; the other rejects
                    847:    them unless they have been allocated suitable hard regs.
                    848:    The symbol REG_OK_STRICT causes the latter definition to be used.
                    849: 
                    850:    Most source files want to accept pseudo regs in the hope that
                    851:    they will get allocated to the class that the insn wants them to be in.
                    852:    Source files for reload pass need to be strict.
                    853:    After reload, it makes no difference, since pseudo regs have
                    854:    been eliminated by then.  */
                    855: 
                    856: #ifndef REG_OK_STRICT
                    857: 
                    858: /* Nonzero if X is a hard reg that can be used as an index
                    859:    or if it is a pseudo reg.  */
                    860: #define REG_OK_FOR_INDEX_P(X) (REGNO (X) > 0)
                    861: /* Nonzero if X is a hard reg that can be used as a base reg
                    862:    or if it is a pseudo reg.  */
                    863: #define REG_OK_FOR_BASE_P(X) 1
                    864: 
                    865: #else
                    866: 
                    867: /* Nonzero if X is a hard reg that can be used as an index.  */
                    868: #define REG_OK_FOR_INDEX_P(X) REGNO_OK_FOR_INDEX_P (REGNO (X))
                    869: /* Nonzero if X is a hard reg that can be used as a base reg.  */
                    870: #define REG_OK_FOR_BASE_P(X) REGNO_OK_FOR_BASE_P (REGNO (X))
                    871: 
                    872: #endif
                    873: 
                    874: /* GO_IF_LEGITIMATE_ADDRESS recognizes an RTL expression
                    875:    that is a valid memory address for an instruction.
                    876:    The MODE argument is the machine mode for the MEM expression
                    877:    that wants to use this address.
                    878: 
                    879:    The other macros defined here are used only in GO_IF_LEGITIMATE_ADDRESS,
                    880:    except for CONSTANT_ADDRESS_P which is actually machine-independent.  */
                    881: 
                    882: 
                    883: /* Go to ADDR if X is indexable -- i.e., neither indexed nor offset.  */
                    884: #define GO_IF_INDEXABLE_ADDRESS(X, ADDR)  \
                    885: { register rtx xfoob = (X);                                            \
                    886:   if ((CONSTANT_ADDRESS_P (xfoob))                                     \
                    887:       || (GET_CODE (xfoob) == REG && (REG_OK_FOR_BASE_P (xfoob))))     \
                    888:          goto ADDR;                                                    \
                    889:  }
                    890: 
                    891: 
                    892: /* Go to label ADDR if X is a valid address that doesn't use indexing.
                    893:    This is so if X is either a simple address, or the contents of a register
                    894:    plus an offset.
                    895:    This macro also gets used in output-pyramid.h in the function that
                    896:    recognizes non-indexed operands.  */
                    897: 
                    898: #define GO_IF_NONINDEXED_ADDRESS(X, ADDR)  \
                    899: {                                                                      \
                    900:   if (GET_CODE (X) == REG)                                             \
                    901:       goto ADDR;                                                       \
                    902:   GO_IF_INDEXABLE_ADDRESS (X, ADDR);                                   \
                    903:   if (GET_CODE (X) == PLUS)                                            \
                    904:     { /* Handle offset(reg) represented with offset on left */         \
                    905:       if (CONSTANT_ADDRESS_P (XEXP (X, 0)))                            \
                    906:        { if (GET_CODE (XEXP (X, 1)) == REG                             \
                    907:              && REG_OK_FOR_BASE_P (XEXP (X, 1)))                       \
                    908:            goto ADDR;                                                  \
                    909:         }                                                              \
                    910:       /* Handle offset(reg) represented with offset on right */                \
                    911:       if (CONSTANT_ADDRESS_P (XEXP (X, 1)))                            \
                    912:        { if (GET_CODE (XEXP (X, 0)) == REG                             \
                    913:              && REG_OK_FOR_BASE_P (XEXP (X, 0)))                       \
                    914:            goto ADDR;                                                  \
                    915:         }                                                              \
                    916:      }                                                                 \
                    917: }
                    918: 
                    919: /* 1 if PROD is either a reg or a reg times a valid offset multiplier
                    920:    (ie, 2, 4, or 8).
                    921:    This macro's expansion uses the temporary variables xfoo0 and xfoo1
                    922:    that must be declared in the surrounding context.  */
                    923: #define INDEX_TERM_P(PROD, MODE)   \
                    924: ((GET_CODE (PROD) == REG && REG_OK_FOR_BASE_P (PROD))                  \
                    925:   || (GET_CODE (PROD) == MULT                                          \
                    926:       &&                                                               \
                    927:       (xfoo0 = XEXP (PROD, 0), xfoo1 = XEXP (PROD, 1),                 \
                    928:        ((GET_CODE (xfoo0) == CONST_INT                                 \
                    929:          && (INTVAL (xfoo0) == 1                                       \
                    930:             || INTVAL (xfoo0) == 2                                     \
                    931:             || INTVAL (xfoo0) == 4                                     \
                    932:             || INTVAL (xfoo0) == 8)                                    \
                    933:          && GET_CODE (xfoo1) == REG                                    \
                    934:          && REG_OK_FOR_INDEX_P (xfoo1))                                        \
                    935:         ||                                                             \
                    936:         (GET_CODE (xfoo1) == CONST_INT                                 \
                    937:         && (INTVAL (xfoo1) == 1                                        \
                    938:             || INTVAL (xfoo1) == 2                                     \
                    939:             || INTVAL (xfoo1) == 4                                     \
                    940:             || INTVAL (xfoo1) == 8)                                    \
                    941:         && GET_CODE (xfoo0) == REG                                     \
                    942:         && REG_OK_FOR_INDEX_P (xfoo0))))))
                    943: 
                    944: 
                    945: #define GO_IF_LEGITIMATE_ADDRESS(MODE, X, ADDR)  \
                    946: { register rtx xone, xtwo, xfoo0, xfoo1;                               \
                    947:   GO_IF_NONINDEXED_ADDRESS (X, ADDR);                                  \
                    948:   if (GET_CODE (X) == PLUS)                                            \
                    949:     {                                                                  \
                    950:       /* Handle <address>[index] represented with index-sum outermost */\
                    951:       xone = XEXP (X, 0);                                              \
                    952:       xtwo = XEXP (X, 1);                                              \
                    953:       if (INDEX_TERM_P (xone, MODE))                                   \
                    954:        { GO_IF_INDEXABLE_ADDRESS (xtwo, ADDR); }                       \
                    955:       /* Handle <address>[index] represented with index-sum innermost */\
                    956:       if (INDEX_TERM_P (xtwo, MODE))                                   \
                    957:        { GO_IF_INDEXABLE_ADDRESS (xone, ADDR); }                       \
                    958:     }                                                                  \
                    959: }
                    960: 
                    961: /* Try machine-dependent ways of modifying an illegitimate address
                    962:    to be legitimate.  If we find one, return the new, valid address.
                    963:    This macro is used in only one place: `memory_address' in explow.c.
                    964: 
                    965:    OLDX is the address as it was before break_out_memory_refs was called.
                    966:    In some cases it is useful to look at this to decide what needs to be done.
                    967: 
                    968:    MODE and WIN are passed so that this macro can use
                    969:    GO_IF_LEGITIMATE_ADDRESS.
                    970: 
                    971:    It is always safe for this macro to do nothing.  It exists to recognize
                    972:    opportunities to optimize the output.
                    973: 
                    974:    --> FIXME: We haven't yet figured out what optimizations are useful
                    975:    --> on Pyramids.   */
                    976: 
                    977: #define LEGITIMIZE_ADDRESS(X,OLDX,MODE,WIN)  {}
                    978: 
                    979: /* Go to LABEL if ADDR (a legitimate address expression)
                    980:    has an effect that depends on the machine mode it is used for.
                    981:    There don't seem to be any such modes on pyramids. */
                    982: #define GO_IF_MODE_DEPENDENT_ADDRESS(ADDR,LABEL)
                    983: 
                    984: /*** Miscellaneous Parameters ***/
                    985: 
                    986: /* Specify the machine mode that this machine uses
                    987:    for the index in the tablejump instruction.  */
                    988: #define CASE_VECTOR_MODE SImode
                    989: 
                    990: /* Define this if the tablejump instruction expects the table
                    991:    to contain offsets from the address of the table.
                    992:    Do not define this if the table should contain absolute addresses.  */
                    993: /*#define CASE_VECTOR_PC_RELATIVE*/
                    994: 
                    995: /* Specify the tree operation to be used to convert reals to integers.  */
                    996: #define IMPLICIT_FIX_EXPR FIX_ROUND_EXPR
                    997: 
                    998: /* This is the kind of divide that is easiest to do in the general case.
                    999:    It's just a guess. I have no idea of insn cost on pyrs. */
                   1000: #define EASY_DIV_EXPR TRUNC_DIV_EXPR
                   1001: 
                   1002: /* Define this as 1 if `char' should by default be signed; else as 0.  */
                   1003: #define DEFAULT_SIGNED_CHAR 1
                   1004: 
                   1005: /* This flag, if defined, says the same insns that convert to a signed fixnum
                   1006:    also convert validly to an unsigned one.  */
                   1007: /* This is untrue for pyramid.  The cvtdw instruction generates a trap
                   1008:    for input operands that are out-of-range for a signed int.  */
                   1009: /* #define FIXUNS_TRUNC_LIKE_FIX_TRUNC */
                   1010: 
                   1011: /* Define this macro if the preprocessor should silently ignore
                   1012:   '#sccs' directives. */
                   1013: /* #define SCCS_DIRECTIVE */
                   1014: 
                   1015: /* Define this macro if the preprocessor should silently ignore
                   1016:   '#ident' directives. */
                   1017: /* #define IDENT_DIRECTIVE */
                   1018: 
                   1019: /* Max number of bytes we can move from memory to memory
                   1020:    in one reasonably fast instruction.  */
                   1021: #define MOVE_MAX 8
                   1022: 
                   1023: /* Define this if zero-extension is slow (more than one real instruction).  */
                   1024: /* #define SLOW_ZERO_EXTEND */
                   1025: 
                   1026: /* number of bits in an 'int' on target machine */
                   1027: #define INT_TYPE_SIZE 32
                   1028: 
                   1029: /* 1 if byte access requires more than one instruction */
                   1030: #define SLOW_BYTE_ACCESS 0
                   1031: 
                   1032: /* Define this to be nonzero if shift instructions ignore all but the low-order
                   1033:    few bits. */
                   1034: #define SHIFT_COUNT_TRUNCATED 1
                   1035: 
                   1036: /* Value is 1 if truncating an integer of INPREC bits to OUTPREC bits
                   1037:    is done just by pretending it is already truncated.  */
                   1038: #define TRULY_NOOP_TRUNCATION(OUTPREC, INPREC) 1
                   1039: 
                   1040: /* Define this macro if it is as good or better to call a constant
                   1041:    function address than to call an address kept in a register.  */
                   1042: /* #define NO_FUNCTION_CSE */
                   1043: 
                   1044: /* When a prototype says `char' or `short', really pass an `int'.  */
                   1045: #define PROMOTE_PROTOTYPES
                   1046: 
                   1047: /* There are no flag store insns on a pyr. */
                   1048: /* #define STORE_FLAG_VALUE */
                   1049: 
                   1050: /* Specify the machine mode that pointers have.
                   1051:    After generation of rtl, the compiler makes no further distinction
                   1052:    between pointers and any other objects of this machine mode.  */
                   1053: #define Pmode SImode
                   1054: 
                   1055: /* A function address in a call instruction
                   1056:    is a byte address (for indexing purposes)
                   1057:    so give the MEM rtx a byte's mode.  */
                   1058: #define FUNCTION_MODE QImode
                   1059: 
                   1060: /* Compute the cost of computing a constant rtl expression RTX
                   1061:    whose rtx-code is CODE.  The body of this macro is a portion
                   1062:    of a switch statement.  If the code is computed here,
                   1063:    return it with a return statement.  Otherwise, break from the switch.  */
                   1064: 
                   1065: #define CONST_COSTS(RTX,CODE,OUTER_CODE) \
                   1066:   case CONST_INT:                                              \
                   1067:     if (CONST_OK_FOR_LETTER_P (INTVAL (RTX),'I')) return 0;    \
                   1068:   case CONST:                                                  \
                   1069:   case LABEL_REF:                                              \
                   1070:   case SYMBOL_REF:                                             \
                   1071:     return 4;                                                  \
                   1072:   case CONST_DOUBLE:                                           \
                   1073:     return 6;
                   1074: 
                   1075: /* A flag which says to swap the operands of certain insns
                   1076:    when they are output.  */
                   1077: extern int swap_operands;
                   1078: 
                   1079: /*** Condition Code Information ***/
                   1080: 
                   1081: /* Tell final.c how to eliminate redundant test instructions.  */
                   1082: 
                   1083: /* Here we define machine-dependent flags and fields in cc_status
                   1084:    (see `conditions.h').  No extra ones are needed for the pyr.  */
                   1085: 
                   1086: /* Store in cc_status the expressions
                   1087:    that the condition codes will describe
                   1088:    after execution of an instruction whose pattern is EXP.
                   1089:    Do not alter them if the instruction would not alter the cc's.  */
                   1090: 
                   1091: /* This is a very simple definition of NOTICE_UPDATE_CC.
                   1092:    Many cases can be optimized, to improve condition code usage.
                   1093:    Maybe we should handle this entirely in the md, since it complicated
                   1094:    to describe the way pyr sets cc.  */
                   1095: 
                   1096: #define TRULY_UNSIGNED_COMPARE_P(X) \
                   1097:   (X == GEU || X == GTU || X == LEU || X == LTU)
                   1098: #define CC_VALID_FOR_UNSIGNED 2
                   1099: 
                   1100: #define CC_STATUS_MDEP_INIT cc_status.mdep = 0
                   1101: 
                   1102: #define NOTICE_UPDATE_CC(EXP, INSN) \
                   1103:   notice_update_cc(EXP, INSN)
                   1104: 
                   1105: /*** Output of Assembler Code ***/
                   1106: 
                   1107: /* Output at beginning of assembler file.  */
                   1108: 
                   1109: #define ASM_FILE_START(FILE) \
                   1110:   fprintf (FILE, ((TARGET_UNIX_ASM)? "" : "#NO_APP\n"));
                   1111: 
                   1112: /* Output to assembler file text saying following lines
                   1113:    may contain character constants, extra white space, comments, etc.  */
                   1114: 
                   1115: #define ASM_APP_ON ((TARGET_UNIX_ASM) ? "" : "#APP\n")
                   1116: 
                   1117: /* Output to assembler file text saying following lines
                   1118:    no longer contain unusual constructs.  */
                   1119: 
                   1120: #define ASM_APP_OFF ((TARGET_UNIX_ASM) ? "" : "#NO_APP\n")
                   1121: 
                   1122: /* Output before read-only data.  */
                   1123: 
                   1124: #define TEXT_SECTION_ASM_OP ".text"
                   1125: 
                   1126: /* Output before writable data.  */
                   1127: 
                   1128: #define DATA_SECTION_ASM_OP ".data"
                   1129: 
                   1130: /* How to refer to registers in assembler output.
                   1131:    This sequence is indexed by compiler's hard-register-number (see above).  */
                   1132: 
                   1133: #define REGISTER_NAMES \
                   1134: {"gr0", "gr1", "gr2", "gr3", "gr4", "gr5", "gr6", "gr7", "gr8", \
                   1135:  "gr9", "gr10", "gr11", "logpsw", "cfp", "sp", "pc", \
                   1136:  "pr0", "pr1", "pr2", "pr3", "pr4", "pr5", "pr6", "pr7", \
                   1137:  "pr8", "pr9", "pr10", "pr11", "pr12", "pr13", "pr14", "pr15", \
                   1138:  "lr0", "lr1", "lr2", "lr3", "lr4", "lr5", "lr6", "lr7", \
                   1139:  "lr8", "lr9", "lr10", "lr11", "lr12", "lr13", "lr14", "lr15", \
                   1140:  "tr0", "tr1", "tr2", "tr3", "tr4", "tr5", "tr6", "tr7", \
                   1141:  "tr8", "tr9", "tr10", "tr11", "tr12", "tr13", "tr14", "tr15"}
                   1142: 
                   1143: /* How to renumber registers for dbx and gdb.  */
                   1144: 
                   1145: #define DBX_REGISTER_NUMBER(REGNO) (REGNO)
                   1146: 
                   1147: /* Our preference is for dbx rather than sdb.
                   1148:    Yours may be different. */
                   1149: #define DBX_DEBUGGING_INFO
                   1150: /* #define SDB_DEBUGGING_INFO */
                   1151: 
                   1152: /* Don't use the `xsfoo;' construct in DBX output; this system
                   1153:    doesn't support it.  */
                   1154: 
                   1155: #define DBX_NO_XREFS 1
                   1156: 
                   1157: /* Do not break .stabs pseudos into continuations.  */
                   1158: 
                   1159: #define DBX_CONTIN_LENGTH 0
                   1160: 
                   1161: /* This is the char to use for continuation (in case we need to turn
                   1162:    continuation back on).  */
                   1163: 
                   1164: #define DBX_CONTIN_CHAR '?'
                   1165: 
                   1166: /* This is how to output the definition of a user-level label named NAME,
                   1167:    such as the label on a static function or variable NAME.  */
                   1168: 
                   1169: #define ASM_OUTPUT_LABEL(FILE,NAME)    \
                   1170:   do { assemble_name (FILE, NAME); fputs (":\n", FILE); } while (0)
                   1171: 
                   1172: /* This is how to output a command to make the user-level label named NAME
                   1173:    defined for reference from other files.  */
                   1174: 
                   1175: #define ASM_GLOBALIZE_LABEL(FILE,NAME) \
                   1176:   do { fputs (".globl ", FILE); assemble_name (FILE, NAME); fputs ("\n", FILE);} while (0)
                   1177: 
                   1178: /* This is how to output a reference to a user-level label named NAME.  */
                   1179: 
                   1180: #define ASM_OUTPUT_LABELREF(FILE,NAME) \
                   1181:    fprintf (FILE, "_%s", NAME);
                   1182: 
                   1183: /* This is how to output an internal numbered label where
                   1184:    PREFIX is the class of label and NUM is the number within the class.  */
                   1185: 
                   1186: #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM)     \
                   1187:   fprintf (FILE, "%s%d:\n", PREFIX, NUM)
                   1188: 
                   1189: /* This is how to store into the string LABEL
                   1190:    the symbol_ref name of an internal numbered label where
                   1191:    PREFIX is the class of label and NUM is the number within the class.
                   1192:    This is suitable for output with `assemble_name'.  */
                   1193: 
                   1194: #define ASM_GENERATE_INTERNAL_LABEL(LABEL,PREFIX,NUM)  \
                   1195:   sprintf (LABEL, "*%s%d", PREFIX, NUM)
                   1196: 
                   1197: /* This is how to output an assembler line defining a `double' constant.  */
                   1198: 
                   1199: #define ASM_OUTPUT_DOUBLE(FILE,VALUE)  \
                   1200:   fprintf (FILE, "\t.double 0d%.20e\n", (VALUE))
                   1201: 
                   1202: /* This is how to output an assembler line defining a `float' constant.  */
                   1203: 
                   1204: #define ASM_OUTPUT_FLOAT(FILE,VALUE)  \
                   1205:   fprintf (FILE, "\t.float 0f%.20e\n", (VALUE))
                   1206: 
                   1207: /* This is how to output an assembler line defining an `int' constant.  */
                   1208: 
                   1209: #define ASM_OUTPUT_INT(FILE,VALUE)  \
                   1210: ( fprintf (FILE, "\t.word "),                  \
                   1211:   output_addr_const (FILE, (VALUE)),           \
                   1212:   fprintf (FILE, "\n"))
                   1213: 
                   1214: /* Likewise for `char' and `short' constants.  */
                   1215: 
                   1216: #define ASM_OUTPUT_SHORT(FILE,VALUE)  \
                   1217: ( fprintf (FILE, "\t.half "),                  \
                   1218:   output_addr_const (FILE, (VALUE)),           \
                   1219:   fprintf (FILE, "\n"))
                   1220: 
                   1221: #define ASM_OUTPUT_CHAR(FILE,VALUE)  \
                   1222: ( fprintf (FILE, "\t.byte "),                  \
                   1223:   output_addr_const (FILE, (VALUE)),           \
                   1224:   fprintf (FILE, "\n"))
                   1225: 
                   1226: /* This is how to output an assembler line for a numeric constant byte.  */
                   1227: 
                   1228: #define ASM_OUTPUT_BYTE(FILE,VALUE)  \
                   1229:   fprintf (FILE, "\t.byte 0x%x\n", (VALUE))
                   1230: 
                   1231: /* This is how to output an insn to push a register on the stack.
                   1232:    It need not be very fast code.  */
                   1233: 
                   1234: #define ASM_OUTPUT_REG_PUSH(FILE,REGNO)  \
                   1235:   fprintf (FILE, "\tsubw $4,sp\n\tmovw %s,(sp)\n", reg_names[REGNO])
                   1236: 
                   1237: /* This is how to output an insn to pop a register from the stack.
                   1238:    It need not be very fast code.  */
                   1239: 
                   1240: #define ASM_OUTPUT_REG_POP(FILE,REGNO)  \
                   1241:   fprintf (FILE, "\tmovw (sp),%s\n\taddw $4,sp\n", reg_names[REGNO])
                   1242: 
                   1243: /* Store in OUTPUT a string (made with alloca) containing
                   1244:    an assembler-name for a local static variable named NAME.
                   1245:    LABELNO is an integer which is different for each call.  */
                   1246: 
                   1247: #define ASM_FORMAT_PRIVATE_NAME(OUTPUT, NAME, LABELNO) \
                   1248: ( (OUTPUT) = (char *) alloca (strlen ((NAME)) + 10),   \
                   1249:   sprintf ((OUTPUT), "%s.%d", (NAME), (LABELNO)))
                   1250: 
                   1251: /* This is how to output an element of a case-vector that is absolute.  */
                   1252: 
                   1253: #define ASM_OUTPUT_ADDR_VEC_ELT(FILE, VALUE)  \
                   1254:   fprintf (FILE, "\t.word L%d\n", VALUE)
                   1255: 
                   1256: /* This is how to output an element of a case-vector that is relative.  */
                   1257: 
                   1258: 
                   1259: #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL)  \
                   1260:   fprintf (FILE, "\t.word L%d-L%d\n", VALUE, REL)
                   1261: 
                   1262: /* This is how to output an assembler line
                   1263:    that says to advance the location counter
                   1264:    to a multiple of 2**LOG bytes.
                   1265: 
                   1266:    On Pyramids, the text segment must always be word aligned.
                   1267:    On Pyramids, .align takes only args between 2 and 5.
                   1268:   */
                   1269: 
                   1270: #define ASM_OUTPUT_ALIGN(FILE,LOG)  \
                   1271:   fprintf (FILE, "\t.align %d\n", (LOG) < 2 ? 2 : (LOG))
                   1272: 
                   1273: #define ASM_OUTPUT_SKIP(FILE,SIZE)  \
                   1274:   fprintf (FILE, "\t.space %u\n", (SIZE))
                   1275: 
                   1276: /* This says how to output an assembler line
                   1277:    to define a global common symbol.  */
                   1278: 
                   1279: #define ASM_OUTPUT_COMMON(FILE, NAME, SIZE, ROUNDED)  \
                   1280: ( fputs (".comm ", (FILE)),                    \
                   1281:   assemble_name ((FILE), (NAME)),              \
                   1282:   fprintf ((FILE), ",%u\n", (ROUNDED)))
                   1283: 
                   1284: /* This says how to output an assembler line
                   1285:    to define a local common symbol.  */
                   1286: 
                   1287: #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE, ROUNDED)  \
                   1288: ( fputs (".lcomm ", (FILE)),                   \
                   1289:   assemble_name ((FILE), (NAME)),              \
                   1290:   fprintf ((FILE), ",%u\n", (ROUNDED)))
                   1291: 
                   1292: /* Define the parentheses used to group arithmetic operations
                   1293:    in assembler code.  */
                   1294: 
                   1295: #define ASM_OPEN_PAREN "("
                   1296: #define ASM_CLOSE_PAREN ")"
                   1297: 
                   1298: /* Define results of standard character escape sequences.  */
                   1299: #define TARGET_BELL 007
                   1300: #define TARGET_BS 010
                   1301: #define TARGET_TAB 011
                   1302: #define TARGET_NEWLINE 012
                   1303: #define TARGET_VT 013
                   1304: #define TARGET_FF 014
                   1305: #define TARGET_CR 015
                   1306: 
                   1307: /* Print operand X (an rtx) in assembler syntax to file FILE.
                   1308:    CODE is a letter or dot (`z' in `%z0') or 0 if no letter was specified.
                   1309:    For `%' followed by punctuation, CODE is the punctuation and X is null.
                   1310:    On the Pyr, we support the conventional CODE characters:
                   1311: 
                   1312:    'f' for float insn (print a CONST_DOUBLE as a float rather than in hex)
                   1313:    which are never used. */
                   1314: 
                   1315: /* FIXME : should be more robust with CONST_DOUBLE. */
                   1316: 
                   1317: #define PRINT_OPERAND(FILE, X, CODE)  \
                   1318: { if (GET_CODE (X) == REG)                                             \
                   1319:     fprintf (FILE, "%s", reg_names [REGNO (X)]);                       \
                   1320:                                                                        \
                   1321:   else if (GET_CODE (X) == MEM)                                                \
                   1322:     output_address (XEXP (X, 0));                                      \
                   1323:                                                                        \
                   1324:   else if (GET_CODE (X) == CONST_DOUBLE && GET_MODE (X) == SFmode)     \
                   1325:     { union { double d; int i[2]; } u;                                 \
                   1326:       union { float f; int i; } u1;                                    \
                   1327:       u.i[0] = CONST_DOUBLE_LOW (X); u.i[1] = CONST_DOUBLE_HIGH (X);   \
                   1328:       u1.f = u.d;                                                      \
                   1329:       if (CODE == 'f')                                                 \
                   1330:         fprintf (FILE, "$0f%.0e", u1.f);                               \
                   1331:       else                                                             \
                   1332:         fprintf (FILE, "$0x%x", u1.i); }                               \
                   1333:                                                                        \
                   1334:   else if (GET_CODE (X) == CONST_DOUBLE && GET_MODE (X) != DImode)     \
                   1335:     { union { double d; int i[2]; } u;                                 \
                   1336:       u.i[0] = CONST_DOUBLE_LOW (X); u.i[1] = CONST_DOUBLE_HIGH (X);   \
                   1337:       fprintf (FILE, "$0d%.20e", u.d); }                               \
                   1338:                                                                        \
                   1339:   else if (CODE == 'N')                                                        \
                   1340:     switch (GET_CODE (X))                                              \
                   1341:       {                                                                        \
                   1342:       case EQ: fputs ("eq", FILE);     break;                          \
                   1343:       case NE: fputs ("ne", FILE);     break;                          \
                   1344:       case GT:                                                         \
                   1345:       case GTU:        fputs ("gt", FILE);     break;                          \
                   1346:       case LT:                                                         \
                   1347:       case LTU:        fputs ("lt", FILE);     break;                          \
                   1348:       case GE:                                                         \
                   1349:       case GEU:        fputs ("ge", FILE);     break;                          \
                   1350:       case LE:                                                         \
                   1351:       case LEU:        fputs ("le", FILE);     break;                          \
                   1352:       }                                                                        \
                   1353:                                                                        \
                   1354:   else if (CODE == 'C')                                                        \
                   1355:     switch (GET_CODE (X))                                              \
                   1356:       {                                                                        \
                   1357:       case EQ: fputs ("ne", FILE);     break;                          \
                   1358:       case NE: fputs ("eq", FILE);     break;                          \
                   1359:       case GT:                                                         \
                   1360:       case GTU:        fputs ("le", FILE);     break;                          \
                   1361:       case LT:                                                         \
                   1362:       case LTU:        fputs ("ge", FILE);     break;                          \
                   1363:       case GE:                                                         \
                   1364:       case GEU:        fputs ("lt", FILE);     break;                          \
                   1365:       case LE:                                                         \
                   1366:       case LEU:        fputs ("gt", FILE);     break;                          \
                   1367:       }                                                                        \
                   1368:                                                                        \
                   1369:   else if (CODE == 'R')                                                        \
                   1370:     switch (GET_CODE (X))                                              \
                   1371:       {                                                                        \
                   1372:       case EQ: fputs ("eq", FILE);     break;                          \
                   1373:       case NE: fputs ("ne", FILE);     break;                          \
                   1374:       case GT:                                                         \
                   1375:       case GTU:        fputs ("lt", FILE);     break;                          \
                   1376:       case LT:                                                         \
                   1377:       case LTU:        fputs ("gt", FILE);     break;                          \
                   1378:       case GE:                                                         \
                   1379:       case GEU:        fputs ("le", FILE);     break;                          \
                   1380:       case LE:                                                         \
                   1381:       case LEU:        fputs ("ge", FILE);     break;                          \
                   1382:       }                                                                        \
                   1383:                                                                        \
                   1384:   else { putc ('$', FILE); output_addr_const (FILE, X); }              \
                   1385: }
                   1386: 
                   1387: /* Print a memory operand whose address is ADDR, on file FILE.  */
                   1388: /* This is horrendously complicated.  */
                   1389: #define PRINT_OPERAND_ADDRESS(FILE, ADDR)  \
                   1390: {                                                                      \
                   1391:   register rtx reg1, reg2, breg, ireg;                                 \
                   1392:   register rtx addr = ADDR;                                            \
                   1393:   rtx offset, scale;                                                   \
                   1394:  retry:                                                                        \
                   1395:   switch (GET_CODE (addr))                                             \
                   1396:     {                                                                  \
                   1397:     case MEM:                                                          \
                   1398:       fprintf (stderr, "bad Mem "); debug_rtx (addr);                  \
                   1399:       addr = XEXP (addr, 0);                                           \
                   1400:       abort ();                                                                \
                   1401:     case REG:                                                          \
                   1402:       fprintf (FILE, "(%s)", reg_names [REGNO (addr)]);                        \
                   1403:       break;                                                           \
                   1404:     case PLUS:                                                         \
                   1405:       reg1 = 0;        reg2 = 0;                                               \
                   1406:       ireg = 0;        breg = 0;                                               \
                   1407:       offset = 0;                                                      \
                   1408:       if (CONSTANT_ADDRESS_P (XEXP (addr, 0))                          \
                   1409:          || GET_CODE (XEXP (addr, 0)) == MEM)                          \
                   1410:        {                                                               \
                   1411:          offset = XEXP (addr, 0);                                      \
                   1412:          addr = XEXP (addr, 1);                                        \
                   1413:        }                                                               \
                   1414:       else if (CONSTANT_ADDRESS_P (XEXP (addr, 1))                     \
                   1415:               || GET_CODE (XEXP (addr, 1)) == MEM)                     \
                   1416:        {                                                               \
                   1417:          offset = XEXP (addr, 1);                                      \
                   1418:          addr = XEXP (addr, 0);                                        \
                   1419:        }                                                               \
                   1420:       if (GET_CODE (addr) != PLUS) ;                                   \
                   1421:       else if (GET_CODE (XEXP (addr, 0)) == MULT)                      \
                   1422:        {                                                               \
                   1423:          reg1 = XEXP (addr, 0);                                        \
                   1424:          addr = XEXP (addr, 1);                                        \
                   1425:        }                                                               \
                   1426:       else if (GET_CODE (XEXP (addr, 1)) == MULT)                      \
                   1427:        {                                                               \
                   1428:          reg1 = XEXP (addr, 1);                                        \
                   1429:          addr = XEXP (addr, 0);                                        \
                   1430:        }                                                               \
                   1431:       else if (GET_CODE (XEXP (addr, 0)) == REG)                       \
                   1432:        {                                                               \
                   1433:          reg1 = XEXP (addr, 0);                                        \
                   1434:          addr = XEXP (addr, 1);                                        \
                   1435:        }                                                               \
                   1436:       else if (GET_CODE (XEXP (addr, 1)) == REG)                       \
                   1437:        {                                                               \
                   1438:          reg1 = XEXP (addr, 1);                                        \
                   1439:          addr = XEXP (addr, 0);                                        \
                   1440:        }                                                               \
                   1441:       if (GET_CODE (addr) == REG || GET_CODE (addr) == MULT)           \
                   1442:        {                                                               \
                   1443:          if (reg1 == 0)                                                \
                   1444:            reg1 = addr;                                                \
                   1445:           else                                                         \
                   1446:            reg2 = addr;                                                \
                   1447:          addr = 0;                                                     \
                   1448:        }                                                               \
                   1449:       if (offset != 0)                                                         \
                   1450:        {                                                               \
                   1451:          if (addr != 0) {                                              \
                   1452:            fprintf (stderr, "\nBad addr "); debug_rtx (addr);          \
                   1453:            abort ();}                                                  \
                   1454:          addr = offset;                                                \
                   1455:        }                                                               \
                   1456:       if (reg1 != 0 && GET_CODE (reg1) == MULT)                                \
                   1457:        { breg = reg2; ireg = reg1; }                                   \
                   1458:       else if (reg2 != 0 && GET_CODE (reg2) == MULT)                   \
                   1459:        { breg = reg1; ireg = reg2; }                                   \
                   1460:       else if (reg2 != 0 || GET_CODE (addr) == MEM)                    \
                   1461:        { breg = reg2; ireg = reg1; }                                   \
                   1462:       else                                                             \
                   1463:        { breg = reg1; ireg = reg2; }                                   \
                   1464:       if (addr != 0)                                                   \
                   1465:        output_address (offset);                                        \
                   1466:       if (breg != 0)                                                   \
                   1467:        { if (GET_CODE (breg) != REG)                                   \
                   1468:            {                                                           \
                   1469:              fprintf (stderr, "bad Breg"); debug_rtx (addr);           \
                   1470:              abort ();                                                 \
                   1471:            }                                                           \
                   1472:          fprintf (FILE, "(%s)", reg_names[REGNO (breg)]); }            \
                   1473:       if (ireg != 0)                                                   \
                   1474:        {                                                               \
                   1475:          if (GET_CODE (ireg) == MULT)                                  \
                   1476:            {                                                           \
                   1477:              scale = XEXP (ireg, 1);                                   \
                   1478:              ireg = XEXP (ireg, 0);                                    \
                   1479:              if (GET_CODE (ireg) != REG)                               \
                   1480:                { register rtx tem;                                     \
                   1481:                  tem = ireg; ireg = scale; scale = tem;                \
                   1482:                }                                                       \
                   1483:              if (GET_CODE (ireg) != REG) {                             \
                   1484:                      fprintf (stderr, "bad idx "); debug_rtx (addr);   \
                   1485:                abort (); }                                             \
                   1486:              if ((GET_CODE (scale) == CONST_INT) && (INTVAL(scale) >= 1))\
                   1487:                fprintf (FILE, "[%s*0x%x]", reg_names[REGNO (ireg)],    \
                   1488:                         INTVAL(scale));                                \
                   1489:              else                                                      \
                   1490:                fprintf (FILE, "[%s*1]", reg_names[REGNO (ireg)]);      \
                   1491:            }                                                           \
                   1492:          else if (GET_CODE (ireg) == REG)                              \
                   1493:              fprintf (FILE, "[%s*1]", reg_names[REGNO (ireg)]);        \
                   1494:          else                                                          \
                   1495:            {                                                           \
                   1496:              fprintf (stderr, "Not indexed at all!"); debug_rtx (addr);\
                   1497:              abort ();                                                 \
                   1498:            }                                                           \
                   1499:         }                                                              \
                   1500:        break;                                                          \
                   1501:     default:                                                           \
                   1502:       output_addr_const (FILE, addr);                                  \
                   1503:    }                                                                   \
                   1504: }

unix.superglobalmegacorp.com

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