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

1.1     ! root        1: /* Definitions of target machine for GNU compiler, for DEC Alpha.
        !             2:    Copyright (C) 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 "\
        !            25: -Dunix -D__osf__ -D__alpha -D__alpha__ -D_LONGLONG -DSYSTYPE_BSD  \
        !            26: -D_SYSTYPE_BSD -Asystem(unix) -Asystem(xpg4) -Acpu(alpha) -Amachine(alpha)"
        !            27: 
        !            28: /* Write out the correct language type definition for the header files.  
        !            29:    Unless we have assembler language, write out the symbols for C.  */
        !            30: #define CPP_SPEC "\
        !            31: %{!.S: -D__LANGUAGE_C__ -D__LANGUAGE_C %{!ansi:-DLANGUAGE_C}}  \
        !            32: %{.S:  -D__LANGUAGE_ASSEMBLY__ -D__LANGUAGE_ASSEMBLY %{!ansi:-DLANGUAGE_ASSEMBLY}} \
        !            33: %{.cc: -D__LANGUAGE_C_PLUS_PLUS__ -D__LANGUAGE_C_PLUS_PLUS -D__cplusplus} \
        !            34: %{.cxx:        -D__LANGUAGE_C_PLUS_PLUS__ -D__LANGUAGE_C_PLUS_PLUS -D__cplusplus} \
        !            35: %{.C:  -D__LANGUAGE_C_PLUS_PLUS__ -D__LANGUAGE_C_PLUS_PLUS -D__cplusplus} \
        !            36: %{.m:  -D__LANGUAGE_OBJECTIVE_C__ -D__LANGUAGE_OBJECTIVE_C}"
        !            37: 
        !            38: /* Set the spec to use for signed char.  The default tests the above macro
        !            39:    but DEC's compiler can't handle the conditional in a "constant"
        !            40:    operand.  */
        !            41: 
        !            42: #define SIGNED_CHAR_SPEC "%{funsigned-char:-D__CHAR_UNSIGNED__}"
        !            43: 
        !            44: /* No point in running CPP on our assembler output.  */
        !            45: #define ASM_SPEC "-nocpp"
        !            46: 
        !            47: /* Right now Alpha OSF/1 doesn't seem to have debugging libraries.  */
        !            48: 
        !            49: #define LIB_SPEC "%{p:-lprof1} -lc"
        !            50: 
        !            51: /* Pass "-G 8" to ld because Alpha's CC does.  Pass -O3 if we are optimizing,
        !            52:    -O1 if we are not.  Pass -non_shared or -call_shared as appropriate.  */
        !            53: #define LINK_SPEC  \
        !            54:   "-G 8 %{O*:-O3} %{!O*:-O1} %{static:-non_shared} %{!static:-call_shared}"
        !            55: 
        !            56: /* Print subsidiary information on the compiler version in use.  */
        !            57: #define TARGET_VERSION
        !            58: 
        !            59: /* Define the location for the startup file on OSF/1 for Alpha.  */
        !            60: 
        !            61: #define MD_STARTFILE_PREFIX "/usr/lib/cmplrs/cc/"
        !            62: 
        !            63: /* Run-time compilation parameters selecting different hardware subsets.  */
        !            64: 
        !            65: extern int target_flags;
        !            66: 
        !            67: /* This means that floating-point support exists in the target implementation
        !            68:    of the Alpha architecture.  This is usually the default.  */
        !            69: 
        !            70: #define TARGET_FP      (target_flags & 1)
        !            71: 
        !            72: /* This means that floating-point registers are allowed to be used.  Note
        !            73:    that Alpha implementations without FP operations are required to
        !            74:    provide the FP registers.  */
        !            75: 
        !            76: #define TARGET_FPREGS  (target_flags & 2)
        !            77: 
        !            78: /* This means that gas is used to process the assembler file.  */
        !            79: 
        !            80: #define MASK_GAS 4
        !            81: #define TARGET_GAS     (target_flags & MASK_GAS)
        !            82: 
        !            83: /* Macro to define tables used to set the flags.
        !            84:    This is a list in braces of pairs in braces,
        !            85:    each pair being { "NAME", VALUE }
        !            86:    where VALUE is the bits to set or minus the bits to clear.
        !            87:    An empty string NAME is used to identify the default VALUE.  */
        !            88: 
        !            89: #define TARGET_SWITCHES                        \
        !            90:   { {"no-soft-float", 1},              \
        !            91:     {"soft-float", -1},                        \
        !            92:     {"fp-regs", 2},                    \
        !            93:     {"no-fp-regs", -3},                        \
        !            94:     {"alpha-as", -MASK_GAS},           \
        !            95:     {"gas", MASK_GAS},                 \
        !            96:     {"", TARGET_DEFAULT} }
        !            97: 
        !            98: #define TARGET_DEFAULT 3
        !            99: 
        !           100: /* Define this macro to change register usage conditional on target flags.
        !           101: 
        !           102:    On the Alpha, we use this to disable the floating-point registers when
        !           103:    they don't exist.  */
        !           104: 
        !           105: #define CONDITIONAL_REGISTER_USAGE     \
        !           106:   if (! TARGET_FPREGS)                 \
        !           107:     for (i = 32; i < 64; i++)          \
        !           108:       fixed_regs[i] = call_used_regs[i] = 1;
        !           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 to enable software floating point emulation. */
        !           125: #define REAL_ARITHMETIC
        !           126: 
        !           127: /* Define the size of `int'.  The default is the same as the word size.  */
        !           128: #define INT_TYPE_SIZE 32
        !           129: 
        !           130: /* Define the size of `long long'.  The default is the twice the word size.  */
        !           131: #define LONG_LONG_TYPE_SIZE 64
        !           132: 
        !           133: /* The two floating-point formats we support are S-floating, which is
        !           134:    4 bytes, and T-floating, which is 8 bytes.  `float' is S and `double'
        !           135:    and `long double' are T.  */
        !           136: 
        !           137: #define FLOAT_TYPE_SIZE 32
        !           138: #define DOUBLE_TYPE_SIZE 64
        !           139: #define LONG_DOUBLE_TYPE_SIZE 64
        !           140: 
        !           141: #define WCHAR_TYPE "short unsigned int"
        !           142: #define WCHAR_TYPE_SIZE 16
        !           143: 
        !           144: /* Define this macro if it is advisable to hold scalars in registers
        !           145:    in a wider mode than that declared by the program.  In such cases, 
        !           146:    the value is constrained to be within the bounds of the declared
        !           147:    type, but kept valid in the wider mode.  The signedness of the
        !           148:    extension may differ from that of the type.
        !           149: 
        !           150:    For Alpha, we always store objects in a full register.  32-bit objects
        !           151:    are always sign-extended, but smaller objects retain their signedness.  */
        !           152: 
        !           153: #define PROMOTE_MODE(MODE,UNSIGNEDP,TYPE)  \
        !           154:   if (GET_MODE_CLASS (MODE) == MODE_INT                \
        !           155:       && GET_MODE_SIZE (MODE) < UNITS_PER_WORD)        \
        !           156:     {                                          \
        !           157:       if ((MODE) == SImode)                    \
        !           158:        (UNSIGNEDP) = 0;                        \
        !           159:       (MODE) = DImode;                         \
        !           160:     }
        !           161: 
        !           162: /* Define this if function arguments should also be promoted using the above
        !           163:    procedure.  */
        !           164: 
        !           165: #define PROMOTE_FUNCTION_ARGS
        !           166: 
        !           167: /* Likewise, if the function return value is promoted.  */
        !           168: 
        !           169: #define PROMOTE_FUNCTION_RETURN
        !           170: 
        !           171: /* Define this if most significant bit is lowest numbered
        !           172:    in instructions that operate on numbered bit-fields.
        !           173: 
        !           174:    There are no such instructions on the Alpha, but the documentation
        !           175:    is little endian.  */
        !           176: #define BITS_BIG_ENDIAN 0
        !           177: 
        !           178: /* Define this if most significant byte of a word is the lowest numbered.
        !           179:    This is false on the Alpha.  */
        !           180: #define BYTES_BIG_ENDIAN 0
        !           181: 
        !           182: /* Define this if most significant word of a multiword number is lowest
        !           183:    numbered.
        !           184: 
        !           185:    For Alpha we can decide arbitrarily since there are no machine instructions
        !           186:    for them.  Might as well be consistent with bytes. */
        !           187: #define WORDS_BIG_ENDIAN 0
        !           188: 
        !           189: /* number of bits in an addressable storage unit */
        !           190: #define BITS_PER_UNIT 8
        !           191: 
        !           192: /* Width in bits of a "word", which is the contents of a machine register.
        !           193:    Note that this is not necessarily the width of data type `int';
        !           194:    if using 16-bit ints on a 68000, this would still be 32.
        !           195:    But on a machine with 16-bit registers, this would be 16.  */
        !           196: #define BITS_PER_WORD 64
        !           197: 
        !           198: /* Width of a word, in units (bytes).  */
        !           199: #define UNITS_PER_WORD 8
        !           200: 
        !           201: /* Width in bits of a pointer.
        !           202:    See also the macro `Pmode' defined below.  */
        !           203: #define POINTER_SIZE 64
        !           204: 
        !           205: /* Allocation boundary (in *bits*) for storing arguments in argument list.  */
        !           206: #define PARM_BOUNDARY 64
        !           207: 
        !           208: /* Boundary (in *bits*) on which stack pointer should be aligned.  */
        !           209: #define STACK_BOUNDARY 64
        !           210: 
        !           211: /* Allocation boundary (in *bits*) for the code of a function.  */
        !           212: #define FUNCTION_BOUNDARY 64
        !           213: 
        !           214: /* Alignment of field after `int : 0' in a structure.  */
        !           215: #define EMPTY_FIELD_BOUNDARY 64
        !           216: 
        !           217: /* Every structure's size must be a multiple of this.  */
        !           218: #define STRUCTURE_SIZE_BOUNDARY 8
        !           219: 
        !           220: /* A bitfield declared as `int' forces `int' alignment for the struct.  */
        !           221: #define PCC_BITFIELD_TYPE_MATTERS 1
        !           222: 
        !           223: /* Align loop starts for optimal branching.  
        !           224: 
        !           225:    ??? Kludge this and the next macro for the moment by not doing anything if
        !           226:    we don't optimize and also if we are writing ECOFF symbols to work around
        !           227:    a bug in DEC's assembler. */
        !           228: 
        !           229: #define ASM_OUTPUT_LOOP_ALIGN(FILE) \
        !           230:   if (optimize > 0 && write_symbols != SDB_DEBUG)  \
        !           231:     ASM_OUTPUT_ALIGN (FILE, 5)
        !           232: 
        !           233: /* This is how to align an instruction for optimal branching.
        !           234:    On Alpha we'll get better performance by aligning on a quadword
        !           235:    boundary.  */
        !           236: 
        !           237: #define ASM_OUTPUT_ALIGN_CODE(FILE)    \
        !           238:   if (optimize > 0 && write_symbols != SDB_DEBUG) \
        !           239:     ASM_OUTPUT_ALIGN ((FILE), 4)
        !           240: 
        !           241: /* No data type wants to be aligned rounder than this.  */
        !           242: #define BIGGEST_ALIGNMENT 64
        !           243: 
        !           244: /* Make strings word-aligned so strcpy from constants will be faster.  */
        !           245: #define CONSTANT_ALIGNMENT(EXP, ALIGN)  \
        !           246:   (TREE_CODE (EXP) == STRING_CST       \
        !           247:    && (ALIGN) < BITS_PER_WORD ? BITS_PER_WORD : (ALIGN))
        !           248: 
        !           249: /* Make arrays of chars word-aligned for the same reasons.  */
        !           250: #define DATA_ALIGNMENT(TYPE, ALIGN)            \
        !           251:   (TREE_CODE (TYPE) == ARRAY_TYPE              \
        !           252:    && TYPE_MODE (TREE_TYPE (TYPE)) == QImode   \
        !           253:    && (ALIGN) < BITS_PER_WORD ? BITS_PER_WORD : (ALIGN))
        !           254: 
        !           255: /* Set this non-zero if move instructions will actually fail to work
        !           256:    when given unaligned data.
        !           257: 
        !           258:    Since we get an error message when we do one, call them invalid.  */
        !           259: 
        !           260: #define STRICT_ALIGNMENT 1
        !           261: 
        !           262: /* Set this non-zero if unaligned move instructions are extremely slow.
        !           263: 
        !           264:    On the Alpha, they trap.  */
        !           265: 
        !           266: #define SLOW_UNALIGNED_ACCESS 1
        !           267: 
        !           268: /* Standard register usage.  */
        !           269: 
        !           270: /* Number of actual hardware registers.
        !           271:    The hardware registers are assigned numbers for the compiler
        !           272:    from 0 to just below FIRST_PSEUDO_REGISTER.
        !           273:    All registers that the compiler knows about must be given numbers,
        !           274:    even those that are not normally considered general registers.
        !           275: 
        !           276:    We define all 32 integer registers, even though $31 is always zero,
        !           277:    and all 32 floating-point registers, even though $f31 is also
        !           278:    always zero.  We do not bother defining the FP status register and
        !           279:    there are no other registers. 
        !           280: 
        !           281:    Since $31 is always zero, we will use register number 31 as the
        !           282:    argument pointer.  It will never appear in the generated code
        !           283:    because we will always be eliminating it in favor of the stack
        !           284:    poointer or frame pointer.  */
        !           285: 
        !           286: #define FIRST_PSEUDO_REGISTER 64
        !           287: 
        !           288: /* 1 for registers that have pervasive standard uses
        !           289:    and are not available for the register allocator.  */
        !           290: 
        !           291: #define FIXED_REGISTERS  \
        !           292:  {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           293:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, \
        !           294:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
        !           295:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 }
        !           296: 
        !           297: /* 1 for registers not available across function calls.
        !           298:    These must include the FIXED_REGISTERS and also any
        !           299:    registers that can be used without being saved.
        !           300:    The latter must include the registers where values are returned
        !           301:    and the register where structure-value addresses are passed.
        !           302:    Aside from that, you can include as many other registers as you like.  */
        !           303: #define CALL_USED_REGISTERS  \
        !           304:  {1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, \
        !           305:   1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, \
        !           306:   1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, \
        !           307:   1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 }
        !           308: 
        !           309: /* List the order in which to allocate registers.  Each register must be
        !           310:    listed once, even those in FIXED_REGISTERS.
        !           311: 
        !           312:    We allocate in the following order:
        !           313:    $f1                 (nonsaved floating-point register)
        !           314:    $f10-$f15           (likewise)
        !           315:    $f22-$f30           (likewise)
        !           316:    $f21-$f16           (likewise, but input args)
        !           317:    $f0                 (nonsaved, but return value)
        !           318:    $f2-$f9             (saved floating-point registers)
        !           319:    $1-$8               (nonsaved integer registers)
        !           320:    $22-$25             (likewise)
        !           321:    $28                 (likewise)
        !           322:    $0                  (likewise, but return value)
        !           323:    $21-$16             (likewise, but input args)
        !           324:    $27                 (procedure value)
        !           325:    $9-$14              (saved integer registers)
        !           326:    $26                 (return PC)
        !           327:    $15                 (frame pointer)
        !           328:    $29                 (global pointer)
        !           329:    $30, $31, $f31      (stack pointer and always zero/ap)  */
        !           330: 
        !           331: #define REG_ALLOC_ORDER                \
        !           332:   {33,                                 \
        !           333:    42, 43, 44, 45, 46, 47,             \
        !           334:    54, 55, 56, 57, 58, 59, 60, 61, 62, \
        !           335:    53, 52, 51, 50, 49, 48,             \
        !           336:    32,                                 \
        !           337:    34, 35, 36, 37, 38, 39, 40, 41,     \
        !           338:    1, 2, 3, 4, 5, 6, 7, 8,             \
        !           339:    22, 23, 24, 25,                     \
        !           340:    28,                                 \
        !           341:    0,                                  \
        !           342:    21, 20, 19, 18, 17, 16,             \
        !           343:    27,                                 \
        !           344:    9, 10, 11, 12, 13, 14,              \
        !           345:    26,                                 \
        !           346:    15,                                 \
        !           347:    29,                                 \
        !           348:    30, 31, 63 }
        !           349: 
        !           350: /* Return number of consecutive hard regs needed starting at reg REGNO
        !           351:    to hold something of mode MODE.
        !           352:    This is ordinarily the length in words of a value of mode MODE
        !           353:    but can be less for certain modes in special long registers.  */
        !           354: 
        !           355: #define HARD_REGNO_NREGS(REGNO, MODE)   \
        !           356:   ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD)
        !           357: 
        !           358: /* Value is 1 if hard register REGNO can hold a value of machine-mode MODE.
        !           359:    On Alpha, the integer registers can hold any mode.  The floating-point
        !           360:    registers can hold 32-bit and 64-bit integers as well, but not 16-bit
        !           361:    or 8-bit values.  If we only allowed the larger integers into FP registers,
        !           362:    we'd have to say that QImode and SImode aren't tiable, which is a
        !           363:    pain.  So say all registers can hold everything and see how that works.  */
        !           364: 
        !           365: #define HARD_REGNO_MODE_OK(REGNO, MODE) 1
        !           366: 
        !           367: /* Value is 1 if it is a good idea to tie two pseudo registers
        !           368:    when one has mode MODE1 and one has mode MODE2.
        !           369:    If HARD_REGNO_MODE_OK could produce different values for MODE1 and MODE2,
        !           370:    for any hard reg, then this must be 0 for correct output.  */
        !           371: 
        !           372: #define MODES_TIEABLE_P(MODE1, MODE2) 1
        !           373: 
        !           374: /* Specify the registers used for certain standard purposes.
        !           375:    The values of these macros are register numbers.  */
        !           376: 
        !           377: /* Alpha pc isn't overloaded on a register that the compiler knows about.  */
        !           378: /* #define PC_REGNUM  */
        !           379: 
        !           380: /* Register to use for pushing function arguments.  */
        !           381: #define STACK_POINTER_REGNUM 30
        !           382: 
        !           383: /* Base register for access to local variables of the function.  */
        !           384: #define FRAME_POINTER_REGNUM 15
        !           385: 
        !           386: /* Value should be nonzero if functions must have frame pointers.
        !           387:    Zero means the frame pointer need not be set up (and parms
        !           388:    may be accessed via the stack pointer) in functions that seem suitable.
        !           389:    This is computed in `reload', in reload1.c.  */
        !           390: #define FRAME_POINTER_REQUIRED 0
        !           391: 
        !           392: /* Base register for access to arguments of the function.  */
        !           393: #define ARG_POINTER_REGNUM 31
        !           394: 
        !           395: /* Register in which static-chain is passed to a function. 
        !           396: 
        !           397:    For the Alpha, this is based on an example; the calling sequence
        !           398:    doesn't seem to specify this.  */
        !           399: #define STATIC_CHAIN_REGNUM 1
        !           400: 
        !           401: /* Register in which address to store a structure value
        !           402:    arrives in the function.  On the Alpha, the address is passed
        !           403:    as a hidden argument.  */
        !           404: #define STRUCT_VALUE 0
        !           405: 
        !           406: /* Define the classes of registers for register constraints in the
        !           407:    machine description.  Also define ranges of constants.
        !           408: 
        !           409:    One of the classes must always be named ALL_REGS and include all hard regs.
        !           410:    If there is more than one class, another class must be named NO_REGS
        !           411:    and contain no registers.
        !           412: 
        !           413:    The name GENERAL_REGS must be the name of a class (or an alias for
        !           414:    another name such as ALL_REGS).  This is the class of registers
        !           415:    that is allowed by "g" or "r" in a register constraint.
        !           416:    Also, registers outside this class are allocated only when
        !           417:    instructions express preferences for them.
        !           418: 
        !           419:    The classes must be numbered in nondecreasing order; that is,
        !           420:    a larger-numbered class must never be contained completely
        !           421:    in a smaller-numbered class.
        !           422: 
        !           423:    For any two classes, it is very desirable that there be another
        !           424:    class that represents their union.  */
        !           425:    
        !           426: enum reg_class { NO_REGS, GENERAL_REGS, FLOAT_REGS, ALL_REGS,
        !           427:                 LIM_REG_CLASSES };
        !           428: 
        !           429: #define N_REG_CLASSES (int) LIM_REG_CLASSES
        !           430: 
        !           431: /* Give names of register classes as strings for dump file.   */
        !           432: 
        !           433: #define REG_CLASS_NAMES                                \
        !           434:  {"NO_REGS", "GENERAL_REGS", "FLOAT_REGS", "ALL_REGS" }
        !           435: 
        !           436: /* Define which registers fit in which classes.
        !           437:    This is an initializer for a vector of HARD_REG_SET
        !           438:    of length N_REG_CLASSES.  */
        !           439: 
        !           440: #define REG_CLASS_CONTENTS     \
        !           441:   { {0, 0}, {~0, 0}, {0, ~0}, {~0, ~0} }
        !           442: 
        !           443: /* The same information, inverted:
        !           444:    Return the class number of the smallest class containing
        !           445:    reg number REGNO.  This could be a conditional expression
        !           446:    or could index an array.  */
        !           447: 
        !           448: #define REGNO_REG_CLASS(REGNO) ((REGNO) >= 32 ? FLOAT_REGS : GENERAL_REGS)
        !           449: 
        !           450: /* The class value for index registers, and the one for base regs.  */
        !           451: #define INDEX_REG_CLASS NO_REGS
        !           452: #define BASE_REG_CLASS GENERAL_REGS
        !           453: 
        !           454: /* Get reg_class from a letter such as appears in the machine description.  */
        !           455: 
        !           456: #define REG_CLASS_FROM_LETTER(C)       \
        !           457:  ((C) == 'f' ? FLOAT_REGS : NO_REGS)
        !           458: 
        !           459: /* Define this macro to change register usage conditional on target flags.  */
        !           460: /* #define CONDITIONAL_REGISTER_USAGE  */
        !           461: 
        !           462: /* The letters I, J, K, L, M, N, O, and P in a register constraint string
        !           463:    can be used to stand for particular ranges of immediate operands.
        !           464:    This macro defines what the ranges are.
        !           465:    C is the letter, and VALUE is a constant value.
        !           466:    Return 1 if VALUE is in the range specified by C.
        !           467: 
        !           468:    For Alpha:
        !           469:    `I' is used for the range of constants most insns can contain.
        !           470:    `J' is the constant zero.
        !           471:    `K' is used for the constant in an LDA insn.
        !           472:    `L' is used for the constant in a LDAH insn.
        !           473:    `M' is used for the constants that can be AND'ed with using a ZAP insn.
        !           474:    `N' is used for complemented 8-bit constants.
        !           475:    `O' is used for negated 8-bit constants.
        !           476:    `P' is used for the constants 1, 2 and 3.  */
        !           477: 
        !           478: #define CONST_OK_FOR_LETTER_P(VALUE, C)                                \
        !           479:   ((C) == 'I' ? (unsigned HOST_WIDE_INT) (VALUE) < 0x100       \
        !           480:    : (C) == 'J' ? (VALUE) == 0                                 \
        !           481:    : (C) == 'K' ? (unsigned HOST_WIDE_INT) ((VALUE) + 0x8000) < 0x10000        \
        !           482:    : (C) == 'L' ? (((VALUE) & 0xffff) == 0                     \
        !           483:                   && (((VALUE)) >> 31 == -1 || (VALUE) >> 31 == 0)) \
        !           484:    : (C) == 'M' ? zap_mask (VALUE)                             \
        !           485:    : (C) == 'N' ? (unsigned HOST_WIDE_INT) (~ (VALUE)) < 0x100 \
        !           486:    : (C) == 'O' ? (unsigned HOST_WIDE_INT) (- (VALUE)) < 0x100 \
        !           487:    : (C) == 'P' ? (VALUE) == 1 || (VALUE) == 2 || (VALUE) == 3 \
        !           488:    : 0)
        !           489: 
        !           490: /* Similar, but for floating or large integer constants, and defining letters
        !           491:    G and H.   Here VALUE is the CONST_DOUBLE rtx itself.
        !           492: 
        !           493:    For Alpha, `G' is the floating-point constant zero.  `H' is a CONST_DOUBLE
        !           494:    that is the operand of a ZAP insn.  */
        !           495: 
        !           496: #define CONST_DOUBLE_OK_FOR_LETTER_P(VALUE, C)                         \
        !           497:   ((C) == 'G' ? (GET_MODE_CLASS (GET_MODE (VALUE)) == MODE_FLOAT       \
        !           498:                 && (VALUE) == CONST0_RTX (GET_MODE (VALUE)))           \
        !           499:    : (C) == 'H' ? (GET_MODE (VALUE) == VOIDmode                                \
        !           500:                   && zap_mask (CONST_DOUBLE_LOW (VALUE))               \
        !           501:                   && zap_mask (CONST_DOUBLE_HIGH (VALUE)))             \
        !           502:    : 0)
        !           503: 
        !           504: /* Optional extra constraints for this machine.
        !           505: 
        !           506:    For the Alpha, `Q' means that this is a memory operand but not a
        !           507:    reference to an unaligned location.  */
        !           508: 
        !           509: #define EXTRA_CONSTRAINT(OP, C)                                \
        !           510:   ((C) == 'Q' ? GET_CODE (OP) == MEM && GET_CODE (XEXP (OP, 0)) != AND \
        !           511:    : 0)
        !           512: 
        !           513: /* Given an rtx X being reloaded into a reg required to be
        !           514:    in class CLASS, return the class of reg to actually use.
        !           515:    In general this is just CLASS; but on some machines
        !           516:    in some cases it is preferable to use a more restrictive class.
        !           517: 
        !           518:    On the Alpha, all constants except zero go into a floating-point
        !           519:    register via memory.  */
        !           520: 
        !           521: #define PREFERRED_RELOAD_CLASS(X, CLASS)               \
        !           522:   (CONSTANT_P (X) && (X) != const0_rtx && (X) != CONST0_RTX (GET_MODE (X)) \
        !           523:    ? ((CLASS) == FLOAT_REGS ? NO_REGS : GENERAL_REGS)                  \
        !           524:    : (CLASS))
        !           525: 
        !           526: /* Loading and storing HImode or QImode values to and from memory
        !           527:    usually requires a scratch register.  The exceptions are loading
        !           528:    QImode and HImode from an aligned address to a general register. 
        !           529:    We also cannot load an unaligned address into an FP register.  */
        !           530: 
        !           531: #define SECONDARY_INPUT_RELOAD_CLASS(CLASS,MODE,IN)                    \
        !           532: (((GET_CODE (IN) == MEM                                                \
        !           533:    || (GET_CODE (IN) == REG && REGNO (IN) >= FIRST_PSEUDO_REGISTER)    \
        !           534:    || (GET_CODE (IN) == SUBREG                                         \
        !           535:        && (GET_CODE (SUBREG_REG (IN)) == MEM                           \
        !           536:           || (GET_CODE (SUBREG_REG (IN)) == REG                        \
        !           537:               && REGNO (SUBREG_REG (IN)) >= FIRST_PSEUDO_REGISTER))))  \
        !           538:   && (((CLASS) == FLOAT_REGS                                           \
        !           539:        && ((MODE) == SImode || (MODE) == HImode || (MODE) == QImode))  \
        !           540:       || (((MODE) == QImode || (MODE) == HImode)                       \
        !           541:          && unaligned_memory_operand (IN, MODE))))                     \
        !           542:  ? GENERAL_REGS                                                                \
        !           543:  : ((CLASS) == FLOAT_REGS && GET_CODE (IN) == MEM                      \
        !           544:     && GET_CODE (XEXP (IN, 0)) == AND) ? GENERAL_REGS                  \
        !           545:  : NO_REGS)
        !           546: 
        !           547: #define SECONDARY_OUTPUT_RELOAD_CLASS(CLASS,MODE,OUT)                  \
        !           548: (((GET_CODE (OUT) == MEM                                               \
        !           549:    || (GET_CODE (OUT) == REG && REGNO (OUT) >= FIRST_PSEUDO_REGISTER)  \
        !           550:    || (GET_CODE (OUT) == SUBREG                                                \
        !           551:        && (GET_CODE (SUBREG_REG (OUT)) == MEM                          \
        !           552:           || (GET_CODE (SUBREG_REG (OUT)) == REG                       \
        !           553:               && REGNO (SUBREG_REG (OUT)) >= FIRST_PSEUDO_REGISTER)))) \
        !           554:   && (((MODE) == HImode || (MODE) == QImode                            \
        !           555:        || ((MODE) == SImode && (CLASS) == FLOAT_REGS))))               \
        !           556:  ? GENERAL_REGS                                                                \
        !           557:  : ((CLASS) == FLOAT_REGS && GET_CODE (OUT) == MEM                     \
        !           558:     && GET_CODE (XEXP (OUT, 0)) == AND) ? GENERAL_REGS                 \
        !           559:   : NO_REGS)
        !           560: 
        !           561: /* If we are copying between general and FP registers, we need a memory
        !           562:    location.  */
        !           563: 
        !           564: #define SECONDARY_MEMORY_NEEDED(CLASS1,CLASS2,MODE) ((CLASS1) != (CLASS2))
        !           565: 
        !           566: /* Return the maximum number of consecutive registers
        !           567:    needed to represent mode MODE in a register of class CLASS.  */
        !           568: 
        !           569: #define CLASS_MAX_NREGS(CLASS, MODE)                           \
        !           570:  ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD)
        !           571: 
        !           572: /* Define the cost of moving between registers of various classes.  Moving
        !           573:    between FLOAT_REGS and anything else except float regs is expensive. 
        !           574:    In fact, we make it quite expensive because we really don't want to
        !           575:    do these moves unless it is clearly worth it.  Optimizations may
        !           576:    reduce the impact of not being able to allocate a pseudo to a
        !           577:    hard register.  */
        !           578: 
        !           579: #define REGISTER_MOVE_COST(CLASS1, CLASS2)     \
        !           580:   (((CLASS1) == FLOAT_REGS) == ((CLASS2) == FLOAT_REGS) ? 2 : 20)
        !           581: 
        !           582: /* A C expressions returning the cost of moving data of MODE from a register to
        !           583:    or from memory.
        !           584: 
        !           585:    On the Alpha, bump this up a bit.  */
        !           586: 
        !           587: #define MEMORY_MOVE_COST(MODE)  6
        !           588: 
        !           589: /* Provide the cost of a branch.  Exact meaning under development.  */
        !           590: #define BRANCH_COST 5
        !           591: 
        !           592: /* Adjust the cost of dependencies.  */
        !           593: 
        !           594: #define ADJUST_COST(INSN,LINK,DEP,COST) \
        !           595:   (COST) = alpha_adjust_cost (INSN, LINK, DEP, COST)
        !           596: 
        !           597: /* Stack layout; function entry, exit and calling.  */
        !           598: 
        !           599: /* Define this if pushing a word on the stack
        !           600:    makes the stack pointer a smaller address.  */
        !           601: #define STACK_GROWS_DOWNWARD
        !           602: 
        !           603: /* Define this if the nominal address of the stack frame
        !           604:    is at the high-address end of the local variables;
        !           605:    that is, each additional local variable allocated
        !           606:    goes at a more negative offset in the frame.  */
        !           607: /* #define FRAME_GROWS_DOWNWARD */
        !           608: 
        !           609: /* Offset within stack frame to start allocating local variables at.
        !           610:    If FRAME_GROWS_DOWNWARD, this is the offset to the END of the
        !           611:    first local allocated.  Otherwise, it is the offset to the BEGINNING
        !           612:    of the first local allocated.  */
        !           613: 
        !           614: #define STARTING_FRAME_OFFSET current_function_outgoing_args_size
        !           615: 
        !           616: /* If we generate an insn to push BYTES bytes,
        !           617:    this says how many the stack pointer really advances by.
        !           618:    On Alpha, don't define this because there are no push insns.  */
        !           619: /*  #define PUSH_ROUNDING(BYTES) */
        !           620: 
        !           621: /* Define this if the maximum size of all the outgoing args is to be
        !           622:    accumulated and pushed during the prologue.  The amount can be
        !           623:    found in the variable current_function_outgoing_args_size.  */
        !           624: #define ACCUMULATE_OUTGOING_ARGS
        !           625: 
        !           626: /* Offset of first parameter from the argument pointer register value.  */
        !           627: 
        !           628: #define FIRST_PARM_OFFSET(FNDECL) 0
        !           629: 
        !           630: /* Definitions for register eliminations.
        !           631: 
        !           632:    We have two registers that can be eliminated on the Alpha.  First, the
        !           633:    frame pointer register can often be eliminated in favor of the stack
        !           634:    pointer register.  Secondly, the argument pointer register can always be
        !           635:    eliminated; it is replaced with either the stack or frame pointer. */
        !           636: 
        !           637: /* This is an array of structures.  Each structure initializes one pair
        !           638:    of eliminable registers.  The "from" register number is given first,
        !           639:    followed by "to".  Eliminations of the same "from" register are listed
        !           640:    in order of preference.  */
        !           641: 
        !           642: #define ELIMINABLE_REGS                                \
        !           643: {{ ARG_POINTER_REGNUM, STACK_POINTER_REGNUM},  \
        !           644:  { ARG_POINTER_REGNUM, FRAME_POINTER_REGNUM},   \
        !           645:  { FRAME_POINTER_REGNUM, STACK_POINTER_REGNUM}}
        !           646: 
        !           647: /* Given FROM and TO register numbers, say whether this elimination is allowed.
        !           648:    Frame pointer elimination is automatically handled.
        !           649: 
        !           650:    All eliminations are valid since the cases where FP can't be
        !           651:    eliminated are already handled.  */
        !           652: 
        !           653: #define CAN_ELIMINATE(FROM, TO) 1
        !           654: 
        !           655: /* Define the offset between two registers, one to be eliminated, and the other
        !           656:    its replacement, at the start of a routine.  */
        !           657: #define INITIAL_ELIMINATION_OFFSET(FROM, TO, OFFSET)                   \
        !           658: { if ((FROM) == FRAME_POINTER_REGNUM && (TO) == STACK_POINTER_REGNUM)  \
        !           659:     (OFFSET) = 0;                                                      \
        !           660:   else                                                                 \
        !           661:     {                                                                  \
        !           662:       (OFFSET) = ((get_frame_size () + current_function_outgoing_args_size \
        !           663:                   + current_function_pretend_args_size                 \
        !           664:                   + alpha_sa_size () + 15)                             \
        !           665:                  & ~ 15);                                              \
        !           666:       if ((FROM) == ARG_POINTER_REGNUM)                                        \
        !           667:        (OFFSET) -= current_function_pretend_args_size;                 \
        !           668:     }                                                                  \
        !           669: }
        !           670: 
        !           671: /* Define this if stack space is still allocated for a parameter passed
        !           672:    in a register.  */
        !           673: /* #define REG_PARM_STACK_SPACE */
        !           674: 
        !           675: /* Value is the number of bytes of arguments automatically
        !           676:    popped when returning from a subroutine call.
        !           677:    FUNTYPE is the data type of the function (as a tree),
        !           678:    or for a library call it is an identifier node for the subroutine name.
        !           679:    SIZE is the number of bytes of arguments passed on the stack.  */
        !           680: 
        !           681: #define RETURN_POPS_ARGS(FUNTYPE,SIZE) 0
        !           682: 
        !           683: /* Define how to find the value returned by a function.
        !           684:    VALTYPE is the data type of the value (as a tree).
        !           685:    If the precise function being called is known, FUNC is its FUNCTION_DECL;
        !           686:    otherwise, FUNC is 0.
        !           687: 
        !           688:    On Alpha the value is found in $0 for integer functions and
        !           689:    $f0 for floating-point functions.  */
        !           690: 
        !           691: #define FUNCTION_VALUE(VALTYPE, FUNC)  \
        !           692:   gen_rtx (REG,                                                \
        !           693:           ((TREE_CODE (VALTYPE) == INTEGER_TYPE        \
        !           694:             || TREE_CODE (VALTYPE) == ENUMERAL_TYPE    \
        !           695:             || TREE_CODE (VALTYPE) == BOOLEAN_TYPE     \
        !           696:             || TREE_CODE (VALTYPE) == CHAR_TYPE        \
        !           697:             || TREE_CODE (VALTYPE) == POINTER_TYPE     \
        !           698:             || TREE_CODE (VALTYPE) == OFFSET_TYPE)     \
        !           699:            && TYPE_PRECISION (VALTYPE) < BITS_PER_WORD) \
        !           700:           ? word_mode : TYPE_MODE (VALTYPE),           \
        !           701:           TARGET_FPREGS && TREE_CODE (VALTYPE) == REAL_TYPE ? 32 : 0)
        !           702: 
        !           703: /* Define how to find the value returned by a library function
        !           704:    assuming the value has mode MODE.  */
        !           705: 
        !           706: #define LIBCALL_VALUE(MODE)    \
        !           707:    gen_rtx (REG, MODE,         \
        !           708:            TARGET_FPREGS && GET_MODE_CLASS (MODE) == MODE_FLOAT ? 32 : 0)
        !           709: 
        !           710: /* The definition of this macro implies that there are cases where
        !           711:    a scalar value cannot be returned in registers.
        !           712: 
        !           713:    For the Alpha, any structure or union type is returned in memory, as
        !           714:    are integers whose size is larger than 64 bits.  */
        !           715: 
        !           716: #define RETURN_IN_MEMORY(TYPE) \
        !           717:   (TYPE_MODE (TYPE) == BLKmode \
        !           718:    || (TREE_CODE (TYPE) == INTEGER_TYPE && TYPE_PRECISION (TYPE) > 64))
        !           719: 
        !           720: /* 1 if N is a possible register number for a function value
        !           721:    as seen by the caller.  */
        !           722: 
        !           723: #define FUNCTION_VALUE_REGNO_P(N) ((N) == 0 || (N) == 32)
        !           724: 
        !           725: /* 1 if N is a possible register number for function argument passing.
        !           726:    On Alpha, these are $16-$21 and $f16-$f21.  */
        !           727: 
        !           728: #define FUNCTION_ARG_REGNO_P(N) \
        !           729:   (((N) >= 16 && (N) <= 21) || ((N) >= 16 + 32 && (N) <= 21 + 32))
        !           730: 
        !           731: /* Define a data type for recording info about an argument list
        !           732:    during the scan of that argument list.  This data type should
        !           733:    hold all necessary information about the function itself
        !           734:    and about the args processed so far, enough to enable macros
        !           735:    such as FUNCTION_ARG to determine where the next arg should go.
        !           736: 
        !           737:    On Alpha, this is a single integer, which is a number of words
        !           738:    of arguments scanned so far.
        !           739:    Thus 6 or more means all following args should go on the stack.  */
        !           740: 
        !           741: #define CUMULATIVE_ARGS int
        !           742: 
        !           743: /* Initialize a variable CUM of type CUMULATIVE_ARGS
        !           744:    for a call to a function whose data type is FNTYPE.
        !           745:    For a library call, FNTYPE is 0.  */
        !           746: 
        !           747: #define INIT_CUMULATIVE_ARGS(CUM,FNTYPE,LIBNAME)  (CUM) = 0
        !           748: 
        !           749: /* Define intermediate macro to compute the size (in registers) of an argument
        !           750:    for the Alpha.  */
        !           751: 
        !           752: #define ALPHA_ARG_SIZE(MODE, TYPE, NAMED)                              \
        !           753: ((MODE) != BLKmode                                                     \
        !           754:  ? (GET_MODE_SIZE (MODE) + (UNITS_PER_WORD - 1)) / UNITS_PER_WORD      \
        !           755:  : (int_size_in_bytes (TYPE) + (UNITS_PER_WORD - 1)) / UNITS_PER_WORD)
        !           756: 
        !           757: /* Update the data in CUM to advance over an argument
        !           758:    of mode MODE and data type TYPE.
        !           759:    (TYPE is null for libcalls where that information may not be available.)  */
        !           760: 
        !           761: #define FUNCTION_ARG_ADVANCE(CUM, MODE, TYPE, NAMED)                   \
        !           762:   if (MUST_PASS_IN_STACK (MODE, TYPE))                                 \
        !           763:     (CUM) = 6;                                                         \
        !           764:   else                                                                 \
        !           765:     (CUM) += ALPHA_ARG_SIZE (MODE, TYPE, NAMED)
        !           766: 
        !           767: /* Determine where to put an argument to a function.
        !           768:    Value is zero to push the argument on the stack,
        !           769:    or a hard register in which to store the argument.
        !           770: 
        !           771:    MODE is the argument's machine mode.
        !           772:    TYPE is the data type of the argument (as a tree).
        !           773:     This is null for libcalls where that information may
        !           774:     not be available.
        !           775:    CUM is a variable of type CUMULATIVE_ARGS which gives info about
        !           776:     the preceding args and about the function being called.
        !           777:    NAMED is nonzero if this argument is a named parameter
        !           778:     (otherwise it is an extra parameter matching an ellipsis).
        !           779: 
        !           780:    On Alpha the first 6 words of args are normally in registers
        !           781:    and the rest are pushed.  */
        !           782: 
        !           783: #define FUNCTION_ARG(CUM, MODE, TYPE, NAMED)   \
        !           784: ((CUM) < 6 && ! MUST_PASS_IN_STACK (MODE, TYPE)        \
        !           785:  ? gen_rtx(REG, (MODE),                                \
        !           786:           (CUM) + 16 + (TARGET_FPREGS          \
        !           787:                         && GET_MODE_CLASS (MODE) == MODE_FLOAT) * 32) : 0)
        !           788: 
        !           789: /* Specify the padding direction of arguments.
        !           790: 
        !           791:    On the Alpha, we must pad upwards in order to be able to pass args in
        !           792:    registers.  */
        !           793: 
        !           794: #define FUNCTION_ARG_PADDING(MODE, TYPE)       upward
        !           795: 
        !           796: /* For an arg passed partly in registers and partly in memory,
        !           797:    this is the number of registers used.
        !           798:    For args passed entirely in registers or entirely in memory, zero.  */
        !           799: 
        !           800: #define FUNCTION_ARG_PARTIAL_NREGS(CUM, MODE, TYPE, NAMED)     \
        !           801: ((CUM) < 6 && 6 < (CUM) + ALPHA_ARG_SIZE (MODE, TYPE, NAMED)   \
        !           802:  ? 6 - (CUM) : 0)
        !           803: 
        !           804: /* Perform any needed actions needed for a function that is receiving a
        !           805:    variable number of arguments. 
        !           806: 
        !           807:    CUM is as above.
        !           808: 
        !           809:    MODE and TYPE are the mode and type of the current parameter.
        !           810: 
        !           811:    PRETEND_SIZE is a variable that should be set to the amount of stack
        !           812:    that must be pushed by the prolog to pretend that our caller pushed
        !           813:    it.
        !           814: 
        !           815:    Normally, this macro will push all remaining incoming registers on the
        !           816:    stack and set PRETEND_SIZE to the length of the registers pushed. 
        !           817: 
        !           818:    On the Alpha, we allocate space for all 12 arg registers, but only
        !           819:    push those that are remaining.
        !           820: 
        !           821:    However, if NO registers need to be saved, don't allocate any space.
        !           822:    This is not only because we won't need the space, but because AP includes
        !           823:    the current_pretend_args_size and we don't want to mess up any
        !           824:    ap-relative addresses already made.
        !           825: 
        !           826:    If we are not to use the floating-point registers, save the integer
        !           827:    registers where we would put the floating-point registers.  This is
        !           828:    not the most efficient way to implement varargs with just one register
        !           829:    class, but it isn't worth doing anything more efficient in this rare
        !           830:    case.  */
        !           831:    
        !           832: 
        !           833: #define SETUP_INCOMING_VARARGS(CUM,MODE,TYPE,PRETEND_SIZE,NO_RTL)      \
        !           834: { if ((CUM) < 6)                                                       \
        !           835:     {                                                                  \
        !           836:       if (! (NO_RTL))                                                  \
        !           837:        {                                                               \
        !           838:          move_block_from_reg                                           \
        !           839:            (16 + CUM,                                                  \
        !           840:             gen_rtx (MEM, BLKmode,                                     \
        !           841:                      plus_constant (virtual_incoming_args_rtx,         \
        !           842:                                     ((CUM) + 6)* UNITS_PER_WORD)),     \
        !           843:             6 - (CUM), (6 - (CUM)) * UNITS_PER_WORD);                  \
        !           844:          move_block_from_reg                                           \
        !           845:            (16 + (TARGET_FPREGS ? 32 : 0) + CUM,                       \
        !           846:             gen_rtx (MEM, BLKmode,                                     \
        !           847:                      plus_constant (virtual_incoming_args_rtx,         \
        !           848:                                     (CUM) * UNITS_PER_WORD)),          \
        !           849:             6 - (CUM), (6 - (CUM)) * UNITS_PER_WORD);                  \
        !           850:         }                                                              \
        !           851:       PRETEND_SIZE = 12 * UNITS_PER_WORD;                              \
        !           852:     }                                                                  \
        !           853: }
        !           854: 
        !           855: /* Generate necessary RTL for __builtin_saveregs().
        !           856:    ARGLIST is the argument list; see expr.c.  */
        !           857: extern struct rtx_def *alpha_builtin_saveregs ();
        !           858: #define EXPAND_BUILTIN_SAVEREGS(ARGLIST) alpha_builtin_saveregs (ARGLIST)
        !           859: 
        !           860: /* Define the information needed to generate branch and scc insns.  This is
        !           861:    stored from the compare operation.  Note that we can't use "rtx" here
        !           862:    since it hasn't been defined!  */
        !           863: 
        !           864: extern struct rtx_def *alpha_compare_op0, *alpha_compare_op1;
        !           865: extern int alpha_compare_fp_p;
        !           866: 
        !           867: /* This macro produces the initial definition of a function name.  On the
        !           868:    Alpha, we need to save the function name for the prologue and epilogue.  */
        !           869: 
        !           870: extern char *alpha_function_name;
        !           871: 
        !           872: #define ASM_DECLARE_FUNCTION_NAME(FILE,NAME,DECL)      \
        !           873: {                                                      \
        !           874:    alpha_function_name = NAME;                         \
        !           875: }
        !           876:    
        !           877: /* This macro generates the assembly code for function entry.
        !           878:    FILE is a stdio stream to output the code to.
        !           879:    SIZE is an int: how many units of temporary storage to allocate.
        !           880:    Refer to the array `regs_ever_live' to determine which registers
        !           881:    to save; `regs_ever_live[I]' is nonzero if register number I
        !           882:    is ever used in the function.  This macro is responsible for
        !           883:    knowing which registers should not be saved even if used.  */
        !           884: 
        !           885: #define FUNCTION_PROLOGUE(FILE, SIZE)  output_prolog (FILE, SIZE)
        !           886: 
        !           887: /* Output assembler code to FILE to increment profiler label # LABELNO
        !           888:    for profiling a function entry.  */
        !           889: 
        !           890: #define FUNCTION_PROFILER(FILE, LABELNO)
        !           891: 
        !           892: /* EXIT_IGNORE_STACK should be nonzero if, when returning from a function,
        !           893:    the stack pointer does not matter.  The value is tested only in
        !           894:    functions that have frame pointers.
        !           895:    No definition is equivalent to always zero.  */
        !           896: 
        !           897: #define EXIT_IGNORE_STACK 1
        !           898: 
        !           899: /* This macro generates the assembly code for function exit,
        !           900:    on machines that need it.  If FUNCTION_EPILOGUE is not defined
        !           901:    then individual return instructions are generated for each
        !           902:    return statement.  Args are same as for FUNCTION_PROLOGUE.
        !           903: 
        !           904:    The function epilogue should not depend on the current stack pointer!
        !           905:    It should use the frame pointer only.  This is mandatory because
        !           906:    of alloca; we also take advantage of it to omit stack adjustments
        !           907:    before returning.  */
        !           908: 
        !           909: #define FUNCTION_EPILOGUE(FILE, SIZE)  output_epilog (FILE, SIZE)
        !           910: 
        !           911: 
        !           912: /* Output assembler code for a block containing the constant parts
        !           913:    of a trampoline, leaving space for the variable parts.
        !           914: 
        !           915:    The trampoline should set the static chain pointer to value placed
        !           916:    into the trampoline and should branch to the specified routine.  
        !           917:    Note that $27 has been set to the address of the trampoline, so we can
        !           918:    use it for addressability of the two data items.  Trampolines are always
        !           919:    aligned to FUNCTION_BOUNDARY, which is 64 bits.  */
        !           920: 
        !           921: #define TRAMPOLINE_TEMPLATE(FILE)              \
        !           922: {                                              \
        !           923:   fprintf (FILE, "\tldq $1,24($27)\n");                \
        !           924:   fprintf (FILE, "\tldq $27,16($27)\n");       \
        !           925:   fprintf (FILE, "\tjmp $31,($27),0\n");       \
        !           926:   fprintf (FILE, "\tnop\n");                   \
        !           927:   fprintf (FILE, "\t.quad 0,0\n");             \
        !           928: }
        !           929: 
        !           930: /* Section in which to place the trampoline.  On Alpha, instructions
        !           931:    may only be placed in a text segment.  */
        !           932: 
        !           933: #define TRAMPOLINE_SECTION text_section
        !           934: 
        !           935: /* Length in units of the trampoline for entering a nested function.  */
        !           936: 
        !           937: #define TRAMPOLINE_SIZE    32
        !           938: 
        !           939: /* Emit RTL insns to initialize the variable parts of a trampoline.
        !           940:    FNADDR is an RTX for the address of the function's pure code.
        !           941:    CXT is an RTX for the static chain value for the function.  We assume
        !           942:    here that a function will be called many more times than its address
        !           943:    is taken (e.g., it might be passed to qsort), so we take the trouble 
        !           944:    to initialize the "hint" field in the JMP insn.  Note that the hint
        !           945:    field is PC (new) + 4 * bits 13:0.  */
        !           946: 
        !           947: #define INITIALIZE_TRAMPOLINE(TRAMP, FNADDR, CXT)                      \
        !           948: {                                                                      \
        !           949:   rtx _temp, _temp1, _addr;                                            \
        !           950:                                                                        \
        !           951:   _addr = memory_address (Pmode, plus_constant ((TRAMP), 16));         \
        !           952:   emit_move_insn (gen_rtx (MEM, Pmode, _addr), (FNADDR));              \
        !           953:   _addr = memory_address (Pmode, plus_constant ((TRAMP), 24));         \
        !           954:   emit_move_insn (gen_rtx (MEM, Pmode, _addr), (CXT));                 \
        !           955:                                                                        \
        !           956:   _temp = force_operand (plus_constant ((TRAMP), 12), NULL_RTX);       \
        !           957:   _temp = expand_binop (DImode, sub_optab, (FNADDR), _temp, _temp, 1,  \
        !           958:                        OPTAB_WIDEN);                                   \
        !           959:   _temp = expand_shift (RSHIFT_EXPR, Pmode, _temp,                     \
        !           960:                        build_int_2 (2, 0), NULL_RTX, 1);               \
        !           961:   _temp = expand_and (gen_lowpart (SImode, _temp),                     \
        !           962:                      GEN_INT (0x3fff), 0);                             \
        !           963:                                                                        \
        !           964:   _addr = memory_address (SImode, plus_constant ((TRAMP), 8));         \
        !           965:   _temp1 = force_reg (SImode, gen_rtx (MEM, SImode, _addr));           \
        !           966:   _temp1 = expand_and (_temp1, GEN_INT (0xffffc000), NULL_RTX);                \
        !           967:   _temp1 = expand_binop (SImode, ior_optab, _temp1, _temp, _temp1, 1,  \
        !           968:                         OPTAB_WIDEN);                                  \
        !           969:                                                                        \
        !           970:   emit_move_insn (gen_rtx (MEM, SImode, _addr), _temp1);               \
        !           971:                                                                        \
        !           972:   emit_library_call (gen_rtx (SYMBOL_REF, Pmode,                       \
        !           973:                              "__enable_execute_stack"),                \
        !           974:                     0, VOIDmode, 1,_addr, Pmode);                      \
        !           975:                                                                        \
        !           976:   emit_insn (gen_rtx (UNSPEC_VOLATILE, VOIDmode,                       \
        !           977:                      gen_rtvec (1, const0_rtx), 0));                   \
        !           978: }
        !           979: 
        !           980: /* Attempt to turn on access permissions for the stack.  */
        !           981: 
        !           982: #define TRANSFER_FROM_TRAMPOLINE                                       \
        !           983:                                                                        \
        !           984: void                                                                   \
        !           985: __enable_execute_stack (addr)                                          \
        !           986:      void *addr;                                                       \
        !           987: {                                                                      \
        !           988:   long size = getpagesize ();                                          \
        !           989:   long mask = ~(size-1);                                               \
        !           990:   char *page = (char *) (((long) addr) & mask);                                \
        !           991:   char *end  = (char *) ((((long) (addr + TRAMPOLINE_SIZE)) & mask) + size); \
        !           992:                                                                        \
        !           993:   /* 7 is PROT_READ | PROT_WRITE | PROT_EXEC */                                \
        !           994:   if (mprotect (page, end - page, 7) < 0)                              \
        !           995:     perror ("mprotect of trampoline code");                            \
        !           996: }
        !           997: 
        !           998: /* Addressing modes, and classification of registers for them.  */
        !           999: 
        !          1000: /* #define HAVE_POST_INCREMENT */
        !          1001: /* #define HAVE_POST_DECREMENT */
        !          1002: 
        !          1003: /* #define HAVE_PRE_DECREMENT */
        !          1004: /* #define HAVE_PRE_INCREMENT */
        !          1005: 
        !          1006: /* Macros to check register numbers against specific register classes.  */
        !          1007: 
        !          1008: /* These assume that REGNO is a hard or pseudo reg number.
        !          1009:    They give nonzero only if REGNO is a hard reg of the suitable class
        !          1010:    or a pseudo reg currently allocated to a suitable hard reg.
        !          1011:    Since they use reg_renumber, they are safe only once reg_renumber
        !          1012:    has been allocated, which happens in local-alloc.c.  */
        !          1013: 
        !          1014: #define REGNO_OK_FOR_INDEX_P(REGNO) 0
        !          1015: #define REGNO_OK_FOR_BASE_P(REGNO) \
        !          1016: (((REGNO) < 32 || (unsigned) reg_renumber[REGNO] < 32))
        !          1017: 
        !          1018: /* Maximum number of registers that can appear in a valid memory address.  */
        !          1019: #define MAX_REGS_PER_ADDRESS 1
        !          1020: 
        !          1021: /* Recognize any constant value that is a valid address.  For the Alpha,
        !          1022:    there are only constants none since we want to use LDA to load any
        !          1023:    symbolic addresses into registers.  */
        !          1024: 
        !          1025: #define CONSTANT_ADDRESS_P(X)   \
        !          1026:   (GET_CODE (X) == CONST_INT   \
        !          1027:    && (unsigned HOST_WIDE_INT) (INTVAL (X) + 0x8000) < 0x10000)
        !          1028: 
        !          1029: /* Include all constant integers and constant doubles, but not
        !          1030:    floating-point, except for floating-point zero.  */
        !          1031: 
        !          1032: #define LEGITIMATE_CONSTANT_P(X)               \
        !          1033:   (GET_MODE_CLASS (GET_MODE (X)) != MODE_FLOAT \
        !          1034:    || (X) == CONST0_RTX (GET_MODE (X)))
        !          1035: 
        !          1036: /* The macros REG_OK_FOR..._P assume that the arg is a REG rtx
        !          1037:    and check its validity for a certain class.
        !          1038:    We have two alternate definitions for each of them.
        !          1039:    The usual definition accepts all pseudo regs; the other rejects
        !          1040:    them unless they have been allocated suitable hard regs.
        !          1041:    The symbol REG_OK_STRICT causes the latter definition to be used.
        !          1042: 
        !          1043:    Most source files want to accept pseudo regs in the hope that
        !          1044:    they will get allocated to the class that the insn wants them to be in.
        !          1045:    Source files for reload pass need to be strict.
        !          1046:    After reload, it makes no difference, since pseudo regs have
        !          1047:    been eliminated by then.  */
        !          1048: 
        !          1049: #ifndef REG_OK_STRICT
        !          1050: 
        !          1051: /* Nonzero if X is a hard reg that can be used as an index
        !          1052:    or if it is a pseudo reg.  */
        !          1053: #define REG_OK_FOR_INDEX_P(X) 0
        !          1054: /* Nonzero if X is a hard reg that can be used as a base reg
        !          1055:    or if it is a pseudo reg.  */
        !          1056: #define REG_OK_FOR_BASE_P(X)  \
        !          1057:   (REGNO (X) < 32 || REGNO (X) >= FIRST_PSEUDO_REGISTER)
        !          1058: 
        !          1059: #else
        !          1060: 
        !          1061: /* Nonzero if X is a hard reg that can be used as an index.  */
        !          1062: #define REG_OK_FOR_INDEX_P(X) REGNO_OK_FOR_INDEX_P (REGNO (X))
        !          1063: /* Nonzero if X is a hard reg that can be used as a base reg.  */
        !          1064: #define REG_OK_FOR_BASE_P(X) REGNO_OK_FOR_BASE_P (REGNO (X))
        !          1065: 
        !          1066: #endif
        !          1067: 
        !          1068: /* GO_IF_LEGITIMATE_ADDRESS recognizes an RTL expression
        !          1069:    that is a valid memory address for an instruction.
        !          1070:    The MODE argument is the machine mode for the MEM expression
        !          1071:    that wants to use this address. 
        !          1072: 
        !          1073:    For Alpha, we have either a constant address or the sum of a register
        !          1074:    and a constant address, or just a register.  For DImode, any of those
        !          1075:    forms can be surrounded with an AND that clear the low-order three bits;
        !          1076:    this is an "unaligned" access.
        !          1077: 
        !          1078:    We also allow a SYMBOL_REF that is the name of the current function as
        !          1079:    valid address.  This is for CALL_INSNs.  It cannot be used in any other
        !          1080:    context.
        !          1081: 
        !          1082:    First define the basic valid address.  */
        !          1083: 
        !          1084: #define GO_IF_LEGITIMATE_SIMPLE_ADDRESS(MODE, X, ADDR) \
        !          1085: { if (REG_P (X) && REG_OK_FOR_BASE_P (X))      \
        !          1086:     goto ADDR;                                 \
        !          1087:   if (CONSTANT_ADDRESS_P (X))                  \
        !          1088:     goto ADDR;                                 \
        !          1089:   if (GET_CODE (X) == PLUS                     \
        !          1090:       && REG_P (XEXP (X, 0))                   \
        !          1091:       && REG_OK_FOR_BASE_P (XEXP (X, 0))       \
        !          1092:       && CONSTANT_ADDRESS_P (XEXP (X, 1)))     \
        !          1093:     goto ADDR;                                 \
        !          1094: }
        !          1095: 
        !          1096: /* Now accept the simple address, or, for DImode only, an AND of a simple
        !          1097:    address that turns off the low three bits.  */
        !          1098: 
        !          1099: extern char *current_function_name;
        !          1100: 
        !          1101: #define GO_IF_LEGITIMATE_ADDRESS(MODE, X, ADDR) \
        !          1102: { GO_IF_LEGITIMATE_SIMPLE_ADDRESS (MODE, X, ADDR); \
        !          1103:   if ((MODE) == DImode                         \
        !          1104:       && GET_CODE (X) == AND                   \
        !          1105:       && GET_CODE (XEXP (X, 1)) == CONST_INT   \
        !          1106:       && INTVAL (XEXP (X, 1)) == -8)           \
        !          1107:     GO_IF_LEGITIMATE_SIMPLE_ADDRESS (MODE, XEXP (X, 0), ADDR); \
        !          1108:   if ((MODE) == Pmode && GET_CODE (X) == SYMBOL_REF    \
        !          1109:       && ! strcmp (XSTR (X, 0), current_function_name))        \
        !          1110:     goto ADDR;                                 \
        !          1111: }
        !          1112: 
        !          1113: /* Try machine-dependent ways of modifying an illegitimate address
        !          1114:    to be legitimate.  If we find one, return the new, valid address.
        !          1115:    This macro is used in only one place: `memory_address' in explow.c.
        !          1116: 
        !          1117:    OLDX is the address as it was before break_out_memory_refs was called.
        !          1118:    In some cases it is useful to look at this to decide what needs to be done.
        !          1119: 
        !          1120:    MODE and WIN are passed so that this macro can use
        !          1121:    GO_IF_LEGITIMATE_ADDRESS.
        !          1122: 
        !          1123:    It is always safe for this macro to do nothing.  It exists to recognize
        !          1124:    opportunities to optimize the output. 
        !          1125: 
        !          1126:    For the Alpha, there are three cases we handle:
        !          1127: 
        !          1128:    (1) If the address is (plus reg const_int) and the CONST_INT is not a
        !          1129:        valid offset, compute the high part of the constant and add it to the
        !          1130:        register.  Then our address is (plus temp low-part-const).
        !          1131:    (2) If the address is (const (plus FOO const_int)), find the low-order
        !          1132:        part of the CONST_INT.  Then load FOO plus any high-order part of the
        !          1133:        CONST_INT into a register.  Our address is (plus reg low-part-const).
        !          1134:        This is done to reduce the number of GOT entries.
        !          1135:    (3) If we have a (plus reg const), emit the load as in (2), then add
        !          1136:        the two registers, and finally generate (plus reg low-part-const) as
        !          1137:        our address.  */
        !          1138: 
        !          1139: #define LEGITIMIZE_ADDRESS(X,OLDX,MODE,WIN)                    \
        !          1140: { if (GET_CODE (X) == PLUS && GET_CODE (XEXP (X, 0)) == REG    \
        !          1141:       && GET_CODE (XEXP (X, 1)) == CONST_INT                   \
        !          1142:       && ! CONSTANT_ADDRESS_P (XEXP (X, 1)))                   \
        !          1143:     {                                                          \
        !          1144:       HOST_WIDE_INT val = INTVAL (XEXP (X, 1));                        \
        !          1145:       HOST_WIDE_INT lowpart = (val & 0xffff) - 2 * (val & 0x8000); \
        !          1146:       HOST_WIDE_INT highpart = val - lowpart;                  \
        !          1147:       rtx high = GEN_INT (highpart);                           \
        !          1148:       rtx temp = expand_binop (Pmode, add_optab, XEXP (x, 0),  \
        !          1149:                               high, NULL_RTX, 1, OPTAB_LIB_WIDEN); \
        !          1150:                                                                \
        !          1151:       (X) = plus_constant (temp, lowpart);                     \
        !          1152:       goto WIN;                                                        \
        !          1153:     }                                                          \
        !          1154:   else if (GET_CODE (X) == CONST                               \
        !          1155:           && GET_CODE (XEXP (X, 0)) == PLUS                    \
        !          1156:           && GET_CODE (XEXP (XEXP (X, 0), 1)) == CONST_INT)    \
        !          1157:     {                                                          \
        !          1158:       HOST_WIDE_INT val = INTVAL (XEXP (XEXP (X, 0), 1));      \
        !          1159:       HOST_WIDE_INT lowpart = (val & 0xffff) - 2 * (val & 0x8000); \
        !          1160:       HOST_WIDE_INT highpart = val - lowpart;                  \
        !          1161:       rtx high = XEXP (XEXP (X, 0), 0);                                \
        !          1162:                                                                \
        !          1163:       if (highpart)                                            \
        !          1164:        high = plus_constant (high, highpart);                  \
        !          1165:                                                                \
        !          1166:       (X) = plus_constant (force_reg (Pmode, high), lowpart);  \
        !          1167:       goto WIN;                                                        \
        !          1168:     }                                                          \
        !          1169:   else if (GET_CODE (X) == PLUS && GET_CODE (XEXP (X, 0)) == REG \
        !          1170:           && GET_CODE (XEXP (X, 1)) == CONST                   \
        !          1171:           && GET_CODE (XEXP (XEXP (X, 1), 0)) == PLUS          \
        !          1172:           && GET_CODE (XEXP (XEXP (XEXP (X, 1), 0), 1)) == CONST_INT) \
        !          1173:     {                                                          \
        !          1174:       HOST_WIDE_INT val = INTVAL (XEXP (XEXP (XEXP (X, 1), 0), 1)); \
        !          1175:       HOST_WIDE_INT lowpart = (val & 0xffff) - 2 * (val & 0x8000); \
        !          1176:       HOST_WIDE_INT highpart = val - lowpart;                  \
        !          1177:       rtx high = XEXP (XEXP (XEXP (X, 1), 0), 0);              \
        !          1178:                                                                \
        !          1179:       if (highpart)                                            \
        !          1180:        high = plus_constant (high, highpart);                  \
        !          1181:                                                                \
        !          1182:       high = expand_binop (Pmode, add_optab, XEXP (X, 0),      \
        !          1183:                           force_reg (Pmode, high),             \
        !          1184:                           high, 1, OPTAB_LIB_WIDEN);           \
        !          1185:       (X) = plus_constant (high, lowpart);                     \
        !          1186:       goto WIN;                                                        \
        !          1187:     }                                                          \
        !          1188: }
        !          1189: 
        !          1190: /* Go to LABEL if ADDR (a legitimate address expression)
        !          1191:    has an effect that depends on the machine mode it is used for.
        !          1192:    On the Alpha this is true only for the unaligned modes.   We can
        !          1193:    simplify this test since we know that the address must be valid.  */
        !          1194: 
        !          1195: #define GO_IF_MODE_DEPENDENT_ADDRESS(ADDR,LABEL)  \
        !          1196: { if (GET_CODE (ADDR) == AND) goto LABEL; }
        !          1197: 
        !          1198: /* Compute the cost of an address.  For the Alpha, all valid addresses are
        !          1199:    the same cost.  */
        !          1200: 
        !          1201: #define ADDRESS_COST(X)  0
        !          1202: 
        !          1203: /* Define this if some processing needs to be done immediately before
        !          1204:    emitting code for an insn.  */
        !          1205: 
        !          1206: /* #define FINAL_PRESCAN_INSN(INSN,OPERANDS,NOPERANDS) */
        !          1207: 
        !          1208: /* Specify the machine mode that this machine uses
        !          1209:    for the index in the tablejump instruction.  */
        !          1210: #define CASE_VECTOR_MODE SImode
        !          1211: 
        !          1212: /* Define this if the tablejump instruction expects the table
        !          1213:    to contain offsets from the address of the table.
        !          1214:    Do not define this if the table should contain absolute addresses.  */
        !          1215: /* #define CASE_VECTOR_PC_RELATIVE */
        !          1216: 
        !          1217: /* Specify the tree operation to be used to convert reals to integers.  */
        !          1218: #define IMPLICIT_FIX_EXPR FIX_ROUND_EXPR
        !          1219: 
        !          1220: /* This is the kind of divide that is easiest to do in the general case.  */
        !          1221: #define EASY_DIV_EXPR TRUNC_DIV_EXPR
        !          1222: 
        !          1223: /* Define this as 1 if `char' should by default be signed; else as 0.  */
        !          1224: #define DEFAULT_SIGNED_CHAR 1
        !          1225: 
        !          1226: /* This flag, if defined, says the same insns that convert to a signed fixnum
        !          1227:    also convert validly to an unsigned one.
        !          1228: 
        !          1229:    We actually lie a bit here as overflow conditions are different.  But
        !          1230:    they aren't being checked anyway.  */
        !          1231: 
        !          1232: #define FIXUNS_TRUNC_LIKE_FIX_TRUNC
        !          1233: 
        !          1234: /* Max number of bytes we can move to or from memory
        !          1235:    in one reasonably fast instruction.  */
        !          1236: 
        !          1237: #define MOVE_MAX 8
        !          1238: 
        !          1239: /* Largest number of bytes of an object that can be placed in a register.
        !          1240:    On the Alpha we have plenty of registers, so use TImode.  */
        !          1241: #define MAX_FIXED_MODE_SIZE    GET_MODE_BITSIZE (TImode)
        !          1242: 
        !          1243: /* Nonzero if access to memory by bytes is no faster than for words.
        !          1244:    Also non-zero if doing byte operations (specifically shifts) in registers
        !          1245:    is undesirable. 
        !          1246: 
        !          1247:    On the Alpha, we want to not use the byte operation and instead use
        !          1248:    masking operations to access fields; these will save instructions.  */
        !          1249: 
        !          1250: #define SLOW_BYTE_ACCESS       1
        !          1251: 
        !          1252: /* Define if operations between registers always perform the operation
        !          1253:    on the full register even if a narrower mode is specified.  */
        !          1254: #define WORD_REGISTER_OPERATIONS
        !          1255: 
        !          1256: /* Define if loading in MODE, an integral mode narrower than BITS_PER_WORD
        !          1257:    will either zero-extend or sign-extend.  The value of this macro should
        !          1258:    be the code that says which one of the two operations is implicitly
        !          1259:    done, NIL if none.  */
        !          1260: #define LOAD_EXTEND_OP(MODE) SIGN_EXTEND
        !          1261: 
        !          1262: /* Define if loading short immediate values into registers sign extends.  */
        !          1263: #define SHORT_IMMEDIATES_SIGN_EXTEND
        !          1264: 
        !          1265: /* Value is 1 if truncating an integer of INPREC bits to OUTPREC bits
        !          1266:    is done just by pretending it is already truncated.  */
        !          1267: #define TRULY_NOOP_TRUNCATION(OUTPREC, INPREC) 1
        !          1268: 
        !          1269: /* We assume that the store-condition-codes instructions store 0 for false
        !          1270:    and some other value for true.  This is the value stored for true.  */
        !          1271: 
        !          1272: #define STORE_FLAG_VALUE 1
        !          1273: 
        !          1274: /* Define the value returned by a floating-point comparison instruction.  */
        !          1275: 
        !          1276: #define FLOAT_STORE_FLAG_VALUE 0.5
        !          1277: 
        !          1278: /* Specify the machine mode that pointers have.
        !          1279:    After generation of rtl, the compiler makes no further distinction
        !          1280:    between pointers and any other objects of this machine mode.  */
        !          1281: #define Pmode DImode
        !          1282: 
        !          1283: /* Mode of a function address in a call instruction (for indexing purposes). */
        !          1284: 
        !          1285: #define FUNCTION_MODE Pmode
        !          1286: 
        !          1287: /* Define this if addresses of constant functions
        !          1288:    shouldn't be put through pseudo regs where they can be cse'd.
        !          1289:    Desirable on machines where ordinary constants are expensive
        !          1290:    but a CALL with constant address is cheap.
        !          1291: 
        !          1292:    We define this on the Alpha so that gen_call and gen_call_value
        !          1293:    get to see the SYMBOL_REF (for the hint field of the jsr).  It will
        !          1294:    then copy it into a register, thus actually letting the address be
        !          1295:    cse'ed.  */
        !          1296: 
        !          1297: #define NO_FUNCTION_CSE
        !          1298: 
        !          1299: /* Define this to be nonzero if shift instructions ignore all but the low-order
        !          1300:    few bits. */
        !          1301: #define SHIFT_COUNT_TRUNCATED 1
        !          1302: 
        !          1303: /* Use atexit for static constructors/destructors, instead of defining
        !          1304:    our own exit function.  */
        !          1305: #define HAVE_ATEXIT
        !          1306: 
        !          1307: /* Compute the cost of computing a constant rtl expression RTX
        !          1308:    whose rtx-code is CODE.  The body of this macro is a portion
        !          1309:    of a switch statement.  If the code is computed here,
        !          1310:    return it with a return statement.  Otherwise, break from the switch.
        !          1311: 
        !          1312:    We only care about the cost if it is valid in an insn, so all constants
        !          1313:    are cheap.  */
        !          1314: 
        !          1315: #define CONST_COSTS(RTX,CODE,OUTER_CODE) \
        !          1316:   case CONST_INT:                                              \
        !          1317:   case CONST_DOUBLE:                                           \
        !          1318:     return 0;                                                  \
        !          1319:   case CONST:                                                  \
        !          1320:   case SYMBOL_REF:                                             \
        !          1321:   case LABEL_REF:                                              \
        !          1322:     return 6;                                                  \
        !          1323:     
        !          1324: /* Provide the costs of a rtl expression.  This is in the body of a
        !          1325:    switch on CODE.  */
        !          1326:    
        !          1327: #define RTX_COSTS(X,CODE,OUTER_CODE)                   \
        !          1328:   case PLUS:                                           \
        !          1329:   case MINUS:                                          \
        !          1330:     if (GET_MODE_CLASS (GET_MODE (X)) == MODE_FLOAT)   \
        !          1331:       return COSTS_N_INSNS (6);                                \
        !          1332:     else if (GET_CODE (XEXP (X, 0)) == MULT            \
        !          1333:             && const48_operand (XEXP (XEXP (X, 0), 1), VOIDmode)) \
        !          1334:       return (2 + rtx_cost (XEXP (XEXP (X, 0), 0), OUTER_CODE) \
        !          1335:              + rtx_cost (XEXP (X, 1), OUTER_CODE));    \
        !          1336:     break;                                             \
        !          1337:   case MULT:                                           \
        !          1338:     if (GET_MODE_CLASS (GET_MODE (X)) == MODE_FLOAT)   \
        !          1339:       return COSTS_N_INSNS (6);                                \
        !          1340:     else if (GET_CODE (XEXP (X, 1)) != CONST_INT       \
        !          1341:             || exact_log2 (INTVAL (XEXP (X, 1))) < 0)  \
        !          1342:       return COSTS_N_INSNS (21);                       \
        !          1343:     else if (const48_operand (XEXP (X, 1), VOIDmode))  \
        !          1344:       break;                                           \
        !          1345:     return COSTS_N_INSNS (2);                          \
        !          1346:   case ASHIFT:                                         \
        !          1347:     if (GET_CODE (XEXP (X, 1)) == CONST_INT            \
        !          1348:        && INTVAL (XEXP (X, 1)) <= 3)                   \
        !          1349:       break;                                           \
        !          1350:     /* ... fall through ... */                         \
        !          1351:   case ASHIFTRT:  case LSHIFTRT:  case IF_THEN_ELSE:   \
        !          1352:     return COSTS_N_INSNS (2);                          \
        !          1353:   case DIV:                                            \
        !          1354:   case UDIV:                                           \
        !          1355:   case MOD:                                            \
        !          1356:   case UMOD:                                           \
        !          1357:     if (GET_MODE (X) == SFmode)                                \
        !          1358:       return COSTS_N_INSNS (34);                       \
        !          1359:     else if (GET_MODE (X) == DFmode)                   \
        !          1360:       return COSTS_N_INSNS (63);                       \
        !          1361:     else                                               \
        !          1362:       return COSTS_N_INSNS (70);                       \
        !          1363:   case MEM:                                            \
        !          1364:     return COSTS_N_INSNS (3);
        !          1365: 
        !          1366: /* Control the assembler format that we output.  */
        !          1367: 
        !          1368: /* Output at beginning of assembler file.  */
        !          1369: 
        !          1370: #define ASM_FILE_START(FILE)                                   \
        !          1371: {                                                              \
        !          1372:   alpha_write_verstamp (FILE);                                 \
        !          1373:   fprintf (FILE, "\t.set noreorder\n");                                \
        !          1374:   fprintf (FILE, "\t.set noat\n");                             \
        !          1375:   ASM_OUTPUT_SOURCE_FILENAME (FILE, main_input_filename);      \
        !          1376: }
        !          1377: 
        !          1378: /* Output to assembler file text saying following lines
        !          1379:    may contain character constants, extra white space, comments, etc.  */
        !          1380: 
        !          1381: #define ASM_APP_ON ""
        !          1382: 
        !          1383: /* Output to assembler file text saying following lines
        !          1384:    no longer contain unusual constructs.  */
        !          1385: 
        !          1386: #define ASM_APP_OFF ""
        !          1387: 
        !          1388: #define TEXT_SECTION_ASM_OP ".text"
        !          1389: 
        !          1390: /* Output before read-only data.  */
        !          1391: 
        !          1392: #define READONLY_DATA_SECTION_ASM_OP ".rdata"
        !          1393: 
        !          1394: /* Output before writable data.  */
        !          1395: 
        !          1396: #define DATA_SECTION_ASM_OP ".data"
        !          1397: 
        !          1398: /* Define an extra section for read-only data, a routine to enter it, and
        !          1399:    indicate that it is for read-only data.  */
        !          1400: 
        !          1401: #define EXTRA_SECTIONS readonly_data
        !          1402: 
        !          1403: #define EXTRA_SECTION_FUNCTIONS                                        \
        !          1404: void                                                           \
        !          1405: literal_section ()                                             \
        !          1406: {                                                              \
        !          1407:   if (in_section != readonly_data)                             \
        !          1408:     {                                                          \
        !          1409:       fprintf (asm_out_file, "%s\n", READONLY_DATA_SECTION_ASM_OP); \
        !          1410:       in_section = readonly_data;                              \
        !          1411:     }                                                          \
        !          1412: }                                                              \
        !          1413: 
        !          1414: #define READONLY_DATA_SECTION  literal_section
        !          1415: 
        !          1416: /* If we are referencing a function that is static or is known to be
        !          1417:    in this file, make the SYMBOL_REF special.  We can use this to see
        !          1418:    indicate that we can branch to this function without setting PV or
        !          1419:    restoring GP.  */
        !          1420: 
        !          1421: #define ENCODE_SECTION_INFO(DECL)  \
        !          1422:   if (TREE_CODE (DECL) == FUNCTION_DECL                        \
        !          1423:       && (TREE_ASM_WRITTEN (DECL) || ! TREE_PUBLIC (DECL))) \
        !          1424:     SYMBOL_REF_FLAG (XEXP (DECL_RTL (DECL), 0)) = 1;
        !          1425: 
        !          1426: /* How to refer to registers in assembler output.
        !          1427:    This sequence is indexed by compiler's hard-register-number (see above).  */
        !          1428: 
        !          1429: #define REGISTER_NAMES                                         \
        !          1430: {"$0", "$1", "$2", "$3", "$4", "$5", "$6", "$7", "$8",         \
        !          1431:  "$9", "$10", "$11", "$12", "$13", "$14", "$15",               \
        !          1432:  "$16", "$17", "$18", "$19", "$20", "$21", "$22", "$23",       \
        !          1433:  "$24", "$25", "$26", "$27", "$28", "$29", "$30", "AP",                \
        !          1434:  "$f0", "$f1", "$f2", "$f3", "$f4", "$f5", "$f6", "$f7", "$f8",        \
        !          1435:  "$f9", "$f10", "$f11", "$f12", "$f13", "$f14", "$f15",                \
        !          1436:  "$f16", "$f17", "$f18", "$f19", "$f20", "$f21", "$f22", "$f23",\
        !          1437:  "$f24", "$f25", "$f26", "$f27", "$f28", "$f29", "$f30", "$f31"}
        !          1438: 
        !          1439: /* How to renumber registers for dbx and gdb.  */
        !          1440: 
        !          1441: #define DBX_REGISTER_NUMBER(REGNO) (REGNO)
        !          1442: 
        !          1443: /* This is how to output the definition of a user-level label named NAME,
        !          1444:    such as the label on a static function or variable NAME.  */
        !          1445: 
        !          1446: #define ASM_OUTPUT_LABEL(FILE,NAME)    \
        !          1447:   do { assemble_name (FILE, NAME); fputs (":\n", FILE); } while (0)
        !          1448: 
        !          1449: /* This is how to output a command to make the user-level label named NAME
        !          1450:    defined for reference from other files.  */
        !          1451: 
        !          1452: #define ASM_GLOBALIZE_LABEL(FILE,NAME) \
        !          1453:   do { fputs ("\t.globl ", FILE); assemble_name (FILE, NAME); fputs ("\n", FILE);} while (0)
        !          1454: 
        !          1455: /* This is how to output a reference to a user-level label named NAME.
        !          1456:    `assemble_name' uses this.  */
        !          1457: 
        !          1458: #define ASM_OUTPUT_LABELREF(FILE,NAME) \
        !          1459:   fprintf (FILE, "%s", NAME)
        !          1460: 
        !          1461: /* This is how to output an internal numbered label where
        !          1462:    PREFIX is the class of label and NUM is the number within the class.  */
        !          1463: 
        !          1464: #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM)     \
        !          1465:   if ((PREFIX)[0] == 'L')                              \
        !          1466:     fprintf (FILE, "$%s%d:\n", & (PREFIX)[1], NUM + 32); \
        !          1467:   else                                                 \
        !          1468:     fprintf (FILE, "%s%d:\n", PREFIX, NUM);
        !          1469: 
        !          1470: /* This is how to output a label for a jump table.  Arguments are the same as
        !          1471:    for ASM_OUTPUT_INTERNAL_LABEL, except the insn for the jump table is
        !          1472:    passed. */
        !          1473: 
        !          1474: #define ASM_OUTPUT_CASE_LABEL(FILE,PREFIX,NUM,TABLEINSN)       \
        !          1475: { ASM_OUTPUT_ALIGN (FILE, 2); ASM_OUTPUT_INTERNAL_LABEL (FILE, PREFIX, NUM); }
        !          1476: 
        !          1477: /* This is how to store into the string LABEL
        !          1478:    the symbol_ref name of an internal numbered label where
        !          1479:    PREFIX is the class of label and NUM is the number within the class.
        !          1480:    This is suitable for output with `assemble_name'.  */
        !          1481: 
        !          1482: #define ASM_GENERATE_INTERNAL_LABEL(LABEL,PREFIX,NUM)  \
        !          1483:   if ((PREFIX)[0] == 'L')                              \
        !          1484:     sprintf (LABEL, "*$%s%d", & (PREFIX)[1], NUM + 32);        \
        !          1485:   else                                                 \
        !          1486:     sprintf (LABEL, "*%s%d", PREFIX, NUM)
        !          1487: 
        !          1488: /* This is how to output an assembler line defining a `double' constant.  */
        !          1489: 
        !          1490: #define ASM_OUTPUT_DOUBLE(FILE,VALUE)                                  \
        !          1491:   {                                                                    \
        !          1492:     if (REAL_VALUE_ISINF (VALUE)                                       \
        !          1493:         || REAL_VALUE_ISNAN (VALUE)                                    \
        !          1494:        || REAL_VALUE_MINUS_ZERO (VALUE))                               \
        !          1495:       {                                                                        \
        !          1496:        long t[2];                                                      \
        !          1497:        REAL_VALUE_TO_TARGET_DOUBLE ((VALUE), t);                       \
        !          1498:        fprintf (FILE, "\t.quad 0x%lx%08lx\n",                          \
        !          1499:                t[1] & 0xffffffff, t[0] & 0xffffffff);                  \
        !          1500:       }                                                                        \
        !          1501:     else                                                               \
        !          1502:       {                                                                        \
        !          1503:        char str[30];                                                   \
        !          1504:        REAL_VALUE_TO_DECIMAL (VALUE, "%.20e", str);                    \
        !          1505:        fprintf (FILE, "\t.t_floating %s\n", str);                      \
        !          1506:       }                                                                        \
        !          1507:   }
        !          1508: 
        !          1509: /* This is how to output an assembler line defining a `float' constant.  */
        !          1510: 
        !          1511: #define ASM_OUTPUT_FLOAT(FILE,VALUE)                                   \
        !          1512:   {                                                                    \
        !          1513:     if (REAL_VALUE_ISINF (VALUE)                                       \
        !          1514:         || REAL_VALUE_ISNAN (VALUE)                                    \
        !          1515:        || REAL_VALUE_MINUS_ZERO (VALUE))                               \
        !          1516:       {                                                                        \
        !          1517:        long t;                                                         \
        !          1518:        REAL_VALUE_TO_TARGET_SINGLE ((VALUE), t);                       \
        !          1519:        fprintf (FILE, "\t.long 0x%lx\n", t & 0xffffffff);              \
        !          1520:       }                                                                        \
        !          1521:     else                                                               \
        !          1522:       {                                                                        \
        !          1523:        char str[30];                                                   \
        !          1524:        REAL_VALUE_TO_DECIMAL ((VALUE), "%.20e", str);                  \
        !          1525:        fprintf (FILE, "\t.s_floating %s\n", str);                      \
        !          1526:       }                                                                        \
        !          1527:   }
        !          1528:   
        !          1529: /* This is how to output an assembler line defining an `int' constant.  */
        !          1530: 
        !          1531: #define ASM_OUTPUT_INT(FILE,VALUE)             \
        !          1532:   fprintf (FILE, "\t.long %d\n",               \
        !          1533:     (GET_CODE (VALUE) == CONST_INT             \
        !          1534:      ? INTVAL (VALUE) & 0xffffffff : (abort (), 0)))
        !          1535: 
        !          1536: /* This is how to output an assembler line defining a `long' constant.  */
        !          1537: 
        !          1538: #define ASM_OUTPUT_DOUBLE_INT(FILE,VALUE)      \
        !          1539: ( fprintf (FILE, "\t.quad "),                  \
        !          1540:   output_addr_const (FILE, (VALUE)),           \
        !          1541:   fprintf (FILE, "\n"))
        !          1542: 
        !          1543: /* Likewise for `char' and `short' constants.  */
        !          1544: 
        !          1545: #define ASM_OUTPUT_SHORT(FILE,VALUE)  \
        !          1546:   fprintf (FILE, "\t.word %d\n",               \
        !          1547:     (GET_CODE (VALUE) == CONST_INT             \
        !          1548:      ? INTVAL (VALUE) & 0xffff : (abort (), 0)))
        !          1549: 
        !          1550: #define ASM_OUTPUT_CHAR(FILE,VALUE)            \
        !          1551:   fprintf (FILE, "\t.byte %d\n",               \
        !          1552:     (GET_CODE (VALUE) == CONST_INT             \
        !          1553:      ? INTVAL (VALUE) & 0xff : (abort (), 0)))
        !          1554: 
        !          1555: /* We use the default ASCII-output routine, except that we don't write more
        !          1556:    than 50 characters since the assembler doesn't support very long lines.  */
        !          1557: 
        !          1558: #define ASM_OUTPUT_ASCII(MYFILE, MYSTRING, MYLENGTH) \
        !          1559:   do {                                                                       \
        !          1560:     FILE *_hide_asm_out_file = (MYFILE);                                     \
        !          1561:     unsigned char *_hide_p = (unsigned char *) (MYSTRING);                   \
        !          1562:     int _hide_thissize = (MYLENGTH);                                         \
        !          1563:     int _size_so_far = 0;                                                    \
        !          1564:     {                                                                        \
        !          1565:       FILE *asm_out_file = _hide_asm_out_file;                               \
        !          1566:       unsigned char *p = _hide_p;                                            \
        !          1567:       int thissize = _hide_thissize;                                         \
        !          1568:       int i;                                                                 \
        !          1569:       fprintf (asm_out_file, "\t.ascii \"");                                 \
        !          1570:                                                                              \
        !          1571:       for (i = 0; i < thissize; i++)                                         \
        !          1572:        {                                                                     \
        !          1573:          register int c = p[i];                                              \
        !          1574:                                                                              \
        !          1575:          if (_size_so_far ++ > 50 && i < thissize - 4)                       \
        !          1576:            _size_so_far = 0, fprintf (asm_out_file, "\"\n\t.ascii \"");      \
        !          1577:                                                                              \
        !          1578:          if (c == '\"' || c == '\\')                                         \
        !          1579:            putc ('\\', asm_out_file);                                        \
        !          1580:          if (c >= ' ' && c < 0177)                                           \
        !          1581:            putc (c, asm_out_file);                                           \
        !          1582:          else                                                                \
        !          1583:            {                                                                 \
        !          1584:              fprintf (asm_out_file, "\\%o", c);                              \
        !          1585:              /* After an octal-escape, if a digit follows,                   \
        !          1586:                 terminate one string constant and start another.             \
        !          1587:                 The Vax assembler fails to stop reading the escape           \
        !          1588:                 after three digits, so this is the only way we               \
        !          1589:                 can get it to parse the data properly.  */                   \
        !          1590:              if (i < thissize - 1                                            \
        !          1591:                  && p[i + 1] >= '0' && p[i + 1] <= '9')                      \
        !          1592:                fprintf (asm_out_file, "\"\n\t.ascii \"");                    \
        !          1593:          }                                                                   \
        !          1594:        }                                                                     \
        !          1595:       fprintf (asm_out_file, "\"\n");                                        \
        !          1596:     }                                                                        \
        !          1597:   }                                                                          \
        !          1598:   while (0)
        !          1599: /* This is how to output an insn to push a register on the stack.
        !          1600:    It need not be very fast code.  */
        !          1601: 
        !          1602: #define ASM_OUTPUT_REG_PUSH(FILE,REGNO)                                        \
        !          1603:  fprintf (FILE, "\tsubq $30,8,$30\n\tst%s $%s%d,0($30)\n",             \
        !          1604:          (REGNO) > 32 ? "t" : "q", (REGNO) > 32 ? "f" : "",            \
        !          1605:          (REGNO) & 31);
        !          1606: 
        !          1607: /* This is how to output an insn to pop a register from the stack.
        !          1608:    It need not be very fast code.  */
        !          1609: 
        !          1610: #define ASM_OUTPUT_REG_POP(FILE,REGNO)                                 \
        !          1611:   fprintf (FILE, "\tld%s $%s%d,0($30)\n\taddq $30,8,$30\n",            \
        !          1612:          (REGNO) > 32 ? "t" : "q", (REGNO) > 32 ? "f" : "",            \
        !          1613:          (REGNO) & 31);
        !          1614: 
        !          1615: /* This is how to output an assembler line for a numeric constant byte.  */
        !          1616: 
        !          1617: #define ASM_OUTPUT_BYTE(FILE,VALUE)  \
        !          1618:   fprintf (FILE, "\t.byte 0x%x\n", (VALUE) & 0xff)
        !          1619: 
        !          1620: /* This is how to output an element of a case-vector that is absolute.  */
        !          1621: 
        !          1622: #define ASM_OUTPUT_ADDR_VEC_ELT(FILE, VALUE)  \
        !          1623:   fprintf (FILE, "\t.gprel32 $%d\n", (VALUE) + 32)
        !          1624: 
        !          1625: /* This is how to output an element of a case-vector that is relative.
        !          1626:    (Alpha does not use such vectors, but we must define this macro anyway.)  */
        !          1627: 
        !          1628: #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL)  abort ()
        !          1629: 
        !          1630: /* This is how to output an assembler line
        !          1631:    that says to advance the location counter
        !          1632:    to a multiple of 2**LOG bytes.  */
        !          1633: 
        !          1634: #define ASM_OUTPUT_ALIGN(FILE,LOG)     \
        !          1635:   if ((LOG) != 0)                      \
        !          1636:     fprintf (FILE, "\t.align %d\n", LOG);
        !          1637: 
        !          1638: /* This is how to advance the location counter by SIZE bytes.  */
        !          1639: 
        !          1640: #define ASM_OUTPUT_SKIP(FILE,SIZE)  \
        !          1641:   fprintf (FILE, "\t.space %d\n", (SIZE))
        !          1642: 
        !          1643: /* This says how to output an assembler line
        !          1644:    to define a global common symbol.  */
        !          1645: 
        !          1646: #define ASM_OUTPUT_COMMON(FILE, NAME, SIZE, ROUNDED)  \
        !          1647: ( fputs ("\t.comm ", (FILE)),                  \
        !          1648:   assemble_name ((FILE), (NAME)),              \
        !          1649:   fprintf ((FILE), ",%d\n", (SIZE)))
        !          1650: 
        !          1651: /* This says how to output an assembler line
        !          1652:    to define a local common symbol.  */
        !          1653: 
        !          1654: #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE,ROUNDED)     \
        !          1655: ( fputs ("\t.lcomm ", (FILE)),                         \
        !          1656:   assemble_name ((FILE), (NAME)),                      \
        !          1657:   fprintf ((FILE), ",%d\n", (SIZE)))
        !          1658: 
        !          1659: /* Store in OUTPUT a string (made with alloca) containing
        !          1660:    an assembler-name for a local static variable named NAME.
        !          1661:    LABELNO is an integer which is different for each call.  */
        !          1662: 
        !          1663: #define ASM_FORMAT_PRIVATE_NAME(OUTPUT, NAME, LABELNO) \
        !          1664: ( (OUTPUT) = (char *) alloca (strlen ((NAME)) + 10),   \
        !          1665:   sprintf ((OUTPUT), "%s.%d", (NAME), (LABELNO)))
        !          1666: 
        !          1667: /* Define the parentheses used to group arithmetic operations
        !          1668:    in assembler code.  */
        !          1669: 
        !          1670: #define ASM_OPEN_PAREN "("
        !          1671: #define ASM_CLOSE_PAREN ")"
        !          1672: 
        !          1673: /* Define results of standard character escape sequences.  */
        !          1674: #define TARGET_BELL 007
        !          1675: #define TARGET_BS 010
        !          1676: #define TARGET_TAB 011
        !          1677: #define TARGET_NEWLINE 012
        !          1678: #define TARGET_VT 013
        !          1679: #define TARGET_FF 014
        !          1680: #define TARGET_CR 015
        !          1681: 
        !          1682: /* Print operand X (an rtx) in assembler syntax to file FILE.
        !          1683:    CODE is a letter or dot (`z' in `%z0') or 0 if no letter was specified.
        !          1684:    For `%' followed by punctuation, CODE is the punctuation and X is null.  */
        !          1685: 
        !          1686: #define PRINT_OPERAND(FILE, X, CODE)  print_operand (FILE, X, CODE)
        !          1687: 
        !          1688: /* Determine which codes are valid without a following integer.  These must
        !          1689:    not be alphabetic.  */
        !          1690: 
        !          1691: #define PRINT_OPERAND_PUNCT_VALID_P(CODE) 0
        !          1692: 
        !          1693: /* Print a memory address as an operand to reference that memory location.  */
        !          1694: 
        !          1695: #define PRINT_OPERAND_ADDRESS(FILE, ADDR)              \
        !          1696: { rtx addr = (ADDR);                                   \
        !          1697:   int basereg = 31;                                    \
        !          1698:   HOST_WIDE_INT offset = 0;                            \
        !          1699:                                                        \
        !          1700:   if (GET_CODE (addr) == AND)                          \
        !          1701:     addr = XEXP (addr, 0);                             \
        !          1702:                                                        \
        !          1703:   if (GET_CODE (addr) == REG)                          \
        !          1704:     basereg = REGNO (addr);                            \
        !          1705:   else if (GET_CODE (addr) == CONST_INT)               \
        !          1706:     offset = INTVAL (addr);                            \
        !          1707:   else if (GET_CODE (addr) == PLUS                     \
        !          1708:           && GET_CODE (XEXP (addr, 0)) == REG          \
        !          1709:           && GET_CODE (XEXP (addr, 1)) == CONST_INT)   \
        !          1710:     basereg = REGNO (XEXP (addr, 0)), offset = INTVAL (XEXP (addr, 1)); \
        !          1711:   else                                                 \
        !          1712:     abort ();                                          \
        !          1713:                                                        \
        !          1714:   fprintf (FILE, "%d($%d)", offset, basereg);          \
        !          1715: }
        !          1716: /* Define the codes that are matched by predicates in alpha.c.  */
        !          1717: 
        !          1718: #define PREDICATE_CODES \
        !          1719:   {"reg_or_0_operand", {SUBREG, REG, CONST_INT}},      \
        !          1720:   {"reg_or_6bit_operand", {SUBREG, REG, CONST_INT}},   \
        !          1721:   {"reg_or_8bit_operand", {SUBREG, REG, CONST_INT}},   \
        !          1722:   {"reg_or_cint_operand", {SUBREG, REG, CONST_INT}},   \
        !          1723:   {"add_operand", {SUBREG, REG, CONST_INT}},           \
        !          1724:   {"sext_add_operand", {SUBREG, REG, CONST_INT}},      \
        !          1725:   {"const48_operand", {CONST_INT}},                    \
        !          1726:   {"and_operand", {SUBREG, REG, CONST_INT}},           \
        !          1727:   {"mode_mask_operand", {CONST_INT}},                  \
        !          1728:   {"mul8_operand", {CONST_INT}},                       \
        !          1729:   {"mode_width_operand", {CONST_INT}},                 \
        !          1730:   {"reg_or_fp0_operand", {SUBREG, REG, CONST_DOUBLE}}, \
        !          1731:   {"alpha_comparison_operator", {EQ, LE, LT, LEU, LTU}}, \
        !          1732:   {"signed_comparison_operator", {EQ, NE, LE, LT, GE, GT}}, \
        !          1733:   {"divmod_operator", {DIV, MOD, UDIV, UMOD}},         \
        !          1734:   {"fp0_operand", {CONST_DOUBLE}},                     \
        !          1735:   {"current_file_function_operand", {SYMBOL_REF}},     \
        !          1736:   {"input_operand", {SUBREG, REG, MEM, CONST_INT, CONST_DOUBLE,        \
        !          1737:                     SYMBOL_REF, CONST, LABEL_REF}},    \
        !          1738:   {"aligned_memory_operand", {MEM}},                   \
        !          1739:   {"unaligned_memory_operand", {MEM}},                 \
        !          1740:   {"any_memory_operand", {MEM}},
        !          1741: 
        !          1742: /* Definitions for debugging.  */
        !          1743: 
        !          1744: #define SDB_DEBUGGING_INFO             /* generate info for mips-tfile */
        !          1745: #define DBX_DEBUGGING_INFO             /* generate embedded stabs */
        !          1746: #define MIPS_DEBUGGING_INFO            /* MIPS specific debugging info */
        !          1747: 
        !          1748: #ifndef PREFERRED_DEBUGGING_TYPE       /* assume SDB_DEBUGGING_INFO */
        !          1749: #define PREFERRED_DEBUGGING_TYPE ((len > 1 && !strncmp (str, "ggdb", len)) ? DBX_DEBUG : SDB_DEBUG)
        !          1750: #endif
        !          1751: 
        !          1752: 
        !          1753: /* Correct the offset of automatic variables and arguments.  Note that
        !          1754:    the Alpha debug format wants all automatic variables and arguments
        !          1755:    to be in terms of two different offsets from the virtual frame pointer,
        !          1756:    which is the stack pointer before any adjustment in the function.
        !          1757:    The offset for the argument pointer is fixed for the native compiler,
        !          1758:    it is either zero (for the no arguments case) or large enough to hold
        !          1759:    all argument registers.
        !          1760:    The offset for the auto pointer is the fourth argument to the .frame
        !          1761:    directive (local_offset).
        !          1762:    To stay compatible with the native tools we use the same offsets
        !          1763:    from the virtual frame pointer and adjust the debugger arg/auto offsets
        !          1764:    accordingly. These debugger offsets are set up in output_prolog.  */
        !          1765: 
        !          1766: long alpha_arg_offset;
        !          1767: long alpha_auto_offset;
        !          1768: #define DEBUGGER_AUTO_OFFSET(X) \
        !          1769:   ((GET_CODE (X) == PLUS ? INTVAL (XEXP (X, 1)) : 0) + alpha_auto_offset)
        !          1770: #define DEBUGGER_ARG_OFFSET(OFFSET, X) (OFFSET + alpha_arg_offset)
        !          1771: 
        !          1772: 
        !          1773: #define ASM_OUTPUT_SOURCE_LINE(STREAM, LINE)                           \
        !          1774:   alpha_output_lineno (STREAM, LINE)
        !          1775: extern void alpha_output_lineno ();
        !          1776: 
        !          1777: #define ASM_OUTPUT_SOURCE_FILENAME(STREAM, NAME)                       \
        !          1778:   alpha_output_filename (STREAM, NAME)
        !          1779: extern void alpha_output_filename ();
        !          1780: 
        !          1781: 
        !          1782: /* mips-tfile.c limits us to strings of one page.  */
        !          1783: #define DBX_CONTIN_LENGTH 4000
        !          1784: 
        !          1785: /* By default, turn on GDB extensions.  */
        !          1786: #define DEFAULT_GDB_EXTENSIONS 1
        !          1787: 
        !          1788: /* If we are smuggling stabs through the ALPHA ECOFF object
        !          1789:    format, put a comment in front of the .stab<x> operation so
        !          1790:    that the ALPHA assembler does not choke.  The mips-tfile program
        !          1791:    will correctly put the stab into the object file.  */
        !          1792: 
        !          1793: #define ASM_STABS_OP   ((TARGET_GAS) ? ".stabs" : " #.stabs")
        !          1794: #define ASM_STABN_OP   ((TARGET_GAS) ? ".stabn" : " #.stabn")
        !          1795: #define ASM_STABD_OP   ((TARGET_GAS) ? ".stabd" : " #.stabd")
        !          1796: 
        !          1797: /* Forward references to tags are allowed.  */
        !          1798: #define SDB_ALLOW_FORWARD_REFERENCES
        !          1799: 
        !          1800: /* Unknown tags are also allowed.  */
        !          1801: #define SDB_ALLOW_UNKNOWN_REFERENCES
        !          1802: 
        !          1803: #define PUT_SDB_DEF(a)                                 \
        !          1804: do {                                                   \
        !          1805:   fprintf (asm_out_file, "\t%s.def\t",                 \
        !          1806:           (TARGET_GAS) ? "" : "#");                    \
        !          1807:   ASM_OUTPUT_LABELREF (asm_out_file, a);               \
        !          1808:   fputc (';', asm_out_file);                           \
        !          1809: } while (0)
        !          1810: 
        !          1811: #define PUT_SDB_PLAIN_DEF(a)                           \
        !          1812: do {                                                   \
        !          1813:   fprintf (asm_out_file, "\t%s.def\t.%s;",             \
        !          1814:           (TARGET_GAS) ? "" : "#", (a));               \
        !          1815: } while (0)
        !          1816: 
        !          1817: #define PUT_SDB_TYPE(a)                                        \
        !          1818: do {                                                   \
        !          1819:   fprintf (asm_out_file, "\t.type\t0x%x;", (a));       \
        !          1820: } while (0)
        !          1821: 
        !          1822: /* For block start and end, we create labels, so that
        !          1823:    later we can figure out where the correct offset is.
        !          1824:    The normal .ent/.end serve well enough for functions,
        !          1825:    so those are just commented out.  */
        !          1826: 
        !          1827: extern int sdb_label_count;            /* block start/end next label # */
        !          1828: 
        !          1829: #define PUT_SDB_BLOCK_START(LINE)                      \
        !          1830: do {                                                   \
        !          1831:   fprintf (asm_out_file,                               \
        !          1832:           "$Lb%d:\n\t%s.begin\t$Lb%d\t%d\n",           \
        !          1833:           sdb_label_count,                             \
        !          1834:           (TARGET_GAS) ? "" : "#",                     \
        !          1835:           sdb_label_count,                             \
        !          1836:           (LINE));                                     \
        !          1837:   sdb_label_count++;                                   \
        !          1838: } while (0)
        !          1839: 
        !          1840: #define PUT_SDB_BLOCK_END(LINE)                                \
        !          1841: do {                                                   \
        !          1842:   fprintf (asm_out_file,                               \
        !          1843:           "$Le%d:\n\t%s.bend\t$Le%d\t%d\n",            \
        !          1844:           sdb_label_count,                             \
        !          1845:           (TARGET_GAS) ? "" : "#",                     \
        !          1846:           sdb_label_count,                             \
        !          1847:           (LINE));                                     \
        !          1848:   sdb_label_count++;                                   \
        !          1849: } while (0)
        !          1850: 
        !          1851: #define PUT_SDB_FUNCTION_START(LINE)
        !          1852: 
        !          1853: #define PUT_SDB_FUNCTION_END(LINE)
        !          1854: 
        !          1855: #define PUT_SDB_EPILOGUE_END(NAME)
        !          1856: 
        !          1857: /* Specify to run a post-processor, mips-tfile after the assembler
        !          1858:    has run to stuff the ecoff debug information into the object file.
        !          1859:    This is needed because the Alpha assembler provides no way
        !          1860:    of specifying such information in the assembly file.  */
        !          1861: 
        !          1862: #if (TARGET_DEFAULT & MASK_GAS) != 0
        !          1863: 
        !          1864: #define ASM_FINAL_SPEC "\
        !          1865: %{malpha-as: %{!mno-mips-tfile: \
        !          1866:        \n mips-tfile %{v*: -v} \
        !          1867:                %{K: -I %b.o~} \
        !          1868:                %{!K: %{save-temps: -I %b.o~}} \
        !          1869:                %{c:%W{o*}%{!o*:-o %b.o}}%{!c:-o %U.o} \
        !          1870:                %{.s:%i} %{!.s:%g.s}}}"
        !          1871: 
        !          1872: #else
        !          1873: #define ASM_FINAL_SPEC "\
        !          1874: %{!mgas: %{!mno-mips-tfile: \
        !          1875:        \n mips-tfile %{v*: -v} \
        !          1876:                %{K: -I %b.o~} \
        !          1877:                %{!K: %{save-temps: -I %b.o~}} \
        !          1878:                %{c:%W{o*}%{!o*:-o %b.o}}%{!c:-o %U.o} \
        !          1879:                %{.s:%i} %{!.s:%g.s}}}"
        !          1880: 
        !          1881: #endif
        !          1882: 
        !          1883: /* Macros for mips-tfile.c to encapsulate stabs in ECOFF, and for
        !          1884:    mips-tdump.c to print them out.
        !          1885: 
        !          1886:    These must match the corresponding definitions in gdb/mipsread.c.
        !          1887:    Unfortunately, gcc and gdb do not currently share any directories. */
        !          1888: 
        !          1889: #define CODE_MASK 0x8F300
        !          1890: #define MIPS_IS_STAB(sym) (((sym)->index & 0xFFF00) == CODE_MASK)
        !          1891: #define MIPS_MARK_STAB(code) ((code)+CODE_MASK)
        !          1892: #define MIPS_UNMARK_STAB(code) ((code)-CODE_MASK)
        !          1893: 
        !          1894: /* Override some mips-tfile definitions.  */
        !          1895: 
        !          1896: #define SHASH_SIZE 511
        !          1897: #define THASH_SIZE 55

unix.superglobalmegacorp.com

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