Annotation of GNUtools/cc/config/a29k/a29k.h, revision 1.1

1.1     ! root        1: /* Definitions of target machine for GNU compiler, for AMD Am29000 CPU.
        !             2:    Copyright (C) 1988, 1990, 1991, 1992, 1993 Free Software Foundation, Inc.
        !             3:    Contributed by Richard Kenner ([email protected])
        !             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: /* Names to predefine in the preprocessor for this target machine.  */
        !            23: 
        !            24: #define CPP_PREDEFINES "-D_AM29K -D_AM29000 -D_EPI -Acpu(a29k) -Amachine(a29k)"
        !            25: 
        !            26: /* Print subsidiary information on the compiler version in use.  */
        !            27: #define TARGET_VERSION
        !            28: 
        !            29: /* Pass -w to assembler.  */
        !            30: #define ASM_SPEC "-w"
        !            31: 
        !            32: /* Run-time compilation parameters selecting different hardware subsets.  */
        !            33: 
        !            34: extern int target_flags;
        !            35: 
        !            36: /* Macro to define tables used to set the flags.
        !            37:    This is a list in braces of pairs in braces,
        !            38:    each pair being { "NAME", VALUE }
        !            39:    where VALUE is the bits to set or minus the bits to clear.
        !            40:    An empty string NAME is used to identify the default VALUE.  */
        !            41: 
        !            42: /* This means that the DW bit will be enabled, to allow direct loads
        !            43:    of bytes.  */
        !            44: 
        !            45: #define TARGET_DW_ENABLE       (target_flags & 1)
        !            46: 
        !            47: /* This means that the external hardware does supports byte writes.  */
        !            48: 
        !            49: #define TARGET_BYTE_WRITES     (target_flags & 2)
        !            50: 
        !            51: /* This means that a "small memory model" has been selected where all
        !            52:    function addresses are known to be within 256K.  This allows CALL to be
        !            53:    used.  */
        !            54: 
        !            55: #define TARGET_SMALL_MEMORY    (target_flags & 4)
        !            56: 
        !            57: /* This means that we must always used on indirect call, even when
        !            58:    calling a function in the same file, since the file might be > 256KB.  */
        !            59: 
        !            60: #define TARGET_LARGE_MEMORY    (target_flags & 8)
        !            61: 
        !            62: /* This means that we are compiling for a 29050.  */
        !            63: 
        !            64: #define TARGET_29050           (target_flags & 16)
        !            65: 
        !            66: /* This means that we are compiling for the kernel which means that we use
        !            67:    gr64-gr95 instead of gr96-126.  */
        !            68: 
        !            69: #define TARGET_KERNEL_REGISTERS        (target_flags & 32)
        !            70: 
        !            71: /* This means that a call to "__msp_check" should be inserted after each stack
        !            72:    adjustment to check for stack overflow.  */
        !            73: 
        !            74: #define TARGET_STACK_CHECK     (target_flags & 64)
        !            75: 
        !            76: /* This handles 29k processors which cannot handle the separation
        !            77:    of a mtsrim insns and a storem insn (most 29000 chips to date, but
        !            78:    not the 29050.  */
        !            79: 
        !            80: #define TARGET_NO_STOREM_BUG   (target_flags & 128)
        !            81: 
        !            82: /* This forces the compiler not to use incoming argument registers except
        !            83:    for copying out arguments.  It helps detect problems when a function is
        !            84:    called with fewer arguments than it is declared with.  */
        !            85: 
        !            86: #define TARGET_NO_REUSE_ARGS   (target_flags & 256)
        !            87: 
        !            88: #define TARGET_SWITCHES                        \
        !            89:   { {"dw", 1},                         \
        !            90:     {"ndw", -1},                       \
        !            91:     {"bw", 2},                         \
        !            92:     {"nbw", - (1|2)},                  \
        !            93:     {"small", 4},                      \
        !            94:     {"normal", - (4|8)},               \
        !            95:     {"large", 8},                      \
        !            96:     {"29050", 16+128},                 \
        !            97:     {"29000", -16},                    \
        !            98:     {"kernel-registers", 32},          \
        !            99:     {"user-registers", -32},           \
        !           100:     {"stack-check", 64},               \
        !           101:     {"no-stack-check", - 74},          \
        !           102:     {"storem-bug", -128},              \
        !           103:     {"no-storem-bug", 128},            \
        !           104:     {"reuse-arg-regs", -256},          \
        !           105:     {"no-reuse-arg-regs", 256},                \
        !           106:     {"", TARGET_DEFAULT}}
        !           107: 
        !           108: #define TARGET_DEFAULT 3
        !           109: 
        !           110: /* Define this to change the optimizations performed by default.  */
        !           111: 
        !           112: #define OPTIMIZATION_OPTIONS(LEVEL)    \
        !           113: {                                      \
        !           114:   if ((LEVEL) > 0)                     \
        !           115:     {                                  \
        !           116:       flag_force_addr = 1;             \
        !           117:       flag_force_mem = 1;              \
        !           118:       flag_omit_frame_pointer = 1;     \
        !           119:     }                                  \
        !           120: }
        !           121: 
        !           122: /* target machine storage layout */
        !           123: 
        !           124: /* Define the types for size_t, ptrdiff_t, and wchar_t.  These are the
        !           125:    same as those used by EPI.  The type for wchar_t does not make much
        !           126:    sense, but is what is used.  */
        !           127: 
        !           128: #define SIZE_TYPE "unsigned int"
        !           129: #define PTRDIFF_TYPE "int"
        !           130: #define WCHAR_TYPE "char"
        !           131: #define WCHAR_TYPE_SIZE BITS_PER_UNIT
        !           132: 
        !           133: /* Define this macro if it is advisable to hold scalars in registers
        !           134:    in a wider mode than that declared by the program.  In such cases, 
        !           135:    the value is constrained to be within the bounds of the declared
        !           136:    type, but kept valid in the wider mode.  The signedness of the
        !           137:    extension may differ from that of the type.  */
        !           138: 
        !           139: #define PROMOTE_MODE(MODE,UNSIGNEDP,TYPE)  \
        !           140:   if (GET_MODE_CLASS (MODE) == MODE_INT        \
        !           141:       && GET_MODE_SIZE (MODE) < 4)     \
        !           142:     (MODE) = SImode;
        !           143: 
        !           144: /* Define this if most significant bit is lowest numbered
        !           145:    in instructions that operate on numbered bit-fields.
        !           146:    This is arbitrary on the 29k since it has no actual bit-field insns.
        !           147:    It is better to define this as TRUE because BYTES_BIG_ENDIAN is TRUE
        !           148:    and we want to be able to convert BP position to bit position with
        !           149:    just a shift.  */
        !           150: #define BITS_BIG_ENDIAN 1
        !           151: 
        !           152: /* Define this if most significant byte of a word is the lowest numbered.
        !           153:    This is true on 29k.  */
        !           154: #define BYTES_BIG_ENDIAN 1
        !           155: 
        !           156: /* Define this if most significant word of a multiword number is lowest
        !           157:    numbered. 
        !           158: 
        !           159:    For 29k we can decide arbitrarily since there are no machine instructions
        !           160:    for them.  Might as well be consistent with bytes. */
        !           161: #define WORDS_BIG_ENDIAN 1
        !           162: 
        !           163: /* number of bits in an addressable storage unit */
        !           164: #define BITS_PER_UNIT 8
        !           165: 
        !           166: /* Width in bits of a "word", which is the contents of a machine register.
        !           167:    Note that this is not necessarily the width of data type `int';
        !           168:    if using 16-bit ints on a 68000, this would still be 32.
        !           169:    But on a machine with 16-bit registers, this would be 16.  */
        !           170: #define BITS_PER_WORD 32
        !           171: 
        !           172: /* Width of a word, in units (bytes).  */
        !           173: #define UNITS_PER_WORD 4
        !           174: 
        !           175: /* Width in bits of a pointer.
        !           176:    See also the macro `Pmode' defined below.  */
        !           177: #define POINTER_SIZE 32
        !           178: 
        !           179: /* Allocation boundary (in *bits*) for storing arguments in argument list.  */
        !           180: #define PARM_BOUNDARY 32
        !           181: 
        !           182: /* Boundary (in *bits*) on which stack pointer should be aligned.  */
        !           183: #define STACK_BOUNDARY 64
        !           184: 
        !           185: /* Allocation boundary (in *bits*) for the code of a function.  */
        !           186: #define FUNCTION_BOUNDARY 32
        !           187: 
        !           188: /* Alignment of field after `int : 0' in a structure.  */
        !           189: #define EMPTY_FIELD_BOUNDARY 32
        !           190: 
        !           191: /* Every structure's size must be a multiple of this.  */
        !           192: #define STRUCTURE_SIZE_BOUNDARY 8
        !           193: 
        !           194: /* A bitfield declared as `int' forces `int' alignment for the struct.  */
        !           195: #define PCC_BITFIELD_TYPE_MATTERS 1
        !           196: 
        !           197: /* No data type wants to be aligned rounder than this.  */
        !           198: #define BIGGEST_ALIGNMENT 32
        !           199: 
        !           200: /* Make strings word-aligned so strcpy from constants will be faster.  */
        !           201: #define CONSTANT_ALIGNMENT(EXP, ALIGN)  \
        !           202:   (TREE_CODE (EXP) == STRING_CST       \
        !           203:    && (ALIGN) < BITS_PER_WORD ? BITS_PER_WORD : (ALIGN))
        !           204: 
        !           205: /* Make arrays of chars word-aligned for the same reasons.  */
        !           206: #define DATA_ALIGNMENT(TYPE, ALIGN)            \
        !           207:   (TREE_CODE (TYPE) == ARRAY_TYPE              \
        !           208:    && TYPE_MODE (TREE_TYPE (TYPE)) == QImode   \
        !           209:    && (ALIGN) < BITS_PER_WORD ? BITS_PER_WORD : (ALIGN))
        !           210: 
        !           211: /* Set this non-zero if move instructions will actually fail to work
        !           212:    when given unaligned data.  */
        !           213: #define STRICT_ALIGNMENT 0
        !           214: 
        !           215: /* Set this non-zero if unaligned move instructions are extremely slow.
        !           216: 
        !           217:    On the 29k, they trap.  */
        !           218: #define SLOW_UNALIGNED_ACCESS 1
        !           219: 
        !           220: /* Standard register usage.  */
        !           221: 
        !           222: /* Number of actual hardware registers.
        !           223:    The hardware registers are assigned numbers for the compiler
        !           224:    from 0 to just below FIRST_PSEUDO_REGISTER.
        !           225:    All registers that the compiler knows about must be given numbers,
        !           226:    even those that are not normally considered general registers.
        !           227: 
        !           228:    29k has 256 registers, of which 62 are not defined.  gr0 and gr1 are
        !           229:    not produced in generated RTL so we can start at gr96, and call it
        !           230:    register zero.
        !           231: 
        !           232:    So 0-31 are gr96-gr127, lr0-lr127 are 32-159.  To represent the input
        !           233:    arguments, whose register numbers we won't know until we are done,
        !           234:    use register 160-175.  They cannot be modified.  Similarly, 176 is used
        !           235:    for the frame pointer.  It is assigned the last local register number
        !           236:    once the number of registers used is known.
        !           237: 
        !           238:    We use 177, 178, 179, and 180 for the special registers BP, FC, CR, and Q,
        !           239:    respectively.  Registers 181 through 199 are used for the other special
        !           240:    registers that may be used by the programmer, but are never used by the
        !           241:    compiler.
        !           242: 
        !           243:    Registers 200-203 are the four floating-point accumulator register in
        !           244:    the 29050.
        !           245: 
        !           246:    Registers 204-235 are the 32 global registers for kernel mode when
        !           247:    -mkernel-registers is not specified, and the 32 global user registers
        !           248:    when it is.
        !           249: 
        !           250:    When -mkernel-registers is specified, we still use the same register
        !           251:    map but change the names so 0-31 print as gr64-gr95.  */
        !           252: 
        !           253: #define FIRST_PSEUDO_REGISTER 236
        !           254: 
        !           255: /* Because of the large number of registers on the 29k, we define macros
        !           256:    to refer to each group of registers and then define the number for some
        !           257:    registers used in the calling sequence.  */
        !           258: 
        !           259: #define R_GR(N)                ((N) - 96)      /* gr96 is register number 0 */
        !           260: #define R_LR(N)                ((N) + 32)      /* lr0 is register number 32 */
        !           261: #define R_FP           176             /* frame pointer is register 176 */
        !           262: #define R_AR(N)                ((N) + 160)     /* first incoming arg reg is 160 */
        !           263: #define R_KR(N)                ((N) + 204)     /* kernel registers (gr64 to gr95) */
        !           264: 
        !           265: /* Define the numbers of the special registers.  */
        !           266: #define R_BP   177
        !           267: #define R_FC   178
        !           268: #define R_CR   179
        !           269: #define R_Q    180
        !           270: 
        !           271: /* These special registers are not used by the compiler, but may be referenced
        !           272:    by the programmer via asm declarations.  */
        !           273: 
        !           274: #define R_VAB  181
        !           275: #define R_OPS  182
        !           276: #define R_CPS  183
        !           277: #define R_CFG  184
        !           278: #define R_CHA  185
        !           279: #define R_CHD  186
        !           280: #define R_CHC  187
        !           281: #define R_RBP  188
        !           282: #define R_TMC  189
        !           283: #define R_TMR  190
        !           284: #define R_PC0  191
        !           285: #define R_PC1  192
        !           286: #define R_PC2  193
        !           287: #define R_MMU  194
        !           288: #define R_LRU  195
        !           289: #define R_FPE  196
        !           290: #define R_INT  197
        !           291: #define R_FPS  198
        !           292: #define R_EXO  199
        !           293: 
        !           294: /* Define the number for floating-point accumulator N.  */
        !           295: #define R_ACC(N)       ((N) + 200)
        !           296: 
        !           297: /* Now define the registers used in the calling sequence.  */
        !           298: #define R_TAV  R_GR (121)
        !           299: #define R_TPC  R_GR (122)
        !           300: #define R_LRP  R_GR (123)
        !           301: #define R_SLP  R_GR (124)
        !           302: #define R_MSP  R_GR (125)
        !           303: #define R_RAB  R_GR (126)
        !           304: #define R_RFB  R_GR (127)
        !           305: 
        !           306: /* 1 for registers that have pervasive standard uses
        !           307:    and are not available for the register allocator.  */
        !           308: 
        !           309: #define FIXED_REGISTERS  \
        !           310:  {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           311:   1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, \
        !           312:   0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           313:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           314:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           315:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           316:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           317:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           318:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           319:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           320:   1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, \
        !           321:   1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, \
        !           322:   1, 1, 1, 1, 1, 1, 1, 1,                        \
        !           323:   0, 0, 0, 0,                                    \
        !           324:   1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, \
        !           325:   1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 }
        !           326: 
        !           327: /* 1 for registers not available across function calls.
        !           328:    These must include the FIXED_REGISTERS and also any
        !           329:    registers that can be used without being saved.
        !           330:    The latter must include the registers where values are returned
        !           331:    and the register where structure-value addresses are passed.
        !           332:    Aside from that, you can include as many other registers as you like.  */
        !           333: #define CALL_USED_REGISTERS  \
        !           334:  {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, \
        !           335:   1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, \
        !           336:   1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           337:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           338:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           339:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           340:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           341:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           342:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           343:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           344:   1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, \
        !           345:   1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, \
        !           346:   1, 1, 1, 1, 1, 1, 1, 1,                        \
        !           347:   1, 1, 1, 1,                                    \
        !           348:   1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, \
        !           349:   1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 }
        !           350: 
        !           351: /* List the order in which to allocate registers.  Each register must be
        !           352:    listed once, even those in FIXED_REGISTERS.
        !           353: 
        !           354:    We allocate in the following order:
        !           355:        gr116-gr120     (not used for anything but temps)
        !           356:        gr96-gr111      (function return values, reverse order)
        !           357:        argument registers (160-175)
        !           358:        lr0-lr127       (locals, saved)
        !           359:         acc3-0         (acc0 special)
        !           360:        everything else  */
        !           361: 
        !           362: #define REG_ALLOC_ORDER                \
        !           363:   {R_GR (116), R_GR (117), R_GR (118), R_GR (119), R_GR (120),         \
        !           364:    R_GR (111), R_GR (110), R_GR (109), R_GR (108), R_GR (107),         \
        !           365:    R_GR (106), R_GR (105), R_GR (104), R_GR (103), R_GR (102),         \
        !           366:    R_GR (101), R_GR (100), R_GR (99), R_GR (98), R_GR (97), R_GR (96), \
        !           367:    R_AR (0), R_AR (1), R_AR (2), R_AR (3), R_AR (4), R_AR (5),         \
        !           368:    R_AR (6), R_AR (7), R_AR (8), R_AR (9), R_AR (10), R_AR (11),       \
        !           369:    R_AR (12), R_AR (13), R_AR (14), R_AR (15),                         \
        !           370:    R_LR (0), R_LR (1), R_LR (2), R_LR (3), R_LR (4), R_LR (5),         \
        !           371:    R_LR (6), R_LR (7), R_LR (8), R_LR (9), R_LR (10), R_LR (11),       \
        !           372:    R_LR (12), R_LR (13), R_LR (14), R_LR (15), R_LR (16), R_LR (17),   \
        !           373:    R_LR (18), R_LR (19), R_LR (20), R_LR (21), R_LR (22), R_LR (23),   \
        !           374:    R_LR (24), R_LR (25), R_LR (26), R_LR (27), R_LR (28), R_LR (29),   \
        !           375:    R_LR (30), R_LR (31), R_LR (32), R_LR (33), R_LR (34), R_LR (35),   \
        !           376:    R_LR (36), R_LR (37), R_LR (38), R_LR (39), R_LR (40), R_LR (41),   \
        !           377:    R_LR (42), R_LR (43), R_LR (44), R_LR (45), R_LR (46), R_LR (47),   \
        !           378:    R_LR (48), R_LR (49), R_LR (50), R_LR (51), R_LR (52), R_LR (53),   \
        !           379:    R_LR (54), R_LR (55), R_LR (56), R_LR (57), R_LR (58), R_LR (59),   \
        !           380:    R_LR (60), R_LR (61), R_LR (62), R_LR (63), R_LR (64), R_LR (65),   \
        !           381:    R_LR (66), R_LR (67), R_LR (68), R_LR (69), R_LR (70), R_LR (71),   \
        !           382:    R_LR (72), R_LR (73), R_LR (74), R_LR (75), R_LR (76), R_LR (77),   \
        !           383:    R_LR (78), R_LR (79), R_LR (80), R_LR (81), R_LR (82), R_LR (83),   \
        !           384:    R_LR (84), R_LR (85), R_LR (86), R_LR (87), R_LR (88), R_LR (89),   \
        !           385:    R_LR (90), R_LR (91), R_LR (92), R_LR (93), R_LR (94), R_LR (95),   \
        !           386:    R_LR (96), R_LR (97), R_LR (98), R_LR (99), R_LR (100), R_LR (101), \
        !           387:    R_LR (102), R_LR (103), R_LR (104), R_LR (105), R_LR (106),         \
        !           388:    R_LR (107), R_LR (108), R_LR (109), R_LR (110), R_LR (111),         \
        !           389:    R_LR (112), R_LR (113), R_LR (114), R_LR (115), R_LR (116),         \
        !           390:    R_LR (117), R_LR (118), R_LR (119), R_LR (120), R_LR (121),         \
        !           391:    R_LR (122), R_LR (123), R_LR (124), R_LR (124), R_LR (126),         \
        !           392:    R_LR (127),                                                         \
        !           393:    R_ACC (3), R_ACC (2), R_ACC (1), R_ACC (0),                         \
        !           394:    R_GR (112), R_GR (113), R_GR (114), R_GR (115), R_GR (121),         \
        !           395:    R_GR (122), R_GR (123), R_GR (124), R_GR (125), R_GR (126),         \
        !           396:    R_GR (127),                                                         \
        !           397:    R_FP, R_BP, R_FC, R_CR, R_Q,                                                \
        !           398:    R_VAB, R_OPS, R_CPS, R_CFG, R_CHA, R_CHD, R_CHC, R_RBP, R_TMC,      \
        !           399:    R_TMR, R_PC0, R_PC1, R_PC2, R_MMU, R_LRU, R_FPE, R_INT, R_FPS,      \
        !           400:    R_EXO,                                                              \
        !           401:    R_KR (0), R_KR (1), R_KR (2), R_KR (3), R_KR (4), R_KR (5),                 \
        !           402:    R_KR (6), R_KR (7), R_KR (8), R_KR (9), R_KR (10), R_KR (11),       \
        !           403:    R_KR (12), R_KR (13), R_KR (14), R_KR (15), R_KR (16), R_KR (17),   \
        !           404:    R_KR (18), R_KR (19), R_KR (20), R_KR (21), R_KR (22), R_KR (23),   \
        !           405:    R_KR (24), R_KR (25), R_KR (26), R_KR (27), R_KR (28), R_KR (29),   \
        !           406:    R_KR (30), R_KR (31) }
        !           407: 
        !           408: /* Return number of consecutive hard regs needed starting at reg REGNO
        !           409:    to hold something of mode MODE.
        !           410:    This is ordinarily the length in words of a value of mode MODE
        !           411:    but can be less for certain modes in special long registers.  */
        !           412: 
        !           413: #define HARD_REGNO_NREGS(REGNO, MODE)   \
        !           414:   ((REGNO) >= R_ACC (0) && (REGNO) <= R_ACC (3)? 1             \
        !           415:    : (GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD)
        !           416: 
        !           417: /* Value is 1 if hard register REGNO can hold a value of machine-mode MODE.
        !           418:    On 29k, the cpu registers can hold any mode.  But a double-precision
        !           419:    floating-point value should start at an even register.  The special
        !           420:    registers cannot hold floating-point values, BP, CR, and FC cannot
        !           421:    hold integer or floating-point values,  and the accumulators cannot
        !           422:    hold integer values.
        !           423: 
        !           424:    DImode and larger values should start at an even register just like
        !           425:    DFmode values, even though the instruction set doesn't require it, in order
        !           426:    to prevent reload from aborting due to a modes_equiv_for_class_p failure.
        !           427: 
        !           428:    (I'd like to use the "?:" syntax to make this more readable, but Sun's
        !           429:    compiler doesn't seem to accept it.)  */
        !           430: #define HARD_REGNO_MODE_OK(REGNO, MODE)                                \
        !           431: (((REGNO) >= R_ACC (0) && (REGNO) <= R_ACC (3)                         \
        !           432:     && (GET_MODE_CLASS (MODE) == MODE_FLOAT                            \
        !           433:        || GET_MODE_CLASS (MODE) == MODE_COMPLEX_FLOAT))                \
        !           434:    || ((REGNO) >= R_BP && (REGNO) <= R_CR                              \
        !           435:        && GET_MODE_CLASS (MODE) == MODE_PARTIAL_INT)                   \
        !           436:    || ((REGNO) >= R_Q && (REGNO) < R_ACC (0)                           \
        !           437:        && GET_MODE_CLASS (MODE) != MODE_FLOAT                          \
        !           438:        && GET_MODE_CLASS (MODE) != MODE_COMPLEX_FLOAT)                 \
        !           439:    || (((REGNO) < R_BP || (REGNO) >= R_KR (0))                          \
        !           440:        && ((((REGNO) & 1) == 0)                                                \
        !           441:           || GET_MODE_UNIT_SIZE (MODE) <= UNITS_PER_WORD)))
        !           442: 
        !           443: /* Value is 1 if it is a good idea to tie two pseudo registers
        !           444:    when one has mode MODE1 and one has mode MODE2.
        !           445:    If HARD_REGNO_MODE_OK could produce different values for MODE1 and MODE2,
        !           446:    for any hard reg, then this must be 0 for correct output.
        !           447: 
        !           448:    On the 29k, normally we'd just have problems with DFmode because of the
        !           449:    even alignment.  However, we also have to be a bit concerned about
        !           450:    the special register's restriction to non-floating and the floating-point
        !           451:    accumulator's restriction to only floating.  This probably won't
        !           452:    cause any great inefficiencies in practice.  */
        !           453: 
        !           454: #define MODES_TIEABLE_P(MODE1, MODE2)                  \
        !           455:   ((MODE1) == (MODE2)                                  \
        !           456:    || (GET_MODE_CLASS (MODE1) == MODE_INT              \
        !           457:        && GET_MODE_CLASS (MODE2) == MODE_INT))
        !           458: 
        !           459: /* Specify the registers used for certain standard purposes.
        !           460:    The values of these macros are register numbers.  */
        !           461: 
        !           462: /* 29k pc isn't overloaded on a register that the compiler knows about.  */
        !           463: /* #define PC_REGNUM  */
        !           464: 
        !           465: /* Register to use for pushing function arguments.  */
        !           466: #define STACK_POINTER_REGNUM R_GR (125)
        !           467: 
        !           468: /* Base register for access to local variables of the function.  */
        !           469: #define FRAME_POINTER_REGNUM R_FP
        !           470: 
        !           471: /* Value should be nonzero if functions must have frame pointers.
        !           472:    Zero means the frame pointer need not be set up (and parms
        !           473:    may be accessed via the stack pointer) in functions that seem suitable.
        !           474:    This is computed in `reload', in reload1.c.  */
        !           475: #define FRAME_POINTER_REQUIRED 0
        !           476: 
        !           477: /* Base register for access to arguments of the function.  */
        !           478: #define ARG_POINTER_REGNUM R_FP
        !           479: 
        !           480: /* Register in which static-chain is passed to a function.  */
        !           481: #define STATIC_CHAIN_REGNUM R_SLP
        !           482: 
        !           483: /* Register in which address to store a structure value
        !           484:    is passed to a function.  */
        !           485: #define STRUCT_VALUE_REGNUM R_LRP
        !           486: 
        !           487: /* Define the classes of registers for register constraints in the
        !           488:    machine description.  Also define ranges of constants.
        !           489: 
        !           490:    One of the classes must always be named ALL_REGS and include all hard regs.
        !           491:    If there is more than one class, another class must be named NO_REGS
        !           492:    and contain no registers.
        !           493: 
        !           494:    The name GENERAL_REGS must be the name of a class (or an alias for
        !           495:    another name such as ALL_REGS).  This is the class of registers
        !           496:    that is allowed by "g" or "r" in a register constraint.
        !           497:    Also, registers outside this class are allocated only when
        !           498:    instructions express preferences for them.
        !           499: 
        !           500:    The classes must be numbered in nondecreasing order; that is,
        !           501:    a larger-numbered class must never be contained completely
        !           502:    in a smaller-numbered class.
        !           503: 
        !           504:    For any two classes, it is very desirable that there be another
        !           505:    class that represents their union.
        !           506:    
        !           507:    The 29k has nine registers classes: LR0_REGS, GENERAL_REGS, SPECIAL_REGS,
        !           508:    BP_REGS, FC_REGS, CR_REGS, Q_REGS, ACCUM_REGS, and ACCUM0_REGS.
        !           509:    LR0_REGS, BP_REGS, FC_REGS, CR_REGS, and Q_REGS contain just the single
        !           510:    register.  The latter two classes are used to represent the floating-point
        !           511:    accumulator registers in the 29050.  We also define the union class
        !           512:    FLOAT_REGS to represent any register that can be used to hold a
        !           513:    floating-point value.  The union of SPECIAL_REGS and ACCUM_REGS isn't
        !           514:    useful as the former cannot contain floating-point and the latter can only
        !           515:    contain floating-point.  */
        !           516: 
        !           517: enum reg_class { NO_REGS, LR0_REGS, GENERAL_REGS, BP_REGS, FC_REGS, CR_REGS,
        !           518:                 Q_REGS, SPECIAL_REGS, ACCUM0_REGS, ACCUM_REGS, FLOAT_REGS,
        !           519:                 ALL_REGS, LIM_REG_CLASSES };
        !           520: 
        !           521: #define N_REG_CLASSES (int) LIM_REG_CLASSES
        !           522: 
        !           523: /* Give names of register classes as strings for dump file.   */
        !           524: 
        !           525: #define REG_CLASS_NAMES                                \
        !           526:  {"NO_REGS", "LR0_REGS", "GENERAL_REGS", "BP_REGS", "FC_REGS", "CR_REGS", \
        !           527:   "Q_REGS", "SPECIAL_REGS", "ACCUM0_REGS", "ACCUM_REGS", "FLOAT_REGS",    \
        !           528:   "ALL_REGS" }
        !           529: 
        !           530: /* Define which registers fit in which classes.
        !           531:    This is an initializer for a vector of HARD_REG_SET
        !           532:    of length N_REG_CLASSES.  */
        !           533: 
        !           534: #define REG_CLASS_CONTENTS     \
        !           535:   { {0, 0, 0, 0, 0, 0, 0, 0},                             \
        !           536:     {0, 1, 0, 0, 0, 0, 0, 0},                             \
        !           537:     {~0, ~0, ~0, ~0, ~0, ~ 0xfffe0000, ~ 0xfff, 0xfffff},  \
        !           538:     {0, 0, 0, 0, 0, 0x20000, 0, 0},                       \
        !           539:     {0, 0, 0, 0, 0, 0x40000, 0, 0},                       \
        !           540:     {0, 0, 0, 0, 0, 0x80000, 0, 0},                       \
        !           541:     {0, 0, 0, 0, 0, 0x100000, 0, 0},                      \
        !           542:     {0, 0, 0, 0, 0, 0xfffe0000, 0xff, 0},                 \
        !           543:     {0, 0, 0, 0, 0, 0, 0x100, 0},                         \
        !           544:     {0, 0, 0, 0, 0, 0, 0xf00, 0},                         \
        !           545:     {~0, ~0, ~0, ~0, ~0, ~ 0xfffe0000, ~ 0xff, ~0},       \
        !           546:     {~0, ~0, ~0, ~0, ~0, ~0, ~0, ~0} }
        !           547: 
        !           548: /* The same information, inverted:
        !           549:    Return the class number of the smallest class containing
        !           550:    reg number REGNO.  This could be a conditional expression
        !           551:    or could index an array.  */
        !           552: 
        !           553: #define REGNO_REG_CLASS(REGNO)         \
        !           554:   ((REGNO) == R_BP ? BP_REGS           \
        !           555:    : (REGNO) == R_FC ? FC_REGS         \
        !           556:    : (REGNO) == R_CR ? CR_REGS         \
        !           557:    : (REGNO) == R_Q ? Q_REGS           \
        !           558:    : (REGNO) > R_BP && (REGNO) <= R_EXO ? SPECIAL_REGS \
        !           559:    : (REGNO) == R_ACC (0) ? ACCUM0_REGS        \
        !           560:    : (REGNO) >= R_KR (0) ? GENERAL_REGS \
        !           561:    : (REGNO) > R_ACC (0) ? ACCUM_REGS  \
        !           562:    : (REGNO) == R_LR (0) ? LR0_REGS    \
        !           563:    : GENERAL_REGS)
        !           564: 
        !           565: /* The class value for index registers, and the one for base regs.  */
        !           566: #define INDEX_REG_CLASS NO_REGS
        !           567: #define BASE_REG_CLASS GENERAL_REGS
        !           568: 
        !           569: /* Get reg_class from a letter such as appears in the machine description.  */
        !           570: 
        !           571: #define REG_CLASS_FROM_LETTER(C)       \
        !           572:  ((C) == 'r' ? GENERAL_REGS            \
        !           573:   : (C) == 'l' ? LR0_REGS              \
        !           574:   : (C) == 'b' ? BP_REGS               \
        !           575:   : (C) == 'f' ? FC_REGS               \
        !           576:   : (C) == 'c' ? CR_REGS               \
        !           577:   : (C) == 'q' ? Q_REGS                        \
        !           578:   : (C) == 'h' ? SPECIAL_REGS          \
        !           579:   : (C) == 'a' ? ACCUM_REGS            \
        !           580:   : (C) == 'A' ? ACCUM0_REGS           \
        !           581:   : (C) == 'f' ? FLOAT_REGS            \
        !           582:   : NO_REGS)
        !           583: 
        !           584: /* Define this macro to change register usage conditional on target flags.
        !           585: 
        !           586:    On the 29k, we use this to change the register names for kernel mapping.  */
        !           587: 
        !           588: #define CONDITIONAL_REGISTER_USAGE             \
        !           589:   {                                            \
        !           590:     char *p;                                   \
        !           591:     int i;                                     \
        !           592:                                                \
        !           593:     if (TARGET_KERNEL_REGISTERS)               \
        !           594:       for (i = 0; i < 32; i++)                 \
        !           595:        {                                       \
        !           596:          p = reg_names[i];                     \
        !           597:          reg_names[i] = reg_names[R_KR (i)];   \
        !           598:          reg_names[R_KR (i)] = p;              \
        !           599:        }                                       \
        !           600:   }
        !           601: 
        !           602: /* The letters I, J, K, L, M, N, O, and P in a register constraint string
        !           603:    can be used to stand for particular ranges of immediate operands.
        !           604:    This macro defines what the ranges are.
        !           605:    C is the letter, and VALUE is a constant value.
        !           606:    Return 1 if VALUE is in the range specified by C.
        !           607: 
        !           608:    For 29k:
        !           609:    `I' is used for the range of constants most insns can contain.
        !           610:    `J' is for the few 16-bit insns.
        !           611:    `K' is a constant whose high-order 24 bits are all one
        !           612:    `L' is a HImode constant whose high-order 8 bits are all one
        !           613:    `M' is a 32-bit constant whose high-order 16 bits are all one (for CONSTN)
        !           614:    `N' is a 32-bit constant whose negative is 8 bits
        !           615:    `O' is the 32-bit constant 0x80000000, any constant with low-order
        !           616:           16 bits zero for 29050.
        !           617:    `P' is a HImode constant whose negative is 8 bits  */
        !           618: 
        !           619: #define CONST_OK_FOR_LETTER_P(VALUE, C)                                \
        !           620:   ((C) == 'I' ? (unsigned) (VALUE) < 0x100                     \
        !           621:    : (C) == 'J' ? (unsigned) (VALUE) < 0x10000                 \
        !           622:    : (C) == 'K' ? ((VALUE) & 0xffffff00) == 0xffffff00         \
        !           623:    : (C) == 'L' ? ((VALUE) & 0xff00) == 0xff00                 \
        !           624:    : (C) == 'M' ? ((VALUE) & 0xffff0000) == 0xffff0000         \
        !           625:    : (C) == 'N' ? ((VALUE) < 0 && (VALUE) > -256)              \
        !           626:    : (C) == 'O' ? ((VALUE) == 0x80000000                       \
        !           627:                   || (TARGET_29050 && ((VALUE) & 0xffff) == 0)) \
        !           628:    : (C) == 'P' ? (((VALUE) | 0xffff0000) < 0                  \
        !           629:                   && ((VALUE) | 0xffff0000) > -256)            \
        !           630:    : 0)
        !           631: 
        !           632: /* Similar, but for floating constants, and defining letters G and H.
        !           633:    Here VALUE is the CONST_DOUBLE rtx itself.
        !           634:    All floating-point constants are valid on 29k.  */
        !           635: 
        !           636: #define CONST_DOUBLE_OK_FOR_LETTER_P(VALUE, C)  1
        !           637: 
        !           638: /* Given an rtx X being reloaded into a reg required to be
        !           639:    in class CLASS, return the class of reg to actually use.
        !           640:    In general this is just CLASS; but on some machines
        !           641:    in some cases it is preferable to use a more restrictive class.  */
        !           642: 
        !           643: #define PREFERRED_RELOAD_CLASS(X,CLASS)        CLASS
        !           644: 
        !           645: /* Return the register class of a scratch register needed to copy IN into
        !           646:    or out of a register in CLASS in MODE.  If it can be done directly,
        !           647:    NO_REGS is returned.  */
        !           648: 
        !           649: #define SECONDARY_RELOAD_CLASS(CLASS,MODE,IN) \
        !           650:   secondary_reload_class (CLASS, MODE, IN)
        !           651: 
        !           652: /* This function is used to get the address of an object.  */
        !           653: 
        !           654: extern struct rtx_def *a29k_get_reloaded_address ();
        !           655: 
        !           656: /* Return the maximum number of consecutive registers
        !           657:    needed to represent mode MODE in a register of class CLASS.
        !           658: 
        !           659:    On 29k, this is the size of MODE in words except that the floating-point
        !           660:    accumulators only require one word for anything they can hold.  */
        !           661: 
        !           662: #define CLASS_MAX_NREGS(CLASS, MODE)                           \
        !           663:  (((CLASS) == ACCUM_REGS || (CLASS) == ACCUM0_REGS) ? 1                \
        !           664:   : (GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD)
        !           665: 
        !           666: /* Define the cost of moving between registers of various classes.  Everything
        !           667:    involving a general register is cheap, but moving between the other types
        !           668:    (even within a class) is two insns.  */
        !           669: 
        !           670: #define REGISTER_MOVE_COST(CLASS1, CLASS2)     \
        !           671:   ((CLASS1) == GENERAL_REGS || (CLASS2) == GENERAL_REGS ? 2 : 4)
        !           672: 
        !           673: /* A C statement (sans semicolon) to update the integer variable COST
        !           674:    based on the relationship between INSN that is dependent on
        !           675:    DEP_INSN through the dependence LINK.  The default is to make no
        !           676:    adjustment to COST.  On the a29k, ignore the cost of anti- and
        !           677:    output-dependencies.  */
        !           678: #define ADJUST_COST(INSN,LINK,DEP_INSN,COST)                           \
        !           679:   if (REG_NOTE_KIND (LINK) != 0)                                       \
        !           680:     (COST) = 0; /* Anti or output dependence.  */
        !           681: 
        !           682: /* Stack layout; function entry, exit and calling.  */
        !           683: 
        !           684: /* Define this if pushing a word on the stack
        !           685:    makes the stack pointer a smaller address.  */
        !           686: #define STACK_GROWS_DOWNWARD
        !           687: 
        !           688: /* Define this if the nominal address of the stack frame
        !           689:    is at the high-address end of the local variables;
        !           690:    that is, each additional local variable allocated
        !           691:    goes at a more negative offset in the frame.  */
        !           692: #define FRAME_GROWS_DOWNWARD
        !           693: 
        !           694: /* Offset within stack frame to start allocating local variables at.
        !           695:    If FRAME_GROWS_DOWNWARD, this is the offset to the END of the
        !           696:    first local allocated.  Otherwise, it is the offset to the BEGINNING
        !           697:    of the first local allocated.  */
        !           698: 
        !           699: #define STARTING_FRAME_OFFSET (- current_function_pretend_args_size)
        !           700: 
        !           701: /* If we generate an insn to push BYTES bytes,
        !           702:    this says how many the stack pointer really advances by.
        !           703:    On 29k, don't define this because there are no push insns.  */
        !           704: /*  #define PUSH_ROUNDING(BYTES) */
        !           705: 
        !           706: /* Define this if the maximum size of all the outgoing args is to be
        !           707:    accumulated and pushed during the prologue.  The amount can be
        !           708:    found in the variable current_function_outgoing_args_size.  */
        !           709: #define ACCUMULATE_OUTGOING_ARGS
        !           710: 
        !           711: /* Offset of first parameter from the argument pointer register value.  */
        !           712: 
        !           713: #define FIRST_PARM_OFFSET(FNDECL) (- current_function_pretend_args_size)
        !           714: 
        !           715: /* Define this if stack space is still allocated for a parameter passed
        !           716:    in a register.  */
        !           717: /* #define REG_PARM_STACK_SPACE */
        !           718: 
        !           719: /* Value is the number of bytes of arguments automatically
        !           720:    popped when returning from a subroutine call.
        !           721:    FUNTYPE is the data type of the function (as a tree),
        !           722:    or for a library call it is an identifier node for the subroutine name.
        !           723:    SIZE is the number of bytes of arguments passed on the stack.  */
        !           724: 
        !           725: #define RETURN_POPS_ARGS(FUNTYPE,SIZE) 0
        !           726: 
        !           727: /* Define how to find the value returned by a function.
        !           728:    VALTYPE is the data type of the value (as a tree).
        !           729:    If the precise function being called is known, FUNC is its FUNCTION_DECL;
        !           730:    otherwise, FUNC is 0.
        !           731: 
        !           732:    On 29k the value is found in gr96.  */
        !           733: 
        !           734: #define FUNCTION_VALUE(VALTYPE, FUNC)  \
        !           735:   gen_rtx (REG, TYPE_MODE (VALTYPE), R_GR (96))
        !           736: 
        !           737: /* Define how to find the value returned by a library function
        !           738:    assuming the value has mode MODE.  */
        !           739: 
        !           740: #define LIBCALL_VALUE(MODE)  gen_rtx (REG, MODE, R_GR (96))
        !           741: 
        !           742: /* 1 if N is a possible register number for a function value
        !           743:    as seen by the caller.
        !           744:    On 29k, gr96-gr111 are used.  */
        !           745: 
        !           746: #define FUNCTION_VALUE_REGNO_P(N) ((N) == R_GR (96))
        !           747: 
        !           748: /* 1 if N is a possible register number for function argument passing.
        !           749:    On 29k, these are lr2-lr17.  */
        !           750: 
        !           751: #define FUNCTION_ARG_REGNO_P(N) ((N) <= R_LR (17) && (N) >= R_LR (2))
        !           752: 
        !           753: /* Define a data type for recording info about an argument list
        !           754:    during the scan of that argument list.  This data type should
        !           755:    hold all necessary information about the function itself
        !           756:    and about the args processed so far, enough to enable macros
        !           757:    such as FUNCTION_ARG to determine where the next arg should go.
        !           758: 
        !           759:    On 29k, this is a single integer, which is a number of words
        !           760:    of arguments scanned so far.
        !           761:    Thus 16 or more means all following args should go on the stack.  */
        !           762: 
        !           763: #define CUMULATIVE_ARGS int
        !           764: 
        !           765: /* Initialize a variable CUM of type CUMULATIVE_ARGS
        !           766:    for a call to a function whose data type is FNTYPE.
        !           767:    For a library call, FNTYPE is 0.  */
        !           768: 
        !           769: #define INIT_CUMULATIVE_ARGS(CUM,FNTYPE,LIBNAME)  (CUM) = 0
        !           770: 
        !           771: /* Same, but called for incoming args.
        !           772: 
        !           773:    On the 29k, we use this to set all argument registers to fixed and
        !           774:    set the last 16 local regs (lr112-lr127) to available.  Some
        !           775:    will later be changed to call-saved by FUNCTION_INCOMING_ARG.  */
        !           776: 
        !           777: #define INIT_CUMULATIVE_INCOMING_ARGS(CUM,FNTYPE,IGNORE)               \
        !           778: { int i;                                                       \
        !           779:   for (i = R_AR (0); i < R_AR (16); i++)                       \
        !           780:     {                                                          \
        !           781:       fixed_regs[i] = call_used_regs[i] = call_fixed_regs[i] = 1; \
        !           782:       SET_HARD_REG_BIT (fixed_reg_set, i);                     \
        !           783:       SET_HARD_REG_BIT (call_used_reg_set, i);                 \
        !           784:       SET_HARD_REG_BIT (call_fixed_reg_set, i);                        \
        !           785:     }                                                          \
        !           786:   for (i = R_LR (112); i < R_LR (128); i++)                                    \
        !           787:     {                                                          \
        !           788:       fixed_regs[i] = call_used_regs[i] = call_fixed_regs[i] = 0; \
        !           789:       CLEAR_HARD_REG_BIT (fixed_reg_set, i);                   \
        !           790:       CLEAR_HARD_REG_BIT (call_used_reg_set, i);               \
        !           791:       CLEAR_HARD_REG_BIT (call_fixed_reg_set, i);              \
        !           792:     }                                                          \
        !           793:   (CUM) = 0;                                                   \
        !           794:  }
        !           795: 
        !           796: /* Define intermediate macro to compute the size (in registers) of an argument
        !           797:    for the 29k.  */
        !           798: 
        !           799: #define A29K_ARG_SIZE(MODE, TYPE, NAMED)                               \
        !           800: (! (NAMED) ? 0                                                         \
        !           801:  : (MODE) != BLKmode                                                   \
        !           802:  ? (GET_MODE_SIZE (MODE) + (UNITS_PER_WORD - 1)) / UNITS_PER_WORD      \
        !           803:  : (int_size_in_bytes (TYPE) + (UNITS_PER_WORD - 1)) / UNITS_PER_WORD)
        !           804: 
        !           805: /* Update the data in CUM to advance over an argument
        !           806:    of mode MODE and data type TYPE.
        !           807:    (TYPE is null for libcalls where that information may not be available.)  */
        !           808: 
        !           809: #define FUNCTION_ARG_ADVANCE(CUM, MODE, TYPE, NAMED)                   \
        !           810:   if (MUST_PASS_IN_STACK (MODE, TYPE))                                 \
        !           811:     (CUM) = 16;                                                                \
        !           812:   else                                                                 \
        !           813:     (CUM) += A29K_ARG_SIZE (MODE, TYPE, NAMED)
        !           814: 
        !           815: /* Determine where to put an argument to a function.
        !           816:    Value is zero to push the argument on the stack,
        !           817:    or a hard register in which to store the argument.
        !           818: 
        !           819:    MODE is the argument's machine mode.
        !           820:    TYPE is the data type of the argument (as a tree).
        !           821:     This is null for libcalls where that information may
        !           822:     not be available.
        !           823:    CUM is a variable of type CUMULATIVE_ARGS which gives info about
        !           824:     the preceding args and about the function being called.
        !           825:    NAMED is nonzero if this argument is a named parameter
        !           826:     (otherwise it is an extra parameter matching an ellipsis).
        !           827: 
        !           828:    On 29k the first 16 words of args are normally in registers
        !           829:    and the rest are pushed.  */
        !           830: 
        !           831: #define FUNCTION_ARG(CUM, MODE, TYPE, NAMED)                   \
        !           832: ((CUM) < 16 && (NAMED) && ! MUST_PASS_IN_STACK (MODE, TYPE)    \
        !           833:  ? gen_rtx(REG, (MODE), R_LR (2) + (CUM)) : 0)
        !           834: 
        !           835: /* Define where a function finds its arguments.
        !           836:    This is different from FUNCTION_ARG because of register windows.
        !           837: 
        !           838:    On the 29k, we hack this to call a function that sets the used registers
        !           839:    as non-fixed and not used by calls.  */
        !           840: 
        !           841: #define FUNCTION_INCOMING_ARG(CUM, MODE, TYPE, NAMED)                  \
        !           842: ((CUM) < 16 && (NAMED) && ! MUST_PASS_IN_STACK (MODE, TYPE)            \
        !           843:  ? gen_rtx (REG, MODE,                                                 \
        !           844:            incoming_reg (CUM, A29K_ARG_SIZE (MODE, TYPE, NAMED)))      \
        !           845:  : 0)
        !           846: 
        !           847: /* This indicates that an argument is to be passed with an invisible reference
        !           848:    (i.e., a pointer to the object is passed).
        !           849: 
        !           850:    On the 29k, we do this if it must be passed on the stack.  */
        !           851: 
        !           852: #define FUNCTION_ARG_PASS_BY_REFERENCE(CUM, MODE, TYPE, NAMED) \
        !           853:   (MUST_PASS_IN_STACK (MODE, TYPE))
        !           854: 
        !           855: /* Specify the padding direction of arguments.
        !           856: 
        !           857:    On the 29k, we must pad upwards in order to be able to pass args in
        !           858:    registers.  */
        !           859: 
        !           860: #define FUNCTION_ARG_PADDING(MODE, TYPE)       upward
        !           861: 
        !           862: /* For an arg passed partly in registers and partly in memory,
        !           863:    this is the number of registers used.
        !           864:    For args passed entirely in registers or entirely in memory, zero.  */
        !           865: 
        !           866: #define FUNCTION_ARG_PARTIAL_NREGS(CUM, MODE, TYPE, NAMED)             \
        !           867: ((CUM) < 16 && 16 < (CUM) + A29K_ARG_SIZE (MODE, TYPE, NAMED) && (NAMED) \
        !           868:  ? 16 - (CUM) : 0)
        !           869: 
        !           870: /* Perform any needed actions needed for a function that is receiving a
        !           871:    variable number of arguments. 
        !           872: 
        !           873:    CUM is as above.
        !           874: 
        !           875:    MODE and TYPE are the mode and type of the current parameter.
        !           876: 
        !           877:    PRETEND_SIZE is a variable that should be set to the amount of stack
        !           878:    that must be pushed by the prolog to pretend that our caller pushed
        !           879:    it.
        !           880: 
        !           881:    Normally, this macro will push all remaining incoming registers on the
        !           882:    stack and set PRETEND_SIZE to the length of the registers pushed.  */
        !           883: 
        !           884: #define SETUP_INCOMING_VARARGS(CUM,MODE,TYPE,PRETEND_SIZE,NO_RTL) \
        !           885: { if ((CUM) < 16)                                                      \
        !           886:     {                                                                  \
        !           887:       int first_reg_offset = (CUM);                                    \
        !           888:                                                                        \
        !           889:       if (MUST_PASS_IN_STACK (MODE, TYPE))                             \
        !           890:        first_reg_offset += A29K_ARG_SIZE (TYPE_MODE (TYPE), TYPE, 1);  \
        !           891:                                                                        \
        !           892:       if (first_reg_offset > 16)                                       \
        !           893:        first_reg_offset = 16;                                          \
        !           894:                                                                        \
        !           895:       if (! (NO_RTL) && first_reg_offset != 16)                                \
        !           896:        move_block_from_reg                                             \
        !           897:          (R_AR (0) + first_reg_offset,                                 \
        !           898:           gen_rtx (MEM, BLKmode, virtual_incoming_args_rtx),           \
        !           899:           16 - first_reg_offset, (16 - first_reg_offset) * UNITS_PER_WORD); \
        !           900:       PRETEND_SIZE = (16 - first_reg_offset) * UNITS_PER_WORD;         \
        !           901:     }                                                                  \
        !           902: }
        !           903: 
        !           904: /* Define the information needed to generate branch and scc insns.  This is
        !           905:    stored from the compare operation.  Note that we can't use "rtx" here
        !           906:    since it hasn't been defined!  */
        !           907: 
        !           908: extern struct rtx_def *a29k_compare_op0, *a29k_compare_op1;
        !           909: extern int a29k_compare_fp_p;
        !           910: 
        !           911: /* This macro produces the initial definition of a function name.
        !           912: 
        !           913:    For the 29k, we need the prolog to contain one or two words prior to
        !           914:    the declaration of the function name.  So just store away the name and
        !           915:    write it as part of the prolog.  */
        !           916: 
        !           917: extern char *a29k_function_name;
        !           918: 
        !           919: #define ASM_DECLARE_FUNCTION_NAME(FILE,NAME,DECL)      \
        !           920:   a29k_function_name = NAME;
        !           921: 
        !           922: /* This macro generates the assembly code for function entry.
        !           923:    FILE is a stdio stream to output the code to.
        !           924:    SIZE is an int: how many units of temporary storage to allocate.
        !           925:    Refer to the array `regs_ever_live' to determine which registers
        !           926:    to save; `regs_ever_live[I]' is nonzero if register number I
        !           927:    is ever used in the function.  This macro is responsible for
        !           928:    knowing which registers should not be saved even if used.  */
        !           929: 
        !           930: #define FUNCTION_PROLOGUE(FILE, SIZE)  output_prolog (FILE, SIZE)
        !           931: 
        !           932: /* Output assembler code to FILE to increment profiler label # LABELNO
        !           933:    for profiling a function entry.  */
        !           934: 
        !           935: #define FUNCTION_PROFILER(FILE, LABELNO)
        !           936: 
        !           937: /* EXIT_IGNORE_STACK should be nonzero if, when returning from a function,
        !           938:    the stack pointer does not matter.  The value is tested only in
        !           939:    functions that have frame pointers.
        !           940:    No definition is equivalent to always zero.  */
        !           941: 
        !           942: #define EXIT_IGNORE_STACK 1
        !           943: 
        !           944: /* This macro generates the assembly code for function exit,
        !           945:    on machines that need it.  If FUNCTION_EPILOGUE is not defined
        !           946:    then individual return instructions are generated for each
        !           947:    return statement.  Args are same as for FUNCTION_PROLOGUE.
        !           948: 
        !           949:    The function epilogue should not depend on the current stack pointer!
        !           950:    It should use the frame pointer only.  This is mandatory because
        !           951:    of alloca; we also take advantage of it to omit stack adjustments
        !           952:    before returning.  */
        !           953: 
        !           954: #define FUNCTION_EPILOGUE(FILE, SIZE)  output_epilog (FILE, SIZE)
        !           955: 
        !           956: /* Define the number of delay slots needed for the function epilogue.
        !           957: 
        !           958:    On the 29k, we need a slot except when we have a register stack adjustment,
        !           959:    have a memory stack adjustment, and have no frame pointer.  */
        !           960: 
        !           961: #define DELAY_SLOTS_FOR_EPILOGUE                                       \
        !           962:   (! (needs_regstack_p ()                                              \
        !           963:       && (get_frame_size () + current_function_pretend_args_size       \
        !           964:           + current_function_outgoing_args_size) != 0                  \
        !           965:       && ! frame_pointer_needed))
        !           966: 
        !           967: /* Define whether INSN can be placed in delay slot N for the epilogue.
        !           968: 
        !           969:    On the 29k, we must be able to place it in a delay slot, it must
        !           970:    not use sp if the frame pointer cannot be eliminated, and it cannot
        !           971:    use local regs if we need to push the register stack.  */
        !           972: 
        !           973: #define ELIGIBLE_FOR_EPILOGUE_DELAY(INSN,N)                            \
        !           974:   (get_attr_in_delay_slot (INSN) == IN_DELAY_SLOT_YES                  \
        !           975:    && ! (frame_pointer_needed                                          \
        !           976:         && reg_mentioned_p (stack_pointer_rtx, PATTERN (INSN)))        \
        !           977:    && ! (needs_regstack_p () && uses_local_reg_p (PATTERN (INSN))))
        !           978: 
        !           979: /* Output assembler code for a block containing the constant parts
        !           980:    of a trampoline, leaving space for the variable parts.
        !           981: 
        !           982:    The trampoline should set the static chain pointer to value placed
        !           983:    into the trampoline and should branch to the specified routine.  We
        !           984:    use gr121 (tav) as a temporary.  */
        !           985: 
        !           986: #define TRAMPOLINE_TEMPLATE(FILE)                      \
        !           987: {                                                      \
        !           988:   fprintf (FILE, "\tconst %s,0\n", reg_names[R_TAV]);  \
        !           989:   fprintf (FILE, "\tconsth %s,0\n", reg_names[R_TAV]); \
        !           990:   fprintf (FILE, "\tconst %s,0\n", reg_names[R_SLP]);  \
        !           991:   fprintf (FILE, "\tjmpi %s\n", reg_names[R_TAV]);     \
        !           992:   fprintf (FILE, "\tconsth %s,0\n", reg_names[R_SLP]); \
        !           993: }
        !           994: 
        !           995: /* Length in units of the trampoline for entering a nested function.  */
        !           996: 
        !           997: #define TRAMPOLINE_SIZE    20
        !           998: 
        !           999: /* Emit RTL insns to initialize the variable parts of a trampoline.
        !          1000:    FNADDR is an RTX for the address of the function's pure code.
        !          1001:    CXT is an RTX for the static chain value for the function.
        !          1002: 
        !          1003:    We do this on the 29k by writing the bytes of the addresses into the
        !          1004:    trampoline one byte at a time.  */
        !          1005: 
        !          1006: #define INITIALIZE_TRAMPOLINE(TRAMP, FNADDR, CXT)                      \
        !          1007: {                                                                      \
        !          1008:   INITIALIZE_TRAMPOLINE_VALUE (TRAMP, FNADDR, 0, 4);                   \
        !          1009:   INITIALIZE_TRAMPOLINE_VALUE (TRAMP, CXT, 8, 16);                     \
        !          1010: }
        !          1011: 
        !          1012: /* Define a sub-macro to initialize one value into the trampoline.
        !          1013:    We specify the offsets of the CONST and CONSTH instructions, respectively
        !          1014:    and copy the value a byte at a time into these instructions.  */
        !          1015: 
        !          1016: #define INITIALIZE_TRAMPOLINE_VALUE(TRAMP, VALUE, CONST, CONSTH)       \
        !          1017: {                                                                      \
        !          1018:   rtx _addr, _temp;                                                    \
        !          1019:   rtx _val = force_reg (SImode, VALUE);                                        \
        !          1020:                                                                        \
        !          1021:   _addr = memory_address (QImode, plus_constant (TRAMP, (CONST) + 3)); \
        !          1022:   emit_move_insn (gen_rtx (MEM, QImode, _addr),                                \
        !          1023:                  gen_lowpart (QImode, _val));                          \
        !          1024:                                                                        \
        !          1025:   _temp = expand_shift (RSHIFT_EXPR, SImode, _val,                     \
        !          1026:                       build_int_2 (8, 0), 0, 1);                       \
        !          1027:   _addr = memory_address (QImode, plus_constant (TRAMP, (CONST) + 1)); \
        !          1028:   emit_move_insn (gen_rtx (MEM, QImode, _addr),                                \
        !          1029:                  gen_lowpart (QImode, _temp));                         \
        !          1030:                                                                        \
        !          1031:   _temp = expand_shift (RSHIFT_EXPR, SImode, _temp,                    \
        !          1032:                       build_int_2 (8, 0), _temp, 1);                   \
        !          1033:   _addr = memory_address (QImode, plus_constant (TRAMP, (CONSTH) + 3));        \
        !          1034:   emit_move_insn (gen_rtx (MEM, QImode, _addr),                                \
        !          1035:                  gen_lowpart (QImode, _temp));                         \
        !          1036:                                                                        \
        !          1037:   _temp = expand_shift (RSHIFT_EXPR, SImode, _temp,                    \
        !          1038:                       build_int_2 (8, 0), _temp, 1);                   \
        !          1039:   _addr = memory_address (QImode, plus_constant (TRAMP, (CONSTH) + 1));        \
        !          1040:   emit_move_insn (gen_rtx (MEM, QImode, _addr),                                \
        !          1041:                  gen_lowpart (QImode, _temp));                         \
        !          1042: }
        !          1043: 
        !          1044: /* Addressing modes, and classification of registers for them.  */
        !          1045: 
        !          1046: /* #define HAVE_POST_INCREMENT */
        !          1047: /* #define HAVE_POST_DECREMENT */
        !          1048: 
        !          1049: /* #define HAVE_PRE_DECREMENT */
        !          1050: /* #define HAVE_PRE_INCREMENT */
        !          1051: 
        !          1052: /* Macros to check register numbers against specific register classes.  */
        !          1053: 
        !          1054: /* These assume that REGNO is a hard or pseudo reg number.
        !          1055:    They give nonzero only if REGNO is a hard reg of the suitable class
        !          1056:    or a pseudo reg currently allocated to a suitable hard reg.
        !          1057:    Since they use reg_renumber, they are safe only once reg_renumber
        !          1058:    has been allocated, which happens in local-alloc.c.  */
        !          1059: 
        !          1060: #define REGNO_OK_FOR_INDEX_P(REGNO) 0
        !          1061: #define REGNO_OK_FOR_BASE_P(REGNO) 1
        !          1062: 
        !          1063: /* Given the value returned from get_frame_size, compute the actual size
        !          1064:    of the frame we will allocate.   We include the pretend and outgoing
        !          1065:    arg sizes and round to a doubleword.  */
        !          1066: 
        !          1067: #define ACTUAL_FRAME_SIZE(SIZE)                                \
        !          1068:   (((SIZE) + current_function_pretend_args_size                \
        !          1069:     + current_function_outgoing_args_size + 7) & ~7)
        !          1070: 
        !          1071: /* Define the initial offset between the frame and stack pointer.  */
        !          1072: 
        !          1073: #define INITIAL_FRAME_POINTER_OFFSET(DEPTH)    \
        !          1074:   (DEPTH) = ACTUAL_FRAME_SIZE (get_frame_size ())
        !          1075: 
        !          1076: /* Maximum number of registers that can appear in a valid memory address.  */
        !          1077: #define MAX_REGS_PER_ADDRESS 1
        !          1078: 
        !          1079: /* Recognize any constant value that is a valid address.
        !          1080: 
        !          1081:    None are on the 29K.  */
        !          1082: #define CONSTANT_ADDRESS_P(X)  0
        !          1083: 
        !          1084: /* Include all constant integers and constant doubles */
        !          1085: #define LEGITIMATE_CONSTANT_P(X)       1
        !          1086: 
        !          1087: /* The macros REG_OK_FOR..._P assume that the arg is a REG rtx
        !          1088:    and check its validity for a certain class.
        !          1089:    We have two alternate definitions for each of them.
        !          1090:    The usual definition accepts all pseudo regs; the other rejects
        !          1091:    them unless they have been allocated suitable hard regs.
        !          1092:    The symbol REG_OK_STRICT causes the latter definition to be used.
        !          1093: 
        !          1094:    Most source files want to accept pseudo regs in the hope that
        !          1095:    they will get allocated to the class that the insn wants them to be in.
        !          1096:    Source files for reload pass need to be strict.
        !          1097:    After reload, it makes no difference, since pseudo regs have
        !          1098:    been eliminated by then.  */
        !          1099: 
        !          1100: #ifndef REG_OK_STRICT
        !          1101: 
        !          1102: /* Nonzero if X is a hard reg that can be used as an index
        !          1103:    or if it is a pseudo reg.  */
        !          1104: #define REG_OK_FOR_INDEX_P(X) 0
        !          1105: /* Nonzero if X is a hard reg that can be used as a base reg
        !          1106:    or if it is a pseudo reg.  */
        !          1107: #define REG_OK_FOR_BASE_P(X)  1
        !          1108: 
        !          1109: #else
        !          1110: 
        !          1111: /* Nonzero if X is a hard reg that can be used as an index.  */
        !          1112: #define REG_OK_FOR_INDEX_P(X) REGNO_OK_FOR_INDEX_P (REGNO (X))
        !          1113: /* Nonzero if X is a hard reg that can be used as a base reg.  */
        !          1114: #define REG_OK_FOR_BASE_P(X) REGNO_OK_FOR_BASE_P (REGNO (X))
        !          1115: 
        !          1116: #endif
        !          1117: 
        !          1118: /* GO_IF_LEGITIMATE_ADDRESS recognizes an RTL expression
        !          1119:    that is a valid memory address for an instruction.
        !          1120:    The MODE argument is the machine mode for the MEM expression
        !          1121:    that wants to use this address.
        !          1122: 
        !          1123:    On the 29k, a legitimate address is a register and so is a
        !          1124:    constant of less than 256.  */
        !          1125: 
        !          1126: #define GO_IF_LEGITIMATE_ADDRESS(MODE, X, ADDR)  \
        !          1127: { if (REG_P (X) && REG_OK_FOR_BASE_P (X))      \
        !          1128:     goto ADDR;                                 \
        !          1129:   if (GET_CODE (X) == CONST_INT                        \
        !          1130:       && (unsigned) INTVAL (X) < 0x100)                \
        !          1131:     goto ADDR;                                 \
        !          1132: }
        !          1133: 
        !          1134: /* Try machine-dependent ways of modifying an illegitimate address
        !          1135:    to be legitimate.  If we find one, return the new, valid address.
        !          1136:    This macro is used in only one place: `memory_address' in explow.c.
        !          1137: 
        !          1138:    OLDX is the address as it was before break_out_memory_refs was called.
        !          1139:    In some cases it is useful to look at this to decide what needs to be done.
        !          1140: 
        !          1141:    MODE and WIN are passed so that this macro can use
        !          1142:    GO_IF_LEGITIMATE_ADDRESS.
        !          1143: 
        !          1144:    It is always safe for this macro to do nothing.  It exists to recognize
        !          1145:    opportunities to optimize the output.
        !          1146: 
        !          1147:    For the 29k, we need not do anything.  However, if we don't,
        !          1148:    `memory_address' will try lots of things to get a valid address, most of
        !          1149:    which will result in dead code and extra pseudos.  So we make the address
        !          1150:    valid here.
        !          1151: 
        !          1152:    This is easy:  The only valid addresses are an offset from a register
        !          1153:    and we know the address isn't valid.  So just call either `force_operand'
        !          1154:    or `force_reg' unless this is a (plus (reg ...) (const_int 0)).  */
        !          1155: 
        !          1156: #define LEGITIMIZE_ADDRESS(X,OLDX,MODE,WIN)                    \
        !          1157: { if (GET_CODE (X) == PLUS && XEXP (X, 1) == const0_rtx)       \
        !          1158:     X = XEXP (x, 0);                                           \
        !          1159:   if (GET_CODE (X) == MULT || GET_CODE (X) == PLUS)            \
        !          1160:     X = force_operand (X, 0);                                  \
        !          1161:   else                                                         \
        !          1162:     X = force_reg (Pmode, X);                                  \
        !          1163:   goto WIN;                                                    \
        !          1164: }
        !          1165: 
        !          1166: /* Go to LABEL if ADDR (a legitimate address expression)
        !          1167:    has an effect that depends on the machine mode it is used for.
        !          1168:    On the 29k this is never true.  */
        !          1169: 
        !          1170: #define GO_IF_MODE_DEPENDENT_ADDRESS(ADDR,LABEL)
        !          1171: 
        !          1172: /* Compute the cost of an address.  For the 29k, all valid addresses are
        !          1173:    the same cost.  */
        !          1174: 
        !          1175: #define ADDRESS_COST(X)  0
        !          1176: 
        !          1177: /* Define this if some processing needs to be done immediately before
        !          1178:    emitting code for an insn.  */
        !          1179: 
        !          1180: /* #define FINAL_PRESCAN_INSN(INSN,OPERANDS,NOPERANDS) */
        !          1181: 
        !          1182: /* Specify the machine mode that this machine uses
        !          1183:    for the index in the tablejump instruction.  */
        !          1184: #define CASE_VECTOR_MODE SImode
        !          1185: 
        !          1186: /* Define this if the tablejump instruction expects the table
        !          1187:    to contain offsets from the address of the table.
        !          1188:    Do not define this if the table should contain absolute addresses.  */
        !          1189: /* #define CASE_VECTOR_PC_RELATIVE */
        !          1190: 
        !          1191: /* Specify the tree operation to be used to convert reals to integers.  */
        !          1192: #define IMPLICIT_FIX_EXPR FIX_ROUND_EXPR
        !          1193: 
        !          1194: /* This is the kind of divide that is easiest to do in the general case.  */
        !          1195: #define EASY_DIV_EXPR TRUNC_DIV_EXPR
        !          1196: 
        !          1197: /* Define this as 1 if `char' should by default be signed; else as 0.  */
        !          1198: #define DEFAULT_SIGNED_CHAR 0
        !          1199: 
        !          1200: /* This flag, if defined, says the same insns that convert to a signed fixnum
        !          1201:    also convert validly to an unsigned one.
        !          1202: 
        !          1203:    We actually lie a bit here as overflow conditions are different.  But
        !          1204:    they aren't being checked anyway.  */
        !          1205: 
        !          1206: #define FIXUNS_TRUNC_LIKE_FIX_TRUNC
        !          1207: 
        !          1208: /* Max number of bytes we can move to of from memory
        !          1209:    in one reasonably fast instruction.
        !          1210: 
        !          1211:    For the 29k, we will define movti, so put this at 4 words.  */
        !          1212: #define MOVE_MAX 16
        !          1213: 
        !          1214: /* Largest number of bytes of an object that can be placed in a register.
        !          1215:    On the 29k we have plenty of registers, so use TImode.  */
        !          1216: #define MAX_FIXED_MODE_SIZE    GET_MODE_BITSIZE (TImode)
        !          1217: 
        !          1218: /* Nonzero if access to memory by bytes is no faster than for words.
        !          1219:    Also non-zero if doing byte operations (specifically shifts) in registers
        !          1220:    is undesirable. 
        !          1221: 
        !          1222:    On the 29k, large masks are expensive, so we want to use bytes to
        !          1223:    manipulate fields.  */
        !          1224: #define SLOW_BYTE_ACCESS       0
        !          1225: 
        !          1226: /* Define if operations between registers always perform the operation
        !          1227:    on the full register even if a narrower mode is specified.  */
        !          1228: #define WORD_REGISTER_OPERATIONS
        !          1229: 
        !          1230: /* Define if loading in MODE, an integral mode narrower than BITS_PER_WORD
        !          1231:    will either zero-extend or sign-extend.  The value of this macro should
        !          1232:    be the code that says which one of the two operations is implicitly
        !          1233:    done, NIL if none.  */
        !          1234: #define LOAD_EXTEND_OP(MODE) ZERO_EXTEND
        !          1235: 
        !          1236: /* Define if the object format being used is COFF or a superset.  */
        !          1237: #define OBJECT_FORMAT_COFF
        !          1238: 
        !          1239: /* This uses COFF, so it wants SDB format.  */
        !          1240: #define SDB_DEBUGGING_INFO
        !          1241: 
        !          1242: /* Define this to be the delimiter between SDB sub-sections.  The default
        !          1243:    is ";".  */
        !          1244: #define SDB_DELIM      "\n"
        !          1245: 
        !          1246: /* Do not break .stabs pseudos into continuations.  */
        !          1247: #define DBX_CONTIN_LENGTH 0
        !          1248: 
        !          1249: /* Don't try to use the `x' type-cross-reference character in DBX data.
        !          1250:    Also has the consequence of putting each struct, union or enum
        !          1251:    into a separate .stabs, containing only cross-refs to the others.  */
        !          1252: #define DBX_NO_XREFS
        !          1253: 
        !          1254: /* Value is 1 if truncating an integer of INPREC bits to OUTPREC bits
        !          1255:    is done just by pretending it is already truncated.  */
        !          1256: #define TRULY_NOOP_TRUNCATION(OUTPREC, INPREC) 1
        !          1257: 
        !          1258: /* We assume that the store-condition-codes instructions store 0 for false
        !          1259:    and some other value for true.  This is the value stored for true.  */
        !          1260: 
        !          1261: #define STORE_FLAG_VALUE 0x80000000
        !          1262: 
        !          1263: /* Specify the machine mode that pointers have.
        !          1264:    After generation of rtl, the compiler makes no further distinction
        !          1265:    between pointers and any other objects of this machine mode.  */
        !          1266: #define Pmode SImode
        !          1267: 
        !          1268: /* Mode of a function address in a call instruction (for indexing purposes).
        !          1269: 
        !          1270:    Doesn't matter on 29k.  */
        !          1271: #define FUNCTION_MODE SImode
        !          1272: 
        !          1273: /* Define this if addresses of constant functions
        !          1274:    shouldn't be put through pseudo regs where they can be cse'd.
        !          1275:    Desirable on machines where ordinary constants are expensive
        !          1276:    but a CALL with constant address is cheap.  */
        !          1277: #define NO_FUNCTION_CSE
        !          1278: 
        !          1279: /* Define this to be nonzero if shift instructions ignore all but the low-order
        !          1280:    few bits. */
        !          1281: #define SHIFT_COUNT_TRUNCATED 1
        !          1282: 
        !          1283: /* Compute the cost of computing a constant rtl expression RTX
        !          1284:    whose rtx-code is CODE.  The body of this macro is a portion
        !          1285:    of a switch statement.  If the code is computed here,
        !          1286:    return it with a return statement.  Otherwise, break from the switch.
        !          1287: 
        !          1288:    We only care about the cost if it is valid in an insn.  The only
        !          1289:    constants that cause an insn to generate more than one machine
        !          1290:    instruction are those involving floating-point or address.  So 
        !          1291:    only these need be expensive.  */
        !          1292: 
        !          1293: #define CONST_COSTS(RTX,CODE,OUTER_CODE) \
        !          1294:   case CONST_INT:                                              \
        !          1295:     return 0;                                                  \
        !          1296:   case CONST:                                                  \
        !          1297:   case LABEL_REF:                                              \
        !          1298:   case SYMBOL_REF:                                             \
        !          1299:     return 6;                                                  \
        !          1300:   case CONST_DOUBLE:                                           \
        !          1301:     return GET_MODE (RTX) == SFmode ? 6 : 8;
        !          1302:     
        !          1303: /* Provide the costs of a rtl expression.  This is in the body of a
        !          1304:    switch on CODE.
        !          1305: 
        !          1306:    All MEMs cost the same if they are valid.  This is used to ensure
        !          1307:    that (mem (symbol_ref ...)) is placed into a CALL when valid.
        !          1308: 
        !          1309:    The multiply cost depends on whether this is a 29050 or not.  */
        !          1310: 
        !          1311: #define RTX_COSTS(X,CODE,OUTER_CODE)                   \
        !          1312:   case MULT:                                           \
        !          1313:     return TARGET_29050 ? COSTS_N_INSNS (2) : COSTS_N_INSNS (40);  \
        !          1314:   case DIV:                                            \
        !          1315:   case UDIV:                                           \
        !          1316:   case MOD:                                            \
        !          1317:   case UMOD:                                           \
        !          1318:     return COSTS_N_INSNS (50);                         \
        !          1319:   case MEM:                                            \
        !          1320:     return COSTS_N_INSNS (2);
        !          1321: 
        !          1322: /* Control the assembler format that we output.  */
        !          1323: 
        !          1324: /* Output at beginning of assembler file.  */
        !          1325: 
        !          1326: #define ASM_FILE_START(FILE)                                   \
        !          1327: { char *p, *after_dir = main_input_filename;                   \
        !          1328:   if (TARGET_29050)                                            \
        !          1329:     fprintf (FILE, "\t.cputype 29050\n");                      \
        !          1330:   for (p = main_input_filename; *p; p++)                       \
        !          1331:     if (*p == '/')                                             \
        !          1332:       after_dir = p + 1;                                       \
        !          1333:   fprintf (FILE, "\t.file ");                                  \
        !          1334:   output_quoted_string (FILE, after_dir);                      \
        !          1335:   fprintf (FILE, "\n");                                                \
        !          1336:   fprintf (FILE, "\t.sect .lit,lit\n"); }
        !          1337: 
        !          1338: /* Output to assembler file text saying following lines
        !          1339:    may contain character constants, extra white space, comments, etc.  */
        !          1340: 
        !          1341: #define ASM_APP_ON ""
        !          1342: 
        !          1343: /* Output to assembler file text saying following lines
        !          1344:    no longer contain unusual constructs.  */
        !          1345: 
        !          1346: #define ASM_APP_OFF ""
        !          1347: 
        !          1348: /* The next few macros don't have tabs on most machines, but
        !          1349:    at least one 29K assembler wants them.  */
        !          1350: 
        !          1351: /* Output before instructions.  */
        !          1352: 
        !          1353: #define TEXT_SECTION_ASM_OP "\t.text"
        !          1354: 
        !          1355: /* Output before read-only data.  */
        !          1356: 
        !          1357: #define READONLY_DATA_SECTION_ASM_OP "\t.use .lit"
        !          1358: 
        !          1359: /* Output before writable data.  */
        !          1360: 
        !          1361: #define DATA_SECTION_ASM_OP "\t.data"
        !          1362: 
        !          1363: /* Define an extra section for read-only data, a routine to enter it, and
        !          1364:    indicate that it is for read-only data.  */
        !          1365: 
        !          1366: #define EXTRA_SECTIONS readonly_data
        !          1367: 
        !          1368: #define EXTRA_SECTION_FUNCTIONS                                        \
        !          1369: void                                                           \
        !          1370: literal_section ()                                             \
        !          1371: {                                                              \
        !          1372:   if (in_section != readonly_data)                             \
        !          1373:     {                                                          \
        !          1374:       fprintf (asm_out_file, "%s\n", READONLY_DATA_SECTION_ASM_OP); \
        !          1375:       in_section = readonly_data;                              \
        !          1376:     }                                                          \
        !          1377: }                                                              \
        !          1378: 
        !          1379: #define READONLY_DATA_SECTION  literal_section
        !          1380: 
        !          1381: /* If we are referencing a function that is static or is known to be
        !          1382:    in this file, make the SYMBOL_REF special.  We can use this to indicate
        !          1383:    that we can branch to this function without emitting a no-op after the
        !          1384:    call.  */
        !          1385: 
        !          1386: #define ENCODE_SECTION_INFO(DECL)  \
        !          1387:   if (TREE_CODE (DECL) == FUNCTION_DECL                        \
        !          1388:       && (TREE_ASM_WRITTEN (DECL) || ! TREE_PUBLIC (DECL))) \
        !          1389:     SYMBOL_REF_FLAG (XEXP (DECL_RTL (DECL), 0)) = 1;
        !          1390: 
        !          1391: /* How to refer to registers in assembler output.
        !          1392:    This sequence is indexed by compiler's hard-register-number (see above).  */
        !          1393: 
        !          1394: #define REGISTER_NAMES \
        !          1395: {"gr96", "gr97", "gr98", "gr99", "gr100", "gr101", "gr102", "gr103", "gr104", \
        !          1396:  "gr105", "gr106", "gr107", "gr108", "gr109", "gr110", "gr111", "gr112", \
        !          1397:  "gr113", "gr114", "gr115", "gr116", "gr117", "gr118", "gr119", "gr120", \
        !          1398:  "gr121", "gr122", "gr123", "gr124", "gr125", "gr126", "gr127",                 \
        !          1399:  "lr0", "lr1", "lr2", "lr3", "lr4", "lr5", "lr6", "lr7", "lr8", "lr9",   \
        !          1400:  "lr10", "lr11", "lr12", "lr13", "lr14", "lr15", "lr16", "lr17", "lr18", \
        !          1401:  "lr19", "lr20", "lr21", "lr22", "lr23", "lr24", "lr25", "lr26", "lr27", \
        !          1402:  "lr28", "lr29", "lr30", "lr31", "lr32", "lr33", "lr34", "lr35", "lr36", \
        !          1403:  "lr37", "lr38", "lr39", "lr40", "lr41", "lr42", "lr43", "lr44", "lr45", \
        !          1404:  "lr46", "lr47", "lr48", "lr49", "lr50", "lr51", "lr52", "lr53", "lr54", \
        !          1405:  "lr55", "lr56", "lr57", "lr58", "lr59", "lr60", "lr61", "lr62", "lr63", \
        !          1406:  "lr64", "lr65", "lr66", "lr67", "lr68", "lr69", "lr70", "lr71", "lr72", \
        !          1407:  "lr73", "lr74", "lr75", "lr76", "lr77", "lr78", "lr79", "lr80", "lr81", \
        !          1408:  "lr82", "lr83", "lr84", "lr85", "lr86", "lr87", "lr88", "lr89", "lr90", \
        !          1409:  "lr91", "lr92", "lr93", "lr94", "lr95", "lr96", "lr97", "lr98", "lr99", \
        !          1410:  "lr100", "lr101", "lr102", "lr103", "lr104", "lr105", "lr106", "lr107", \
        !          1411:  "lr108", "lr109", "lr110", "lr111", "lr112", "lr113", "lr114", "lr115", \
        !          1412:  "lr116", "lr117", "lr118", "lr119", "lr120", "lr121", "lr122", "lr123", \
        !          1413:  "lr124", "lr125", "lr126", "lr127",                                    \
        !          1414:   "AI0", "AI1", "AI2", "AI3", "AI4", "AI5", "AI6", "AI7", "AI8", "AI9",  \
        !          1415:   "AI10", "AI11", "AI12", "AI13", "AI14", "AI15", "FP",                         \
        !          1416:   "bp", "fc", "cr", "q",                                                \
        !          1417:   "vab", "ops", "cps", "cfg", "cha", "chd", "chc", "rbp", "tmc", "tmr",         \
        !          1418:   "pc0", "pc1", "pc2", "mmu", "lru", "fpe", "int", "fps", "exo",        \
        !          1419:   "0", "1", "2", "3",                                                   \
        !          1420:   "gr64", "gr65", "gr66", "gr67", "gr68", "gr69", "gr70", "gr71",       \
        !          1421:   "gr72", "gr73", "gr74", "gr75", "gr76", "gr77", "gr78", "gr79",       \
        !          1422:   "gr80", "gr81", "gr82", "gr83", "gr84", "gr85", "gr86", "gr87",       \
        !          1423:   "gr88", "gr89", "gr90", "gr91", "gr92", "gr93", "gr94", "gr95" }
        !          1424: 
        !          1425: /* How to renumber registers for dbx and gdb.  */
        !          1426: 
        !          1427: extern int a29k_debug_reg_map[];
        !          1428: #define DBX_REGISTER_NUMBER(REGNO) a29k_debug_reg_map[REGNO]
        !          1429: 
        !          1430: /* This is how to output the definition of a user-level label named NAME,
        !          1431:    such as the label on a static function or variable NAME.  */
        !          1432: 
        !          1433: #define ASM_OUTPUT_LABEL(FILE,NAME)    \
        !          1434:   do { assemble_name (FILE, NAME); fputs (":\n", FILE); } while (0)
        !          1435: 
        !          1436: /* This is how to output a command to make the user-level label named NAME
        !          1437:    defined for reference from other files.  */
        !          1438: 
        !          1439: #define ASM_GLOBALIZE_LABEL(FILE,NAME) \
        !          1440:   do { fputs ("\t.global ", FILE); assemble_name (FILE, NAME); fputs ("\n", FILE);} while (0)
        !          1441: 
        !          1442: /* This is how to output a reference to a user-level label named NAME.
        !          1443:    `assemble_name' uses this.  */
        !          1444: 
        !          1445: #define ASM_OUTPUT_LABELREF(FILE,NAME) \
        !          1446:   fprintf (FILE, "_%s", NAME)
        !          1447: 
        !          1448: /* This is how to output an internal numbered label where
        !          1449:    PREFIX is the class of label and NUM is the number within the class.  */
        !          1450: 
        !          1451: #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM)     \
        !          1452:   fprintf (FILE, "%s%d:\n", PREFIX, NUM)
        !          1453: 
        !          1454: /* This is how to output a label for a jump table.  Arguments are the same as
        !          1455:    for ASM_OUTPUT_INTERNAL_LABEL, except the insn for the jump table is
        !          1456:    passed. */
        !          1457: 
        !          1458: #define ASM_OUTPUT_CASE_LABEL(FILE,PREFIX,NUM,TABLEINSN)       \
        !          1459: { ASM_OUTPUT_ALIGN (FILE, 2); ASM_OUTPUT_INTERNAL_LABEL (FILE, PREFIX, NUM); }
        !          1460: 
        !          1461: /* This is how to store into the string LABEL
        !          1462:    the symbol_ref name of an internal numbered label where
        !          1463:    PREFIX is the class of label and NUM is the number within the class.
        !          1464:    This is suitable for output with `assemble_name'.  */
        !          1465: 
        !          1466: #define ASM_GENERATE_INTERNAL_LABEL(LABEL,PREFIX,NUM)  \
        !          1467:   sprintf (LABEL, "*%s%d", PREFIX, NUM)
        !          1468: 
        !          1469: /* This is how to output an assembler line defining a `double' constant.  */
        !          1470: 
        !          1471: #define ASM_OUTPUT_DOUBLE(FILE,VALUE)          \
        !          1472:   fprintf (FILE, "\t.double %.20e\n", (VALUE))
        !          1473: 
        !          1474: /* This is how to output an assembler line defining a `float' constant.  */
        !          1475: 
        !          1476: #define ASM_OUTPUT_FLOAT(FILE,VALUE)           \
        !          1477:   fprintf (FILE, "\t.float %.20e\n", (VALUE))
        !          1478: 
        !          1479: /* This is how to output an assembler line defining an `int' constant.  */
        !          1480: 
        !          1481: #define ASM_OUTPUT_INT(FILE,VALUE)  \
        !          1482: ( fprintf (FILE, "\t.word "),                  \
        !          1483:   output_addr_const (FILE, (VALUE)),           \
        !          1484:   fprintf (FILE, "\n"))
        !          1485: 
        !          1486: /* Likewise for `char' and `short' constants.  */
        !          1487: 
        !          1488: #define ASM_OUTPUT_SHORT(FILE,VALUE)  \
        !          1489: ( fprintf (FILE, "\t.hword "),                 \
        !          1490:   output_addr_const (FILE, (VALUE)),           \
        !          1491:   fprintf (FILE, "\n"))
        !          1492: 
        !          1493: #define ASM_OUTPUT_CHAR(FILE,VALUE)  \
        !          1494: ( fprintf (FILE, "\t.byte "),                  \
        !          1495:   output_addr_const (FILE, (VALUE)),           \
        !          1496:   fprintf (FILE, "\n"))
        !          1497: 
        !          1498: /* This is how to output an insn to push a register on the stack.
        !          1499:    It need not be very fast code.  */
        !          1500: 
        !          1501: #define ASM_OUTPUT_REG_PUSH(FILE,REGNO)                                        \
        !          1502:   fprintf (FILE, "\tsub %s,%s,4\n\tstore 0,0,%s,%s\n",                 \
        !          1503:            reg_names[R_MSP], reg_names[R_MSP], reg_names[REGNO],       \
        !          1504:           reg_names[R_MSP]);
        !          1505: 
        !          1506: /* This is how to output an insn to pop a register from the stack.
        !          1507:    It need not be very fast code.  */
        !          1508: 
        !          1509: #define ASM_OUTPUT_REG_POP(FILE,REGNO)                                 \
        !          1510:   fprintf (FILE, "\tload 0,0,%s,%s\n\tadd %s,%s,4\n",                  \
        !          1511:            reg_names[REGNO], reg_names[R_MSP], reg_names[R_MSP],       \
        !          1512:           reg_names[R_MSP]);
        !          1513: 
        !          1514: /* This is how to output an assembler line for a numeric constant byte.  */
        !          1515: 
        !          1516: #define ASM_OUTPUT_BYTE(FILE,VALUE)  \
        !          1517:   fprintf (FILE, "\t.byte 0x%x\n", (VALUE))
        !          1518: 
        !          1519: /* This is how to output an element of a case-vector that is absolute.  */
        !          1520: 
        !          1521: #define ASM_OUTPUT_ADDR_VEC_ELT(FILE, VALUE)  \
        !          1522:   fprintf (FILE, "\t.word L%d\n", VALUE)
        !          1523: 
        !          1524: /* This is how to output an element of a case-vector that is relative.
        !          1525:    (29k does not use such vectors,
        !          1526:    but we must define this macro anyway.)  */
        !          1527: 
        !          1528: #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL)  abort ()
        !          1529: 
        !          1530: /* This is how to output an assembler line
        !          1531:    that says to advance the location counter
        !          1532:    to a multiple of 2**LOG bytes.  */
        !          1533: 
        !          1534: #define ASM_OUTPUT_ALIGN(FILE,LOG)     \
        !          1535:   if ((LOG) != 0)                      \
        !          1536:     fprintf (FILE, "\t.align %d\n", 1 << (LOG))
        !          1537: 
        !          1538: #define ASM_OUTPUT_SKIP(FILE,SIZE)  \
        !          1539:   fprintf (FILE, "\t.block %d\n", (SIZE))
        !          1540: 
        !          1541: /* This says how to output an assembler line
        !          1542:    to define a global common symbol.  */
        !          1543: 
        !          1544: #define ASM_OUTPUT_COMMON(FILE, NAME, SIZE, ROUNDED)  \
        !          1545: ( fputs ("\t.comm ", (FILE)),                  \
        !          1546:   assemble_name ((FILE), (NAME)),              \
        !          1547:   fprintf ((FILE), ",%d\n", (SIZE)))
        !          1548: 
        !          1549: /* This says how to output an assembler line
        !          1550:    to define a local common symbol.  */
        !          1551: 
        !          1552: #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE,ROUNDED)     \
        !          1553: ( fputs ("\t.lcomm ", (FILE)),                         \
        !          1554:   assemble_name ((FILE), (NAME)),                      \
        !          1555:   fprintf ((FILE), ",%d\n", (SIZE)))
        !          1556: 
        !          1557: /* Store in OUTPUT a string (made with alloca) containing
        !          1558:    an assembler-name for a local static variable named NAME.
        !          1559:    LABELNO is an integer which is different for each call.  */
        !          1560: 
        !          1561: #define ASM_FORMAT_PRIVATE_NAME(OUTPUT, NAME, LABELNO) \
        !          1562: ( (OUTPUT) = (char *) alloca (strlen ((NAME)) + 10),   \
        !          1563:   sprintf ((OUTPUT), "%s.%d", (NAME), (LABELNO)))
        !          1564: 
        !          1565: /* Define the parentheses used to group arithmetic operations
        !          1566:    in assembler code.  */
        !          1567: 
        !          1568: #define ASM_OPEN_PAREN "("
        !          1569: #define ASM_CLOSE_PAREN ")"
        !          1570: 
        !          1571: /* Define results of standard character escape sequences.  */
        !          1572: #define TARGET_BELL 007
        !          1573: #define TARGET_BS 010
        !          1574: #define TARGET_TAB 011
        !          1575: #define TARGET_NEWLINE 012
        !          1576: #define TARGET_VT 013
        !          1577: #define TARGET_FF 014
        !          1578: #define TARGET_CR 015
        !          1579: 
        !          1580: /* Print operand X (an rtx) in assembler syntax to file FILE.
        !          1581:    CODE is a letter or dot (`z' in `%z0') or 0 if no letter was specified.
        !          1582:    For `%' followed by punctuation, CODE is the punctuation and X is null.  */
        !          1583: 
        !          1584: #define PRINT_OPERAND(FILE, X, CODE)  print_operand (FILE, X, CODE)
        !          1585: 
        !          1586: /* Determine which codes are valid without a following integer.  These must
        !          1587:    not be alphabetic.
        !          1588: 
        !          1589:    We support `#' which is null if a delay slot exists, otherwise
        !          1590:    "\n\tnop" and `*' which prints the register name for TPC (gr122).  */
        !          1591: 
        !          1592: #define PRINT_OPERAND_PUNCT_VALID_P(CODE) ((CODE) == '#' || (CODE) == '*')
        !          1593: 
        !          1594: /* Print a memory address as an operand to reference that memory location.  */
        !          1595: 
        !          1596: #define PRINT_OPERAND_ADDRESS(FILE, ADDR)  \
        !          1597: { register rtx addr = ADDR;                                    \
        !          1598:   if (!REG_P (addr)                                            \
        !          1599:       && ! (GET_CODE (addr) == CONST_INT                       \
        !          1600:            && INTVAL (addr) >= 0 && INTVAL (addr) < 256))      \
        !          1601:     abort ();                                                  \
        !          1602:   output_operand (addr, 0);                                    \
        !          1603: }
        !          1604: /* Define the codes that are matched by predicates in a29k.c.  */
        !          1605: 
        !          1606: #define PREDICATE_CODES \
        !          1607:   {"cint_8_operand", {CONST_INT}},                             \
        !          1608:   {"cint_16_operand", {CONST_INT}},                            \
        !          1609:   {"long_const_operand", {CONST_INT, CONST, CONST_DOUBLE,      \
        !          1610:                          LABEL_REF, SYMBOL_REF}},              \
        !          1611:   {"shift_constant_operand", {CONST_INT, ASHIFT}},             \
        !          1612:   {"const_0_operand", {CONST_INT, ASHIFT}},                    \
        !          1613:   {"const_8_operand", {CONST_INT, ASHIFT}},                    \
        !          1614:   {"const_16_operand", {CONST_INT, ASHIFT}},                   \
        !          1615:   {"const_24_operand", {CONST_INT, ASHIFT}},                   \
        !          1616:   {"float_const_operand", {CONST_DOUBLE}},                     \
        !          1617:   {"gpc_reg_operand", {SUBREG, REG}},                          \
        !          1618:   {"gpc_reg_or_float_constant_operand", {SUBREG, REG, CONST_DOUBLE}}, \
        !          1619:   {"gpc_reg_or_integer_constant_operand", {SUBREG, REG,                \
        !          1620:                                           CONST_INT, CONST_DOUBLE}}, \
        !          1621:   {"gpc_reg_or_immediate_operand", {SUBREG, REG, CONST_INT,    \
        !          1622:                                    CONST_DOUBLE, CONST,        \
        !          1623:                                    SYMBOL_REF, LABEL_REF}},    \
        !          1624:   {"spec_reg_operand", {REG}},                                 \
        !          1625:   {"accum_reg_operand", {REG}},                                        \
        !          1626:   {"srcb_operand", {SUBREG, REG, CONST_INT}},                  \
        !          1627:   {"reg_or_immediate_operand", {SUBREG, REG, CONST_INT, CONST, \
        !          1628:                                CONST_DOUBLE, CONST, SYMBOL_REF, LABEL_REF}}, \
        !          1629:   {"reg_or_u_short_operand", {SUBREG, REG, CONST_INT}},                \
        !          1630:   {"and_operand", {SUBREG, REG, CONST_INT}},                   \
        !          1631:   {"add_operand", {SUBREG, REG, CONST_INT}},                   \
        !          1632:   {"call_operand", {SYMBOL_REF, CONST_INT}},                   \
        !          1633:   {"in_operand", {SUBREG, MEM, REG, CONST_INT, CONST, SYMBOL_REF, \
        !          1634:                  LABEL_REF, CONST_DOUBLE}},                    \
        !          1635:   {"out_operand", {SUBREG, REG, MEM}},                         \
        !          1636:   {"reload_memory_operand", {SUBREG, REG, MEM}},               \
        !          1637:   {"fp_comparison_operator", {EQ, GT, GE}},                    \
        !          1638:   {"branch_operator", {GE, LT}},                               \
        !          1639:   {"load_multiple_operation", {PARALLEL}},                     \
        !          1640:   {"store_multiple_operation", {PARALLEL}},                    \
        !          1641:   {"epilogue_operand", {CODE_LABEL}},

unix.superglobalmegacorp.com

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