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

1.1     ! root        1: /* Definitions of target machine for GNU compiler, for the HP Spectrum.
        !             2:    Copyright (C) 1992, 1993 Free Software Foundation, Inc.
        !             3:    Contributed by Michael Tiemann ([email protected])
        !             4:    and Tim Moore ([email protected]) of the Center for
        !             5:    Software Science at the University of Utah.
        !             6: 
        !             7: This file is part of GNU CC.
        !             8: 
        !             9: GNU CC is free software; you can redistribute it and/or modify
        !            10: it under the terms of the GNU General Public License as published by
        !            11: the Free Software Foundation; either version 1, or (at your option)
        !            12: any later version.
        !            13: 
        !            14: GNU CC is distributed in the hope that it will be useful,
        !            15: but WITHOUT ANY WARRANTY; without even the implied warranty of
        !            16: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
        !            17: GNU General Public License for more details.
        !            18: 
        !            19: You should have received a copy of the GNU General Public License
        !            20: along with GNU CC; see the file COPYING.  If not, write to
        !            21: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
        !            22: 
        !            23: enum cmp_type                          /* comparison type */
        !            24: {
        !            25:   CMP_SI,                              /* compare integers */
        !            26:   CMP_SF,                              /* compare single precision floats */
        !            27:   CMP_DF,                              /* compare double precision floats */
        !            28:   CMP_MAX                              /* max comparison type */
        !            29: };
        !            30: 
        !            31: /* Print subsidiary information on the compiler version in use.  */
        !            32: 
        !            33: #ifdef NeXT_ASM
        !            34: #define TARGET_VERSION fprintf (stderr, " (hppa, NeXT syntax)");
        !            35: #else
        !            36: #define TARGET_VERSION fprintf (stderr, " (hppa, HPUX syntax)");
        !            37: #endif
        !            38: 
        !            39: /* Run-time compilation parameters selecting different hardware subsets.  */
        !            40: 
        !            41: extern int target_flags;
        !            42: 
        !            43: /* compile code for HP-PA 1.1 ("Snake") */
        !            44: 
        !            45: #define TARGET_SNAKE (target_flags & 1)
        !            46: 
        !            47: /* Disable all FP registers (they all become fixed).  This may be necessary
        !            48:    for compiling kernels which perform lazy context switching of FP regs.
        !            49:    Note if you use this option and try to perform floating point operations 
        !            50:    the compiler will abort!  */
        !            51: 
        !            52: #define TARGET_DISABLE_FPREGS (target_flags & 2)
        !            53: 
        !            54: /* Allow unconditional jumps in the delay slots of call instructions.  */
        !            55: #define TARGET_JUMP_IN_DELAY (target_flags & 8)
        !            56: 
        !            57: /* Force all function calls to indirect addressing via a register.  This
        !            58:    avoids lossage when the function is very far away from the current PC.
        !            59: 
        !            60:    ??? What about simple jumps, they can suffer from the same problem.  
        !            61:    Would require significant surgery in pa.md.  */
        !            62: 
        !            63: #define TARGET_LONG_CALLS (target_flags & 16)
        !            64: 
        !            65: /* Disable indexed addressing modes.  */
        !            66: 
        !            67: #define TARGET_DISABLE_INDEXING (target_flags & 32)
        !            68: 
        !            69: /* Emit directives only understood by GAS.  This allows parameter
        !            70:    relocations to work for static functions.  There is no way
        !            71:    to make them work the HP assembler at this time. 
        !            72: 
        !            73:    Also forces a colon to be tacked onto the end of local and
        !            74:    global labes.  */
        !            75: 
        !            76: #define TARGET_GAS (target_flags & 128)
        !            77: 
        !            78: /* For all calls to symbols, emit a local stub that does a far
        !            79:    call and then branch locally (using the pseudo instruction jbsr) 
        !            80:    to that stub.  The assembler will then generate a local branch-and-
        !            81:    link instruction in place if the jbsr instruction, and add a
        !            82:    relocation entry to the object file so that the link editor may
        !            83:    relocate where to jump without actually enlarging the object file. */
        !            84: 
        !            85: #define TARGET_STUB_CALLS (target_flags & 256)
        !            86: 
        !            87: /* Macro to define tables used to set the flags.
        !            88:    This is a list in braces of pairs in braces,
        !            89:    each pair being { "NAME", VALUE }
        !            90:    where VALUE is the bits to set or minus the bits to clear.
        !            91:    An empty string NAME is used to identify the default VALUE.  */
        !            92: 
        !            93: #define TARGET_SWITCHES \
        !            94:   {{"snake", 1},               \
        !            95:    {"nosnake", -1},            \
        !            96:    {"pa-risc-1-0", -1},                \
        !            97:    {"pa-risc-1-1", 1},         \
        !            98:    {"disable-fpregs", 2},      \
        !            99:    {"no-disable-fpregs", 2},   \
        !           100:    {"jump-in-delay", 8},       \
        !           101:    {"no-jump-in-delay", -8},   \
        !           102:    {"long-calls", 16},         \
        !           103:    {"no-long-calls", -16},     \
        !           104:    {"disable-indexing", 32},   \
        !           105:    {"no-disable-indexing", -32},\
        !           106:    {"gas", 128},               \
        !           107:    {"no-gas", -128},           \
        !           108:    {"stub-calls", 256},         \
        !           109:    {"no-stub-calls", -256},     \
        !           110:    { "", TARGET_DEFAULT}}
        !           111: 
        !           112: #ifndef TARGET_DEFAULT
        !           113: #define TARGET_DEFAULT 128             /* TARGET_GAS + TARGET_JUMP_IN_DELAY */
        !           114: #endif
        !           115: 
        !           116: #define DBX_DEBUGGING_INFO
        !           117: #define DEFAULT_GDB_EXTENSIONS 1
        !           118: 
        !           119: /* Only lables should ever begin in colunm zero.  */
        !           120: #define ASM_STABS_OP "\t.stabs"
        !           121: #define ASM_STABN_OP "\t.stabn"
        !           122: 
        !           123: #if (TARGET_DEFAULT & 1) == 0
        !           124: #define CPP_SPEC "%{msnake:-D__hp9000s700 -D_PA_RISC1_1}\
        !           125:  %{mpa-risc-1-1:-D__hp9000s700 -D_PA_RISC1_1}"
        !           126: #else
        !           127: #define CPP_SPEC "%{!mpa-risc-1-0:%{!mnosnake:-D__hp9000s700 -D_PA_RISC1_1}}"
        !           128: #endif
        !           129: 
        !           130: /* Defines for a K&R CC */
        !           131: 
        !           132: #define CC1_SPEC "%{pg:} %{p:}"
        !           133:   
        !           134: #define LINK_SPEC "-u main"
        !           135: 
        !           136: /* Allow $ in identifiers.  */
        !           137: #define DOLLARS_IN_IDENTIFIERS 2
        !           138: 
        !           139: /* Make gcc agree with <machine/ansi.h> */
        !           140: 
        !           141: #define SIZE_TYPE "unsigned int"
        !           142: #define PTRDIFF_TYPE "int"
        !           143: #define WCHAR_TYPE "short unsigned int"
        !           144: #define WCHAR_TYPE_SIZE 16
        !           145: 
        !           146: /* Sometimes certain combinations of command options do not make sense
        !           147:    on a particular target machine.  You can define a macro
        !           148:    `OVERRIDE_OPTIONS' to take account of this.  This macro, if
        !           149:    defined, is executed once just after all the command options have
        !           150:    been parsed.
        !           151: 
        !           152:    On the PA, it is used to explicitly warn the user that -fpic and -fPIC
        !           153:    do not work.  */
        !           154: 
        !           155: #define OVERRIDE_OPTIONS \
        !           156: {                                                              \
        !           157:   if (flag_pic != 0)                                           \
        !           158:     warning ("-fpic and -fPIC are not supported on the PA.");  \
        !           159: }
        !           160: 
        !           161: /* Omit frame pointer at high optimization levels.  */
        !           162:   
        !           163: #define OPTIMIZATION_OPTIONS(OPTIMIZE) \
        !           164: {                                                              \
        !           165:   if (OPTIMIZE >= 2)                                           \
        !           166:     flag_omit_frame_pointer = 1;                               \
        !           167: }
        !           168: 
        !           169: /* Names to predefine in the preprocessor for this target machine.  */
        !           170: 
        !           171: #define CPP_PREDEFINES "-Dhppa -Dhp9000s800 -D__hp9000s800 -Dhp9k8 -Dunix -D_HPUX_SOURCE -Dhp9000 -Dhp800 -Dspectrum -DREVARGV -Asystem(unix) -Asystem(bsd) -Acpu(hppa) -Amachine(hppa)"
        !           172: 
        !           173: /* target machine storage layout */
        !           174: 
        !           175: /* Define this if most significant bit is lowest numbered
        !           176:    in instructions that operate on numbered bit-fields.  */
        !           177: #define BITS_BIG_ENDIAN 1
        !           178: 
        !           179: /* Define this if most significant byte of a word is the lowest numbered.  */
        !           180: /* That is true on the HP-PA.  */
        !           181: #define BYTES_BIG_ENDIAN 1
        !           182: 
        !           183: /* Define this if most significant word of a multiword number is lowest
        !           184:    numbered.  */
        !           185: /* For the HP-PA we can decide arbitrarily
        !           186:    since there are no machine instructions for them.  */
        !           187: #define WORDS_BIG_ENDIAN 1
        !           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 32
        !           197: 
        !           198: /* Width of a word, in units (bytes).  */
        !           199: #define UNITS_PER_WORD 4
        !           200: 
        !           201: /* Width in bits of a pointer.
        !           202:    See also the macro `Pmode' defined below.  */
        !           203: #define POINTER_SIZE 32
        !           204: 
        !           205: /* Allocation boundary (in *bits*) for storing arguments in argument list.  */
        !           206: #define PARM_BOUNDARY 32
        !           207: 
        !           208: /* Largest alignment required for any stack parameter, in bits.
        !           209:    Don't define this if it is equal to PARM_BOUNDARY */
        !           210: #define MAX_PARM_BOUNDARY 64
        !           211: 
        !           212: /* Boundary (in *bits*) on which stack pointer should be aligned.  */
        !           213: #define STACK_BOUNDARY 512
        !           214: 
        !           215: /* Allocation boundary (in *bits*) for the code of a function.  */
        !           216: #define FUNCTION_BOUNDARY 32
        !           217: 
        !           218: /* Alignment of field after `int : 0' in a structure.  */
        !           219: #define EMPTY_FIELD_BOUNDARY 32
        !           220: 
        !           221: /* Every structure's size must be a multiple of this.  */
        !           222: #define STRUCTURE_SIZE_BOUNDARY 8
        !           223: 
        !           224: /* A bitfield declared as `int' forces `int' alignment for the struct.  */
        !           225: #define PCC_BITFIELD_TYPE_MATTERS 1
        !           226: 
        !           227: /* No data type wants to be aligned rounder than this.  */
        !           228: #define BIGGEST_ALIGNMENT 64
        !           229: 
        !           230: /* Get around hp-ux assembler bug, and make strcpy of constants fast. */
        !           231: #define CONSTANT_ALIGNMENT(CODE, TYPEALIGN) \
        !           232:   ((TYPEALIGN) < 32 ? 32 : (TYPEALIGN))
        !           233: 
        !           234: /* Make arrays of chars word-aligned for the same reasons.  */
        !           235: #define DATA_ALIGNMENT(TYPE, ALIGN)            \
        !           236:   (TREE_CODE (TYPE) == ARRAY_TYPE              \
        !           237:    && TYPE_MODE (TREE_TYPE (TYPE)) == QImode   \
        !           238:    && (ALIGN) < BITS_PER_WORD ? BITS_PER_WORD : (ALIGN))
        !           239: 
        !           240: 
        !           241: /* Set this nonzero if move instructions will actually fail to work
        !           242:    when given unaligned data.  */
        !           243: #define STRICT_ALIGNMENT 1
        !           244: 
        !           245: /* Generate calls to memcpy, memcmp and memset.  */
        !           246: #define TARGET_MEM_FUNCTIONS
        !           247: 
        !           248: /* Standard register usage.  */
        !           249: 
        !           250: /* Number of actual hardware registers.
        !           251:    The hardware registers are assigned numbers for the compiler
        !           252:    from 0 to just below FIRST_PSEUDO_REGISTER.
        !           253:    All registers that the compiler knows about must be given numbers,
        !           254:    even those that are not normally considered general registers.
        !           255: 
        !           256:    HP-PA 1.0 has 32 fullword registers and 16 floating point
        !           257:    registers. The floating point registers hold either word or double
        !           258:    word values.
        !           259:    
        !           260:    16 additional registers are reserved.
        !           261:    
        !           262:    HP-PA 1.1 has 32 fullword registers and 32 floating point
        !           263:    registers. However, the floating point registers behave
        !           264:    differently: the left and right halves of registers are addressable
        !           265:    as 32 bit registers. So, we will set things up like the 68k which
        !           266:    has different fp units: define separate register sets for the 1.0
        !           267:    and 1.1 fp units. */
        !           268: 
        !           269: #define FIRST_PSEUDO_REGISTER 101  /* 32 + 12 1.0 regs + 56 1.1 regs + */
        !           270:                                   /* 1 shift reg */
        !           271: 
        !           272: /* 1 for registers that have pervasive standard uses
        !           273:    and are not available for the register allocator.
        !           274: 
        !           275:    On the HP-PA, these are:
        !           276:    Reg 0       = 0 (hardware). However, 0 is used for condition code,
        !           277:                   so is not fixed.
        !           278:    Reg 1       = ADDIL target/Temporary (hardware).
        !           279:    Reg 2       = Return Pointer
        !           280:    Reg 3       = Preserved Register (Gnu).  Frame Pointer (> 8k frames HP.)
        !           281:    Reg 4       = Frame Pointer (Gnu)
        !           282:    Reg 5-18    = Preserved Registers
        !           283:    Reg 19      = Linkage Table Register in HPUX 8.0 shared library scheme.
        !           284:    Reg 20-22   = Temporary Registers
        !           285:    Reg 23-26   = Temporary/Parameter Registers
        !           286:    Reg 27      = Global Data Pointer (hp)
        !           287:    Reg 28      = Temporary/???/Return Value register
        !           288:    Reg 29      = Temporary/Static Chain/Return Value register
        !           289:    Reg 30      = stack pointer
        !           290:    Reg 31      = Temporary/Millicode Return Pointer (hp)
        !           291: 
        !           292:    Freg 0-3    = Status Registers       -- Not known to the compiler.
        !           293:    Freg 4-7    = Arguments/Return Value
        !           294:    Freg 8-11   = Temporary Registers
        !           295:    Freg 12-15  = Preserved Registers
        !           296: 
        !           297:    Freg 16-31  = Reserved
        !           298: 
        !           299:    On the Snake, fp regs are
        !           300: 
        !           301:    Freg 0-3    = Status Registers      -- Not known to the compiler.
        !           302:    Freg 4L-7R  = Arguments/Return Value
        !           303:    Freg 8L-11R = Temporary Registers
        !           304:    Freg 12L-21R        = Preserved Registers
        !           305:    Freg 22L-31R = Temporary Registers
        !           306:    
        !           307: 
        !           308: */
        !           309: 
        !           310: #define FIXED_REGISTERS  \
        !           311:  {0, 0, 0, 0, 0, 0, 0, 0, \
        !           312:   0, 0, 0, 0, 0, 0, 0, 0, \
        !           313:   0, 0, 0, 0, 0, 0, 0, 0, \
        !           314:   0, 0, 0, 1, 0, 0, 1, 0, \
        !           315:   /* 1.0 fp registers */ \
        !           316:   0, 0, 0, 0, \
        !           317:   0, 0, 0, 0, 0, 0, 0, 0, \
        !           318:   /* 1.1 fp registers */ \
        !           319:   0, 0, 0, 0, 0, 0, 0, 0, \
        !           320:   0, 0, 0, 0, 0, 0, 0, 0, \
        !           321:   0, 0, 0, 0, 0, 0, 0, 0, \
        !           322:   0, 0, 0, 0, 0, 0, 0, 0, \
        !           323:   0, 0, 0, 0, 0, 0, 0, 0, \
        !           324:   0, 0, 0, 0, 0, 0, 0, 0, \
        !           325:   0, 0, 0, 0, 0, 0, 0, 0, \
        !           326:   0}
        !           327: 
        !           328: /* 1 for registers not available across function calls.
        !           329:    These must include the FIXED_REGISTERS and also any
        !           330:    registers that can be used without being saved.
        !           331:    The latter must include the registers where values are returned
        !           332:    and the register where structure-value addresses are passed.
        !           333:    Aside from that, you can include as many other registers as you like.  */
        !           334: #define CALL_USED_REGISTERS  \
        !           335:  {1, 1, 1, 0, 0, 0, 0, 0, \
        !           336:   0, 0, 0, 0, 0, 0, 0, 0, \
        !           337:   0, 0, 0, 1, 1, 1, 1, 1, \
        !           338:   1, 1, 1, 1, 1, 1, 1, 1, \
        !           339:   /* 1.0 fp registers */ \
        !           340:   1, 1, 1, 1, \
        !           341:   1, 1, 1, 1, 0, 0, 0, 0, \
        !           342:   /* 1.1 fp registers */ \
        !           343:   1, 1, 1, 1, 1, 1, 1, 1, \
        !           344:   1, 1, 1, 1, 1, 1, 1, 1, \
        !           345:   0, 0, 0, 0, 0, 0, 0, 0, \
        !           346:   0, 0, 0, 0, 0, 0, 0, 0, \
        !           347:   0, 0, 0, 0, 1, 1, 1, 1, \
        !           348:   1, 1, 1, 1, 1, 1, 1, 1, \
        !           349:   1, 1, 1, 1, 1, 1, 1, 1, \
        !           350:   1}    
        !           351: 
        !           352: /* Make sure everything's fine if we *don't* have a given processor.
        !           353:    This assumes that putting a register in fixed_regs will keep the
        !           354:    compiler's mitts completely off it.  We don't bother to zero it out
        !           355:    of register classes.   */
        !           356: 
        !           357: #define CONDITIONAL_REGISTER_USAGE \
        !           358: {                                              \
        !           359:   int i;                                       \
        !           360:   HARD_REG_SET x;                              \
        !           361:   if (!TARGET_SNAKE)                           \
        !           362:     {                                          \
        !           363:       COPY_HARD_REG_SET (x, reg_class_contents[(int)SNAKE_FP_REGS]);\
        !           364:       for (i = 0; i < FIRST_PSEUDO_REGISTER; i++ ) \
        !           365:        if (TEST_HARD_REG_BIT (x, i))           \
        !           366:        fixed_regs[i] = call_used_regs[i] = 1;  \
        !           367:     }                                          \
        !           368:   else if (TARGET_DISABLE_FPREGS)              \
        !           369:     {                                          \
        !           370:       COPY_HARD_REG_SET (x, reg_class_contents[(int)FP_REGS]);\
        !           371:       for (i = 0; i < FIRST_PSEUDO_REGISTER; i++ ) \
        !           372:        if (TEST_HARD_REG_BIT (x, i))           \
        !           373:        fixed_regs[i] = call_used_regs[i] = 1;  \
        !           374:       COPY_HARD_REG_SET (x, reg_class_contents[(int)SNAKE_FP_REGS]);\
        !           375:       for (i = 0; i < FIRST_PSEUDO_REGISTER; i++ ) \
        !           376:        if (TEST_HARD_REG_BIT (x, i))           \
        !           377:        fixed_regs[i] = call_used_regs[i] = 1;  \
        !           378:     }                                          \
        !           379:   else                                         \
        !           380:     {                                          \
        !           381:       COPY_HARD_REG_SET (x, reg_class_contents[(int)FP_REGS]); \
        !           382:       for (i = 0; i < FIRST_PSEUDO_REGISTER; i++ ) \
        !           383:        if (TEST_HARD_REG_BIT (x, i))           \
        !           384:        fixed_regs[i] = call_used_regs[i] = 1;  \
        !           385:     }                                          \
        !           386:   if (flag_pic)                                        \
        !           387:     fixed_regs[PIC_OFFSET_TABLE_REGNUM] = 1;   \
        !           388: }
        !           389: 
        !           390: /* Allocated the call used registers first.  This should minimize
        !           391:    the number of registers that need to be saved (as call used
        !           392:    registers will generally not be allocated across a call).
        !           393: 
        !           394:    Experimentation has shown slightly better results by allocating
        !           395:    FP registers first.  */
        !           396: 
        !           397: #define REG_ALLOC_ORDER \
        !           398:   /* 1.0 caller-saved fp regs.  */     \
        !           399:  {36, 37, 38, 39, 32, 33, 34, 35,      \
        !           400:   /* 1.1 caller-saved fp regs.  */     \
        !           401:   52, 53, 54, 55, 56, 57, 58, 59,      \
        !           402:   80, 81, 82, 83, 84, 85, 86, 87,      \
        !           403:   88, 89, 90, 91, 92, 93, 94, 95,      \
        !           404:   96, 97, 98, 99,                      \
        !           405:   44, 45, 46, 47, 48, 49, 50, 51,      \
        !           406:   /* caller-saved general regs.  */    \
        !           407:   19, 20, 21, 22, 23, 24, 25, 26,      \
        !           408:   27, 28, 29, 31,  2,                  \
        !           409:   /* 1.0 callee-saved fp regs.  */     \
        !           410:   40, 41, 42, 43,                      \
        !           411:   /* 1.1 callee-saved fp regs.  */     \
        !           412:   60, 61, 62, 63, 64, 65, 66, 67,      \
        !           413:   68, 69, 70, 71, 72, 73, 74, 75,      \
        !           414:   76, 77, 78, 79,                      \
        !           415:   /* callee-saved general regs.  */    \
        !           416:    3,  4,  5,  6,  7,  8,  9, 10,      \
        !           417:   11, 12, 13, 14, 15, 16, 17, 18,      \
        !           418:   /* special registers.  */            \
        !           419:    1, 30,  0, 100}
        !           420: 
        !           421: 
        !           422: /* Return number of consecutive hard regs needed starting at reg REGNO
        !           423:    to hold something of mode MODE.
        !           424:    This is ordinarily the length in words of a value of mode MODE
        !           425:    but can be less for certain modes in special long registers.
        !           426: 
        !           427:    On the HP-PA, ordinary registers hold 32 bits worth;
        !           428:    The floating point registers are 64 bits wide. Snake fp regs are 32
        !           429:    bits wide */
        !           430: #define HARD_REGNO_NREGS(REGNO, MODE)   \
        !           431:   (((REGNO) < 32 || (REGNO) >= 44)     \
        !           432:    ? ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD) : 1)
        !           433: 
        !           434: /* Value is 1 if hard register REGNO can hold a value of machine-mode MODE.
        !           435:    On the HP-PA, the cpu registers can hold any mode.  We
        !           436:    force this to be an even register is it cannot hold the full mode.  */
        !           437: #define HARD_REGNO_MODE_OK(REGNO, MODE) \
        !           438:   ((REGNO) == 0 ? (MODE) == CCmode || (MODE) == CCFPmode               \
        !           439:    : (REGNO) < 32 ? ((GET_MODE_SIZE (MODE) <= 4) ? 1 : ((REGNO) & 1) == 0)\
        !           440:    : (REGNO) < 44 ? (GET_MODE_SIZE (MODE) <= 4                         \
        !           441:                     || (GET_MODE_SIZE (MODE) > 4                       \
        !           442:                         && GET_MODE_CLASS (MODE) == MODE_FLOAT))       \
        !           443:    : (GET_MODE_SIZE (MODE) > 4 ? ((REGNO) & 1) == 0                    \
        !           444:       : 1))
        !           445: 
        !           446: /* Value is 1 if it is a good idea to tie two pseudo registers
        !           447:    when one has mode MODE1 and one has mode MODE2.
        !           448:    If HARD_REGNO_MODE_OK could produce different values for MODE1 and MODE2,
        !           449:    for any hard reg, then this must be 0 for correct output.  */
        !           450: #define MODES_TIEABLE_P(MODE1, MODE2) \
        !           451:   (GET_MODE_CLASS (MODE1) == GET_MODE_CLASS (MODE2))
        !           452: 
        !           453: /* Specify the registers used for certain standard purposes.
        !           454:    The values of these macros are register numbers.  */
        !           455: 
        !           456: /* The HP-PA pc isn't overloaded on a register that the compiler knows about.  */
        !           457: /* #define PC_REGNUM  */
        !           458: 
        !           459: /* Register to use for pushing function arguments.  */
        !           460: #define STACK_POINTER_REGNUM 30
        !           461: 
        !           462: /* Base register for access to local variables of the function.  */
        !           463: #define FRAME_POINTER_REGNUM 4
        !           464: 
        !           465: /* Value should be nonzero if functions must have frame pointers. */
        !           466: #define FRAME_POINTER_REQUIRED (current_function_calls_alloca)
        !           467:   
        !           468: 
        !           469: /* C statement to store the difference between the frame pointer
        !           470:    and the stack pointer values immediately after the function prologue.
        !           471: 
        !           472:    Note, we always pretend that this is a leaf function because if
        !           473:    it's not, there's no point in trying to eliminate the
        !           474:    frame pointer.  If it is a leaf function, we guessed right!  */
        !           475: #define INITIAL_FRAME_POINTER_OFFSET(VAR) \
        !           476:   do {(VAR) = - compute_frame_size (get_frame_size (), 0);} while (0)
        !           477: 
        !           478: /* Base register for access to arguments of the function.  */
        !           479: #define ARG_POINTER_REGNUM 4
        !           480: 
        !           481: /* Register in which static-chain is passed to a function.  */
        !           482: /* ??? */
        !           483: #define STATIC_CHAIN_REGNUM 29
        !           484: 
        !           485: /* Register which holds offset table for position-independent
        !           486:    data references.  */
        !           487: 
        !           488: #define PIC_OFFSET_TABLE_REGNUM 19
        !           489: 
        !           490: #define INITIALIZE_PIC initialize_pic ()
        !           491: #define FINALIZE_PIC finalize_pic ()
        !           492: 
        !           493: /* SOM ABI says that objects larger than 64 bits are returned in memory.  */
        !           494: #define RETURN_IN_MEMORY(TYPE) \
        !           495:   (TYPE_MODE (TYPE) == BLKmode || int_size_in_bytes (TYPE) > 8)
        !           496: 
        !           497: /* Register in which address to store a structure value
        !           498:    is passed to a function.  */
        !           499: #define STRUCT_VALUE_REGNUM 28
        !           500: 
        !           501: /* Define the classes of registers for register constraints in the
        !           502:    machine description.  Also define ranges of constants.
        !           503: 
        !           504:    One of the classes must always be named ALL_REGS and include all hard regs.
        !           505:    If there is more than one class, another class must be named NO_REGS
        !           506:    and contain no registers.
        !           507: 
        !           508:    The name GENERAL_REGS must be the name of a class (or an alias for
        !           509:    another name such as ALL_REGS).  This is the class of registers
        !           510:    that is allowed by "g" or "r" in a register constraint.
        !           511:    Also, registers outside this class are allocated only when
        !           512:    instructions express preferences for them.
        !           513: 
        !           514:    The classes must be numbered in nondecreasing order; that is,
        !           515:    a larger-numbered class must never be contained completely
        !           516:    in a smaller-numbered class.
        !           517: 
        !           518:    For any two classes, it is very desirable that there be another
        !           519:    class that represents their union.  */
        !           520: 
        !           521:   /* The HP-PA has four kinds of registers: general regs, 1.0 fp regs,
        !           522:      1.1 fp regs, and the high 1.1 fp regs, to which the operands of
        !           523:      fmpyadd and fmpysub are restricted.
        !           524: 
        !           525:      FP_OR_SNAKE_FP_REGS is for reload_{in,out}di only and isn't used
        !           526:      anywhere else.  */
        !           527: 
        !           528: enum reg_class { NO_REGS, R1_REGS, GENERAL_REGS, FP_REGS, GENERAL_OR_FP_REGS,
        !           529:   HI_SNAKE_FP_REGS, SNAKE_FP_REGS, GENERAL_OR_SNAKE_FP_REGS,
        !           530:   FP_OR_SNAKE_FP_REGS, NON_SHIFT_REGS, SHIFT_REGS, ALL_REGS, LIM_REG_CLASSES}; 
        !           531: 
        !           532: #define N_REG_CLASSES (int) LIM_REG_CLASSES
        !           533: 
        !           534: /* Give names of register classes as strings for dump file.   */
        !           535: 
        !           536: #define REG_CLASS_NAMES \
        !           537:   { "NO_REGS", "R1_REGS", "GENERAL_REGS", "FP_REGS", "GENERAL_OR_FP_REGS",\
        !           538:     "HI_SNAKE_FP_REGS", "SNAKE_FP_REGS", "GENERAL_OR_SNAKE_FP_REGS",\
        !           539:     "FP_OR_SNAKE_FP_REGS", "NON_SHIFT_REGS", "SHIFT_REGS", "ALL_REGS"}
        !           540: 
        !           541: /* Define which registers fit in which classes.
        !           542:    This is an initializer for a vector of HARD_REG_SET
        !           543:    of length N_REG_CLASSES. Register 0, the "condition code" register,
        !           544:    is in no class. */
        !           545: 
        !           546: #define REG_CLASS_CONTENTS     \
        !           547: { {0, 0, 0, 0},                        /* NO_REGS */           \
        !           548:   {0x2, 0, 0, 0},              /* R1_REGS */           \
        !           549:   {-2, 0, 0, 0},               /* GENERAL_REGS */      \
        !           550:   {0, 0xfff, 0, 0},            /* FP_REGS */           \
        !           551:   {-2, 0xfff, 0, 0},           /* GENERAL_OR_FP_REGS */\
        !           552:   {0, 0, 0xfffffff0, 0xf},     /* HI_SNAKE_FP_REGS */  \
        !           553:   {0, 0xfffff000, ~0, 0xf},    /* SNAKE_FP_REGS */     \
        !           554:   {-2, 0xfffff000, ~0, 0xf},   /* GENERAL_OR_SNAKE_FP_REGS */\
        !           555:   {0, ~0, ~0, 0xf},            /* FP_OR_SNAKE_FP_REGS */\
        !           556:   {-2, ~0, ~0, ~0x10},         /* NON_SHIFT_REGS */    \
        !           557:   {0, 0, 0, 0x10},             /* SHIFT_REGS */        \
        !           558:   {-2, ~0, ~0, 0x1f}}          /* ALL_REGS */
        !           559: 
        !           560: /* The same information, inverted:
        !           561:    Return the class number of the smallest class containing
        !           562:    reg number REGNO.  This could be a conditional expression
        !           563:    or could index an array.  */
        !           564: 
        !           565: #define REGNO_REG_CLASS(REGNO)         \
        !           566:   ((REGNO) == 0 ? NO_REGS              \
        !           567:    : (REGNO) == 1 ? R1_REGS            \
        !           568:    : (REGNO) < 32 ? GENERAL_REGS       \
        !           569:    : (REGNO) < 44 ? FP_REGS            \
        !           570:    : (REGNO) < 68 ? SNAKE_FP_REGS      \
        !           571:    : (REGNO) < 100 ? HI_SNAKE_FP_REGS  \
        !           572:    : SHIFT_REGS)
        !           573: 
        !           574: /* The class value for index registers, and the one for base regs.  */
        !           575: #define INDEX_REG_CLASS GENERAL_REGS
        !           576: #define BASE_REG_CLASS GENERAL_REGS
        !           577: 
        !           578: #define FP_REG_CLASS_P(CLASS) \
        !           579:   (CLASS == FP_REGS || CLASS == SNAKE_FP_REGS || CLASS == HI_SNAKE_FP_REGS)
        !           580: 
        !           581: /* Get reg_class from a letter such as appears in the machine description.
        !           582:    Note 'Z' is not the same as 'r' since SHIFT_REGS is not part of 
        !           583:    GENERAL_REGS.  */
        !           584: 
        !           585: #define REG_CLASS_FROM_LETTER(C) \
        !           586:   ((C) == 'f' ? (!TARGET_SNAKE ? FP_REGS : NO_REGS) :          \
        !           587:    ((C) == 'x' ? (TARGET_SNAKE ? SNAKE_FP_REGS : NO_REGS) :    \
        !           588:     ((C) == 'y' ? (TARGET_SNAKE ? HI_SNAKE_FP_REGS : NO_REGS) :        \
        !           589:      ((C) == 'q' ? SHIFT_REGS :                                        \
        !           590:       ((C) == 'a' ? R1_REGS :                                  \
        !           591:        ((C) == 'z' ? FP_OR_SNAKE_FP_REGS :                     \
        !           592:         ((C) == 'Z' ? ALL_REGS : NO_REGS)))))))
        !           593: 
        !           594: /* The letters I, J, K, L and M in a register constraint string
        !           595:    can be used to stand for particular ranges of immediate operands.
        !           596:    This macro defines what the ranges are.
        !           597:    C is the letter, and VALUE is a constant value.
        !           598:    Return 1 if VALUE is in the range specified by C.
        !           599: 
        !           600:    `I' is used for the 11 bit constants.
        !           601:    `J' is used for the 14 bit constants.
        !           602:    `K' is used for values that can be moved with a zdepi insn.
        !           603:    `L' is used for the 5 bit constants.
        !           604:    `M' is used for 0.
        !           605:    `N' is used for values with the least significant 11 bits equal to zero.
        !           606:    `O' is used for numbers n such that n+1 is a power of 2.
        !           607:    */
        !           608: 
        !           609: #ifdef NeXT_ASM
        !           610: #define RIGHT_BITS_MASK 0x3fff
        !           611: #else
        !           612: #define RIGHT_BITS_MASK 0x7ff
        !           613: #endif
        !           614: 
        !           615: #define CONST_OK_FOR_LETTER_P(VALUE, C)  \
        !           616:   ((C) == 'I' ? VAL_11_BITS_P (VALUE)                          \
        !           617:    : (C) == 'J' ? VAL_14_BITS_P (VALUE)                                \
        !           618:    : (C) == 'K' ? zdepi_cint_p (VALUE)                         \
        !           619:    : (C) == 'L' ? VAL_5_BITS_P (VALUE)                         \
        !           620:    : (C) == 'M' ? (VALUE) == 0                                 \
        !           621:    : (C) == 'N' ? ((VALUE) & RIGHT_BITS_MASK) == 0             \
        !           622:    : (C) == 'O' ? (((VALUE) & ((VALUE) + 1)) == 0)             \
        !           623:    : (C) == 'P' ? and_mask_p (VALUE)                           \
        !           624:    : 0)
        !           625: 
        !           626: /* Similar, but for floating or large integer constants, and defining letters
        !           627:    G and H.   Here VALUE is the CONST_DOUBLE rtx itself.
        !           628: 
        !           629:    For PA, `G' is the floating-point constant zero.  `H' is undefined.  */
        !           630: 
        !           631: #define CONST_DOUBLE_OK_FOR_LETTER_P(VALUE, C)                         \
        !           632:   ((C) == 'G' ? (GET_MODE_CLASS (GET_MODE (VALUE)) == MODE_FLOAT       \
        !           633:                 && (VALUE) == CONST0_RTX (GET_MODE (VALUE)))           \
        !           634:    : 0)
        !           635: 
        !           636: /* Given an rtx X being reloaded into a reg required to be
        !           637:    in class CLASS, return the class of reg to actually use.
        !           638:    In general this is just CLASS; but on some machines
        !           639:    in some cases it is preferable to use a more restrictive class.  */
        !           640: #define PREFERRED_RELOAD_CLASS(X,CLASS) (CLASS)
        !           641: 
        !           642: /* Return the register class of a scratch register needed to copy IN into
        !           643:    or out of a register in CLASS in MODE.  If it can be done directly,
        !           644:    NO_REGS is returned.  */
        !           645: 
        !           646: #define SECONDARY_RELOAD_CLASS(CLASS,MODE,IN) \
        !           647:   secondary_reload_class (CLASS, MODE, IN)
        !           648: 
        !           649: /* On the PA it is not possible to directly move data between 
        !           650:    GENERAL_REGS and FP_REGS.  */
        !           651: #define SECONDARY_MEMORY_NEEDED(CLASS1, CLASS2, MODE)  \
        !           652:   ((FP_REG_CLASS_P (CLASS1) && ! FP_REG_CLASS_P (CLASS2))      \
        !           653:    || (! FP_REG_CLASS_P (CLASS1) && FP_REG_CLASS_P (CLASS2)))
        !           654: 
        !           655: /* Return the stack location to use for secondary memory needed reloads.  */
        !           656: #define SECONDARY_MEMORY_NEEDED_RTX(MODE) \
        !           657:   gen_rtx (MEM, MODE, gen_rtx (PLUS, Pmode, stack_pointer_rtx, GEN_INT (-16)))
        !           658: 
        !           659: /* Return the maximum number of consecutive registers
        !           660:    needed to represent mode MODE in a register of class CLASS.  */
        !           661: #define CLASS_MAX_NREGS(CLASS, MODE)   \
        !           662:   ((CLASS) == FP_REGS ? 1 : ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD))
        !           663: 
        !           664: /* Stack layout; function entry, exit and calling.  */
        !           665: 
        !           666: /* Define this if pushing a word on the stack
        !           667:    makes the stack pointer a smaller address.  */
        !           668: /* #define STACK_GROWS_DOWNWARD */
        !           669: 
        !           670: /* Believe it or not.  */
        !           671: #define ARGS_GROW_DOWNWARD
        !           672: 
        !           673: /* Define this if the nominal address of the stack frame
        !           674:    is at the high-address end of the local variables;
        !           675:    that is, each additional local variable allocated
        !           676:    goes at a more negative offset in the frame.  */
        !           677: /* #define FRAME_GROWS_DOWNWARD */
        !           678: 
        !           679: /* Offset within stack frame to start allocating local variables at.
        !           680:    If FRAME_GROWS_DOWNWARD, this is the offset to the END of the
        !           681:    first local allocated.  Otherwise, it is the offset to the BEGINNING
        !           682:    of the first local allocated.  */
        !           683: #define STARTING_FRAME_OFFSET 8
        !           684: 
        !           685: /* If we generate an insn to push BYTES bytes,
        !           686:    this says how many the stack pointer really advances by.
        !           687:    On the HP-PA, don't define this because there are no push insns.  */
        !           688: /*  #define PUSH_ROUNDING(BYTES) */
        !           689: 
        !           690: /* Offset of first parameter from the argument pointer register value.
        !           691:    This value will be negated because the arguments grow down.
        !           692:    Also note that on STACK_GROWS_UPWARD machines (such as this one)
        !           693:    this is the distance from the frame pointer to the end of the first
        !           694:    argument, not it's beginning.  To get the real offset of the first
        !           695:    argument, the size of the argument must be added.
        !           696: 
        !           697:    ??? Have to check on this.*/
        !           698: 
        !           699: #define FIRST_PARM_OFFSET(FNDECL) -32 
        !           700: 
        !           701: /* Absolute value of offset from top-of-stack address to location to store the
        !           702:    function parameter if it can't go in a register.
        !           703:    Addresses for following parameters are computed relative to this one.  */
        !           704: #define FIRST_PARM_CALLER_OFFSET(FNDECL) -32 
        !           705: 
        !           706: 
        !           707: /* When a parameter is passed in a register, stack space is still
        !           708:    allocated for it.  */
        !           709: #define REG_PARM_STACK_SPACE(DECL) 16
        !           710: 
        !           711: /* Define this if the above stack space is to be considered part of the
        !           712:    space allocated by the caller.  */
        !           713: #define OUTGOING_REG_PARM_STACK_SPACE
        !           714: 
        !           715: /* Keep the stack pointer constant throughout the function.
        !           716:    This is both an optimization and a necessity: longjmp
        !           717:    doesn't behave itself when the stack pointer moves within
        !           718:    the function!  */
        !           719: #define ACCUMULATE_OUTGOING_ARGS
        !           720:   
        !           721: /* The weird HPPA calling conventions require a minimum of 48 bytes on 
        !           722:    the stack: 16 bytes for register saves, and 32 bytes for magic.
        !           723:    This is the difference between the logical top of stack and the
        !           724:    actual sp. */ 
        !           725: #define STACK_POINTER_OFFSET -32
        !           726: 
        !           727: #define STACK_DYNAMIC_OFFSET(FNDECL)   \
        !           728:   ((STACK_POINTER_OFFSET) - current_function_outgoing_args_size)
        !           729: 
        !           730: /* Value is 1 if returning from a function call automatically
        !           731:    pops the arguments described by the number-of-args field in the call.
        !           732:    FUNTYPE is the data type of the function (as a tree),
        !           733:    or for a library call it is an identifier node for the subroutine name.  */
        !           734: 
        !           735: #define RETURN_POPS_ARGS(FUNTYPE,SIZE) 0
        !           736: 
        !           737: /* Define how to find the value returned by a function.
        !           738:    VALTYPE is the data type of the value (as a tree).
        !           739:    If the precise function being called is known, FUNC is its FUNCTION_DECL;
        !           740:    otherwise, FUNC is 0.  */
        !           741: 
        !           742: /* On the HP-PA the value is found in register(s) 28(-29), unless
        !           743:    the mode is SF or DF. Then the value is returned in fr4 (32, ) */
        !           744: 
        !           745: 
        !           746: #define FUNCTION_VALUE(VALTYPE, FUNC)  \
        !           747:   gen_rtx (REG, TYPE_MODE (VALTYPE), ((TYPE_MODE (VALTYPE) == SFmode ||\
        !           748:                                       TYPE_MODE (VALTYPE) == DFmode) ? \
        !           749:                                      (TARGET_SNAKE ? 44 : 32) : 28))
        !           750: 
        !           751: /* Define how to find the value returned by a library function
        !           752:    assuming the value has mode MODE.  */
        !           753: 
        !           754: #define LIBCALL_VALUE(MODE) \
        !           755:   gen_rtx (REG, MODE, (MODE == SFmode || MODE == DFmode ?\
        !           756:                       (TARGET_SNAKE ? 44 : 32) : 28))
        !           757: 
        !           758: /* 1 if N is a possible register number for a function value
        !           759:    as seen by the caller.  */
        !           760: 
        !           761: #define FUNCTION_VALUE_REGNO_P(N) ((N) == 28 || (N) == (TARGET_SNAKE ? 44 : 32))
        !           762: 
        !           763: /* 1 if N is a possible register number for function argument passing.  */
        !           764: 
        !           765: #define FUNCTION_ARG_REGNO_P(N)                                \
        !           766:   (((N) >= 23 && (N) <= 26)                            \
        !           767:    || ((N) >= 32 && (N) <= 35 && ! TARGET_SNAKE)       \
        !           768:    || ((N) >= 44 && (N) <= 51 && TARGET_SNAKE))
        !           769: 
        !           770: /* Define a data type for recording info about an argument list
        !           771:    during the scan of that argument list.  This data type should
        !           772:    hold all necessary information about the function itself
        !           773:    and about the args processed so far, enough to enable macros
        !           774:    such as FUNCTION_ARG to determine where the next arg should go.
        !           775: 
        !           776:    On the HP-PA, this is a single integer, which is a number of words
        !           777:    of arguments scanned so far (including the invisible argument,
        !           778:    if any, which holds the structure-value-address).
        !           779:    Thus 4 or more means all following args should go on the stack.  */
        !           780: 
        !           781: #define CUMULATIVE_ARGS int
        !           782: 
        !           783: /* Initialize a variable CUM of type CUMULATIVE_ARGS
        !           784:    for a call to a function whose data type is FNTYPE.
        !           785:    For a library call, FNTYPE is 0.
        !           786: */
        !           787: 
        !           788: #define INIT_CUMULATIVE_ARGS(CUM,FNTYPE,LIBNAME) ((CUM) = 0)
        !           789: 
        !           790: /* Figure out the size in words of the function argument. */
        !           791: 
        !           792: #define FUNCTION_ARG_SIZE(MODE, TYPE)  \
        !           793:   ((((MODE) != BLKmode ? GET_MODE_SIZE (MODE) : int_size_in_bytes (TYPE))+3)/4)
        !           794: 
        !           795: /* Update the data in CUM to advance over an argument
        !           796:    of mode MODE and data type TYPE.
        !           797:    (TYPE is null for libcalls where that information may not be available.)  */
        !           798: 
        !           799: #define FUNCTION_ARG_ADVANCE(CUM, MODE, TYPE, NAMED)                   \
        !           800:     (((((CUM) & 01) && (TYPE) != 0 && FUNCTION_ARG_SIZE(MODE, TYPE) > 1)\
        !           801:       && (CUM)++), (CUM) += FUNCTION_ARG_SIZE(MODE, TYPE))
        !           802: 
        !           803: /* Determine where to put an argument to a function.
        !           804:    Value is zero to push the argument on the stack,
        !           805:    or a hard register in which to store the argument.
        !           806: 
        !           807:    MODE is the argument's machine mode.
        !           808:    TYPE is the data type of the argument (as a tree).
        !           809:     This is null for libcalls where that information may
        !           810:     not be available.
        !           811:    CUM is a variable of type CUMULATIVE_ARGS which gives info about
        !           812:     the preceding args and about the function being called.
        !           813:    NAMED is nonzero if this argument is a named parameter
        !           814:     (otherwise it is an extra parameter matching an ellipsis).  */
        !           815: 
        !           816: /* On the HP-PA the first four words of args are normally in registers
        !           817:    and the rest are pushed.  But any arg that won't entirely fit in regs
        !           818:    is pushed.
        !           819: 
        !           820:    Arguments passed in registers are either 1 or 2 words long.
        !           821: 
        !           822:    The caller must make a distinction between calls to explicitly named
        !           823:    functions and calls through pointers to functions -- the conventions
        !           824:    are different!  Calls through pointers to functions only use general
        !           825:    registers for the first four argument words.  */
        !           826: 
        !           827: #define FUNCTION_ARG_PADDING(MODE, TYPE) function_arg_padding ((MODE), (TYPE))
        !           828: 
        !           829: #define FUNCTION_ARG(CUM, MODE, TYPE, NAMED)                           \
        !           830:   (4 >= ((CUM) + FUNCTION_ARG_SIZE ((MODE), (TYPE)))                   \
        !           831:    ? gen_rtx (REG, (MODE),                                             \
        !           832:              (FUNCTION_ARG_SIZE ((MODE), (TYPE)) > 1                   \
        !           833:               ? ((! current_call_is_indirect                           \
        !           834:                   && (MODE) == DFmode)                                 \
        !           835:                  ? ((CUM) ? (TARGET_SNAKE ? 50 : 35)                   \
        !           836:                     : (TARGET_SNAKE ? 46 : 33))                        \
        !           837:                  : ((CUM) ? 23 : 25))                                  \
        !           838:               : ((! current_call_is_indirect                           \
        !           839:                   && (MODE) == SFmode)                                 \
        !           840:                  ? (TARGET_SNAKE ? 44 + 2 * (CUM) : 32  + (CUM))       \
        !           841:                  : (27 - (CUM) - FUNCTION_ARG_SIZE ((MODE), (TYPE))))))\
        !           842:    : 0)
        !           843: 
        !           844: /* Define where a function finds its arguments.
        !           845:    This would be different from FUNCTION_ARG if we had register windows.  */
        !           846: 
        !           847: #define FUNCTION_INCOMING_ARG(CUM, MODE, TYPE, NAMED)  \
        !           848:   FUNCTION_ARG (CUM, MODE, TYPE, NAMED)
        !           849: 
        !           850: /* For an arg passed partly in registers and partly in memory,
        !           851:    this is the number of registers used.
        !           852:    For args passed entirely in registers or entirely in memory, zero.  */
        !           853: 
        !           854: #define FUNCTION_ARG_PARTIAL_NREGS(CUM, MODE, TYPE, NAMED) 0
        !           855: 
        !           856: /* If defined, a C expression that gives the alignment boundary, in
        !           857:    bits, of an argument with the specified mode and type.  If it is
        !           858:    not defined,  `PARM_BOUNDARY' is used for all arguments.  */
        !           859: /*
        !           860: #define FUNCTION_ARG_BOUNDARY(MODE, TYPE)                              \
        !           861:   (((TYPE) != 0)                                                       \
        !           862:        ? (((int_size_in_bytes (TYPE)) + 3) / 4) * BITS_PER_WORD        \
        !           863:        : ((GET_MODE_ALIGNMENT(MODE) <= PARM_BOUNDARY)                  \
        !           864:                ? PARM_BOUNDARY                                         \
        !           865:                : GET_MODE_ALIGNMENT(MODE)))
        !           866: */
        !           867: #define FUNCTION_ARG_BOUNDARY(MODE, TYPE)                              \
        !           868:   (((TYPE) != 0)                                                       \
        !           869:        ? ((TYPE_ALIGN(TYPE) <= PARM_BOUNDARY)                          \
        !           870:                ? PARM_BOUNDARY                                          \
        !           871:                : TYPE_ALIGN(TYPE))                                      \
        !           872:        : ((GET_MODE_ALIGNMENT(MODE) <= PARM_BOUNDARY)                  \
        !           873:                ? PARM_BOUNDARY                                         \
        !           874:                : GET_MODE_ALIGNMENT(MODE)))
        !           875: 
        !           876: /* Arguments larger than eight bytes are passed by invisible reference */
        !           877: 
        !           878: #define FUNCTION_ARG_PASS_BY_REFERENCE(CUM, MODE, TYPE, NAMED)         \
        !           879:   ((TYPE) && int_size_in_bytes (TYPE) > 8)
        !           880: 
        !           881: extern struct rtx_def *hppa_compare_op0, *hppa_compare_op1;
        !           882: extern enum cmp_type hppa_branch_type;
        !           883: 
        !           884: /* How the quote in "R'label" is printed. */
        !           885: #ifdef NeXT_ASM
        !           886: #define PA_QUOTE '`'
        !           887: #else
        !           888: #define PA_QUOTE '\''
        !           889: #endif
        !           890: 
        !           891: /* Output the label for a function definition.  */
        !           892: #ifndef HP_FP_ARG_DESCRIPTOR_REVERSED
        !           893: #define ASM_DOUBLE_ARG_DESCRIPTORS(FILE, ARG0, ARG1)   \
        !           894:   do { fprintf (FILE, ",ARGW%d=FR", (ARG0));           \
        !           895:        fprintf (FILE, ",ARGW%d=FU", (ARG1));} while (0)
        !           896: #else
        !           897: #define ASM_DOUBLE_ARG_DESCRIPTORS(FILE, ARG0, ARG1)   \
        !           898:   do { fprintf (FILE, ",ARGW%d=FU", (ARG0));           \
        !           899:        fprintf (FILE, ",ARGW%d=FR", (ARG1));} while (0)
        !           900: #endif
        !           901: 
        !           902: #define ASM_DECLARE_FUNCTION_NAME(FILE, NAME, DECL) \
        !           903:     do { tree fntype = TREE_TYPE (TREE_TYPE (DECL));                   \
        !           904:         tree tree_type = TREE_TYPE (DECL);                             \
        !           905:         tree parm;                                                     \
        !           906:         int i;                                                         \
        !           907:         if (TREE_PUBLIC (DECL) || TARGET_GAS)                          \
        !           908:           { extern int current_function_varargs;                       \
        !           909:             if (TREE_PUBLIC (DECL))                                    \
        !           910:               {                                                        \
        !           911:                 fputs ("\t.EXPORT ", FILE);                            \
        !           912:                 assemble_name (FILE, NAME);                            \
        !           913:                 fputs (",ENTRY,PRIV_LEV=3", FILE);                     \
        !           914:               }                                                        \
        !           915:             else                                                       \
        !           916:               {                                                        \
        !           917:                 fputs ("\t.PARAM ", FILE);                             \
        !           918:                 assemble_name (FILE, NAME);                            \
        !           919:               }                                                        \
        !           920:             for (parm = DECL_ARGUMENTS (DECL), i = 0; parm && i < 4;   \
        !           921:                  parm = TREE_CHAIN (parm))                             \
        !           922:               {                                                        \
        !           923:                 if (TYPE_MODE (DECL_ARG_TYPE (parm)) == SFmode)        \
        !           924:                   fprintf (FILE, ",ARGW%d=FR", i++);                   \
        !           925:                 else if (TYPE_MODE (DECL_ARG_TYPE (parm)) == DFmode)   \
        !           926:                   {                                                    \
        !           927:                     if (i <= 2)                                        \
        !           928:                       {                                                \
        !           929:                         if (i == 1) i++;                               \
        !           930:                         ASM_DOUBLE_ARG_DESCRIPTORS (FILE, i++, i++);   \
        !           931:                       }                                                \
        !           932:                     else                                               \
        !           933:                       break;                                           \
        !           934:                   }                                                    \
        !           935:                 else                                                   \
        !           936:                   {                                                    \
        !           937:                     int arg_size =                                     \
        !           938:                       FUNCTION_ARG_SIZE (TYPE_MODE (DECL_ARG_TYPE (parm)),\
        !           939:                                          DECL_ARG_TYPE (parm));        \
        !           940:                     if (arg_size == 2 && i <= 2)                       \
        !           941:                       {                                                \
        !           942:                         if (i == 1) i++;                               \
        !           943:                         fprintf (FILE, ",ARGW%d=GR", i++);             \
        !           944:                         fprintf (FILE, ",ARGW%d=GR", i++);             \
        !           945:                       }                                                \
        !           946:                     else if (arg_size == 1)                            \
        !           947:                       fprintf (FILE, ",ARGW%d=GR", i++);               \
        !           948:                     else                                               \
        !           949:                       i += arg_size;                                   \
        !           950:                   }                                                    \
        !           951:               }                                                        \
        !           952:             /* anonymous args */                                       \
        !           953:             if ((TYPE_ARG_TYPES (tree_type) != 0                       \
        !           954:                  && (TREE_VALUE (tree_last (TYPE_ARG_TYPES (tree_type)))\
        !           955:                      != void_type_node))                               \
        !           956:                 || current_function_varargs)                           \
        !           957:               {                                                        \
        !           958:                 for (; i < 4; i++)                                     \
        !           959:                   fprintf (FILE, ",ARGW%d=GR", i);                     \
        !           960:               }                                                        \
        !           961:             if (TYPE_MODE (fntype) == DFmode)                          \
        !           962:               fprintf (FILE, ",RTNVAL=FR");                            \
        !           963:             else if (TYPE_MODE (fntype) == SFmode)                     \
        !           964:               fprintf (FILE, ",RTNVAL=FU");                            \
        !           965:             else if (fntype != void_type_node)                         \
        !           966:               fprintf (FILE, ",RTNVAL=GR");                            \
        !           967:             fputs ("\n", FILE);                                        \
        !           968:           }                                                            \
        !           969:         ASM_OUTPUT_LABEL (FILE, NAME);} while (0)
        !           970: 
        !           971: /* This macro generates the assembly code for function entry.
        !           972:    FILE is a stdio stream to output the code to.
        !           973:    SIZE is an int: how many units of temporary storage to allocate.
        !           974:    Refer to the array `regs_ever_live' to determine which registers
        !           975:    to save; `regs_ever_live[I]' is nonzero if register number I
        !           976:    is ever used in the function.  This macro is responsible for
        !           977:    knowing which registers should not be saved even if used.  */
        !           978: 
        !           979: /* On HP-PA, move-double insns between fpu and cpu need an 8-byte block
        !           980:    of memory.  If any fpu reg is used in the function, we allocate
        !           981:    such a block here, at the bottom of the frame, just in case it's needed.
        !           982: 
        !           983:    If this function is a leaf procedure, then we may choose not
        !           984:    to do a "save" insn.  The decision about whether or not
        !           985:    to do this is made in regclass.c.  */
        !           986: 
        !           987: #define FUNCTION_PROLOGUE(FILE, SIZE) \
        !           988:   output_function_prologue (FILE, SIZE)
        !           989: 
        !           990: /* Output assembler code to FILE to increment profiler label # LABELNO
        !           991:    for profiling a function entry.
        !           992: 
        !           993:    Because HPUX _mcount is so different, we actually emit the
        !           994:    profiling code in function_prologue. This just stores LABELNO for
        !           995:    that. */
        !           996: 
        !           997: #define PROFILE_BEFORE_PROLOGUE
        !           998: #define FUNCTION_PROFILER(FILE, LABELNO) \
        !           999: { extern int hp_profile_labelno; hp_profile_labelno = (LABELNO);}
        !          1000: 
        !          1001: /* EXIT_IGNORE_STACK should be nonzero if, when returning from a function,
        !          1002:    the stack pointer does not matter.  The value is tested only in
        !          1003:    functions that have frame pointers.
        !          1004:    No definition is equivalent to always zero.  */
        !          1005: 
        !          1006: extern int may_call_alloca;
        !          1007: extern int current_function_pretend_args_size;
        !          1008: 
        !          1009: #define EXIT_IGNORE_STACK      \
        !          1010:  (get_frame_size () != 0       \
        !          1011:   || current_function_calls_alloca || current_function_outgoing_args_size)
        !          1012: 
        !          1013: 
        !          1014: /* This macro generates the assembly code for function exit,
        !          1015:    on machines that need it.  If FUNCTION_EPILOGUE is not defined
        !          1016:    then individual return instructions are generated for each
        !          1017:    return statement.  Args are same as for FUNCTION_PROLOGUE.
        !          1018: 
        !          1019:    The function epilogue should not depend on the current stack pointer!
        !          1020:    It should use the frame pointer only.  This is mandatory because
        !          1021:    of alloca; we also take advantage of it to omit stack adjustments
        !          1022:    before returning.  */
        !          1023: 
        !          1024: /* This declaration is needed due to traditional/ANSI
        !          1025:    incompatibilities which cannot be #ifdefed away
        !          1026:    because they occur inside of macros.  Sigh.  */
        !          1027: extern union tree_node *current_function_decl;
        !          1028: 
        !          1029: #define FUNCTION_EPILOGUE(FILE, SIZE)                  \
        !          1030:   output_function_epilogue (FILE, SIZE)
        !          1031: 
        !          1032: /* Output assembler code for a block containing the constant parts
        !          1033:    of a trampoline, leaving space for the variable parts.\
        !          1034: 
        !          1035:    The trampoline sets the static chain pointer to STATIC_CHAIN_REGNUM
        !          1036:    and then branches to the specified routine.
        !          1037: 
        !          1038:    This code template is copied from text segment to stack location
        !          1039:    and then patched with INITIALIZE_TRAMPOLINE to contain
        !          1040:    valid values, and then entered as a subroutine. 
        !          1041: 
        !          1042:    It is best to keep this as small as possible to avoid having to 
        !          1043:    flush multiple lines in the cache.  */
        !          1044: 
        !          1045: #define TRAMPOLINE_TEMPLATE(FILE) \
        !          1046:   {                                                    \
        !          1047:     fprintf (FILE, "\tldw      36(0,%%r22),%%r21\n");  \
        !          1048:     fprintf (FILE, "\tbb,>=,n  %%r21,30,.+16\n");      \
        !          1049:     fprintf (FILE, "\tdepi     0,31,2,%%r21\n");       \
        !          1050:     fprintf (FILE, "\tldw      4(0,%%r21),%%r19\n");   \
        !          1051:     fprintf (FILE, "\tldw      0(0,%%r21),%%r21\n");   \
        !          1052:     fprintf (FILE, "\tldsid    (0,%%r21),%%r1\n");     \
        !          1053:     fprintf (FILE, "\tmtsp     %%r1,%%sr0\n");         \
        !          1054:     fprintf (FILE, "\tbe       0(%%sr0,%%r21)\n");     \
        !          1055:     fprintf (FILE, "\tldw      40(0,%%r22),%%r29\n");  \
        !          1056:     fprintf (FILE, "\t.word    0\n");                  \
        !          1057:     fprintf (FILE, "\t.word    0\n");                  \
        !          1058:   }
        !          1059: 
        !          1060: /* Length in units of the trampoline for entering a nested function.
        !          1061: 
        !          1062:    Flush the cache entries corresponding to the first and last addresses
        !          1063:    of the trampoline.  This is necessary as the trampoline may cross two
        !          1064:    cache lines.  
        !          1065: 
        !          1066:    If the code part of the trampoline ever grows to > 32 bytes, then it
        !          1067:    will become necessary to hack on the cacheflush pattern in pa.md.  */
        !          1068: 
        !          1069: #define TRAMPOLINE_SIZE (11 * 4)
        !          1070: 
        !          1071: /* Emit RTL insns to initialize the variable parts of a trampoline.
        !          1072:    FNADDR is an RTX for the address of the function's pure code.
        !          1073:    CXT is an RTX for the static chain value for the function.
        !          1074: 
        !          1075:    Move the function address to the trampoline template at offset 12.
        !          1076:    Move the static chain value to trampoline template at offset 16.  */
        !          1077: 
        !          1078: #define INITIALIZE_TRAMPOLINE(TRAMP, FNADDR, CXT) \
        !          1079: {                                                                      \
        !          1080:   rtx start_addr, end_addr, masked_start_addr;                         \
        !          1081:                                                                        \
        !          1082:   start_addr = memory_address (Pmode, plus_constant ((TRAMP), 36));    \
        !          1083:   emit_move_insn (gen_rtx (MEM, Pmode, start_addr), (FNADDR));         \
        !          1084:   start_addr = memory_address (Pmode, plus_constant ((TRAMP), 40));    \
        !          1085:   emit_move_insn (gen_rtx (MEM, Pmode, start_addr), (CXT));            \
        !          1086:   /* fdc and fic only use registers for the address to flush,          \
        !          1087:      they do not accept integer displacements.  */                     \
        !          1088:   start_addr = force_reg (SImode, (TRAMP));                            \
        !          1089:   end_addr = force_reg (SImode, plus_constant ((TRAMP), 32));          \
        !          1090:   emit_insn (gen_dcacheflush (start_addr, end_addr));                  \
        !          1091:   masked_start_addr = gen_reg_rtx (SImode);                            \
        !          1092:   emit_insn (gen_andsi3 (masked_start_addr, start_addr,                        \
        !          1093:                         GEN_INT (0x3fffffff)));                        \
        !          1094:   end_addr = force_reg (SImode, plus_constant (masked_start_addr, 32));        \
        !          1095:   emit_insn (gen_icacheflush (masked_start_addr, end_addr, start_addr, \
        !          1096:                              gen_reg_rtx (SImode), gen_reg_rtx (SImode)));\
        !          1097: }
        !          1098: 
        !          1099: /* Emit code for a call to builtin_saveregs.  We must emit USE insns which
        !          1100:    reference the 4 integer arg registers and 4 fp arg registers.
        !          1101:    Ordinarily they are not call used registers, but they are for
        !          1102:    _builtin_saveregs, so we must make this explicit.  */
        !          1103: 
        !          1104: #define EXPAND_BUILTIN_SAVEREGS(ARGLIST) (rtx)hppa_builtin_saveregs (ARGLIST)
        !          1105: 
        !          1106: 
        !          1107: /* Addressing modes, and classification of registers for them.  */
        !          1108: 
        !          1109: #define HAVE_POST_INCREMENT
        !          1110: #define HAVE_POST_DECREMENT
        !          1111: 
        !          1112: #define HAVE_PRE_DECREMENT
        !          1113: #define HAVE_PRE_INCREMENT
        !          1114: 
        !          1115: /* Macros to check register numbers against specific register classes.  */
        !          1116: 
        !          1117: /* These assume that REGNO is a hard or pseudo reg number.
        !          1118:    They give nonzero only if REGNO is a hard reg of the suitable class
        !          1119:    or a pseudo reg currently allocated to a suitable hard reg.
        !          1120:    Since they use reg_renumber, they are safe only once reg_renumber
        !          1121:    has been allocated, which happens in local-alloc.c.  */
        !          1122: 
        !          1123: #define REGNO_OK_FOR_INDEX_P(REGNO) \
        !          1124:   ((REGNO) && ((REGNO) < 32 || (unsigned) reg_renumber[REGNO] < 32))
        !          1125: #define REGNO_OK_FOR_BASE_P(REGNO)  \
        !          1126:   ((REGNO) && ((REGNO) < 32 || (unsigned) reg_renumber[REGNO] < 32))
        !          1127: #define REGNO_OK_FOR_FP_P(REGNO) \
        !          1128:   (((REGNO) >= 32 && (REGNO) <= 99)\
        !          1129:    || (reg_renumber[REGNO] >= 32 && reg_renumber[REGNO] <= 99))
        !          1130: 
        !          1131: /* Now macros that check whether X is a register and also,
        !          1132:    strictly, whether it is in a specified class.
        !          1133: 
        !          1134:    These macros are specific to the the HP-PA, and may be used only
        !          1135:    in code for printing assembler insns and in conditions for
        !          1136:    define_optimization.  */
        !          1137: 
        !          1138: /* 1 if X is an fp register.  */
        !          1139: 
        !          1140: #define FP_REG_P(X) (REG_P (X) && REGNO_OK_FOR_FP_P (REGNO (X)))
        !          1141: 
        !          1142: /* Maximum number of registers that can appear in a valid memory address.  */
        !          1143: 
        !          1144: #define MAX_REGS_PER_ADDRESS 2
        !          1145: 
        !          1146: /* Recognize any constant value that is a valid address except
        !          1147:    for symbolic addresses.  We get better CSE by rejecting them
        !          1148:    here and allowing hppa_legitimize_address to break them up.  We
        !          1149:    use most of the constants accepted by CONSTANT_P, except CONST_DOUBLE.  */
        !          1150: 
        !          1151: #define CONSTANT_ADDRESS_P(X) \
        !          1152:   ((GET_CODE (X) == LABEL_REF || GET_CODE (X) == SYMBOL_REF            \
        !          1153:    || GET_CODE (X) == CONST_INT || GET_CODE (X) == CONST               \
        !          1154:    || GET_CODE (X) == HIGH)                                            \
        !          1155:    && (reload_in_progress || reload_completed || ! symbolic_expression_p (X)))
        !          1156: 
        !          1157: /* Include all constant integers and constant doubles, but not
        !          1158:    floating-point, except for floating-point zero. 
        !          1159: 
        !          1160:    Also reject function labels as reload can not handle them correctly
        !          1161:    right now.  (Fix this for 2.5).  */
        !          1162: #define LEGITIMATE_CONSTANT_P(X)               \
        !          1163:   (((GET_MODE_CLASS (GET_MODE (X)) != MODE_FLOAT       \
        !          1164:      || (X) == CONST0_RTX (GET_MODE (X)))      \
        !          1165:     && ! function_label_operand (X, VOIDmode)))
        !          1166: 
        !          1167: /* Subroutine for EXTRA_CONSTRAINT.  
        !          1168: 
        !          1169:    Return 1 iff OP is a pseudo which did not get a hard register and
        !          1170:    we are running the reload pass.  */
        !          1171: 
        !          1172: #define IS_RELOADING_PSEUDO_P(OP) \
        !          1173:   ((reload_in_progress                                 \
        !          1174:     && GET_CODE (OP) == REG                            \
        !          1175:     && REGNO (OP) >= FIRST_PSEUDO_REGISTER             \
        !          1176:     && reg_renumber [REGNO (OP)] < 0))
        !          1177: 
        !          1178: /* Optional extra constraints for this machine. Borrowed from sparc.h.
        !          1179: 
        !          1180:    For the HPPA, `Q' means that this is a memory operand but not a
        !          1181:    symbolic memory operand.  Note that an unassigned pseudo register
        !          1182:    is such a memory operand.  Needed because reload will generate
        !          1183:    these things in insns and then not re-recognize the insns, causing
        !          1184:    constrain_operands to fail.
        !          1185: 
        !          1186:    Also note `Q' accepts any memory operand during the reload pass.
        !          1187:    This includes out-of-range displacements in reg+d addressing. 
        !          1188:    This makes for better code.  (??? For 2.5 address this issue).
        !          1189: 
        !          1190:    `R' is unused.
        !          1191: 
        !          1192:    `S' is unused.
        !          1193: 
        !          1194:    `T' is for fp loads and stores.  */
        !          1195: #define EXTRA_CONSTRAINT(OP, C)                                \
        !          1196:   ((C) == 'Q' ?                                                \
        !          1197:    (IS_RELOADING_PSEUDO_P (OP)                         \
        !          1198:     || (GET_CODE (OP) == MEM                           \
        !          1199:        && reload_in_progress)                          \
        !          1200:     || (GET_CODE (OP) == MEM                           \
        !          1201:        && memory_address_p (GET_MODE (OP), XEXP (OP, 0))\
        !          1202:        && ! symbolic_memory_operand (OP, VOIDmode)))   \
        !          1203:    : ((C) == 'T' ?                                     \
        !          1204:       (GET_CODE (OP) == MEM                            \
        !          1205:        /* Using DFmode forces only short displacements \
        !          1206:          to be recognized as valid in reg+d addresses.  */\
        !          1207:        && memory_address_p (DFmode, XEXP (OP, 0))) : 0))
        !          1208: 
        !          1209: /* The macros REG_OK_FOR..._P assume that the arg is a REG rtx
        !          1210:    and check its validity for a certain class.
        !          1211:    We have two alternate definitions for each of them.
        !          1212:    The usual definition accepts all pseudo regs; the other rejects
        !          1213:    them unless they have been allocated suitable hard regs.
        !          1214:    The symbol REG_OK_STRICT causes the latter definition to be used.
        !          1215: 
        !          1216:    Most source files want to accept pseudo regs in the hope that
        !          1217:    they will get allocated to the class that the insn wants them to be in.
        !          1218:    Source files for reload pass need to be strict.
        !          1219:    After reload, it makes no difference, since pseudo regs have
        !          1220:    been eliminated by then.  */
        !          1221: 
        !          1222: #ifndef REG_OK_STRICT
        !          1223: 
        !          1224: /* Nonzero if X is a hard reg that can be used as an index
        !          1225:    or if it is a pseudo reg.  */
        !          1226: #define REG_OK_FOR_INDEX_P(X) \
        !          1227: (REGNO (X) && (REGNO (X) < 32 || REGNO (X) >= FIRST_PSEUDO_REGISTER))
        !          1228: /* Nonzero if X is a hard reg that can be used as a base reg
        !          1229:    or if it is a pseudo reg.  */
        !          1230: #define REG_OK_FOR_BASE_P(X) \
        !          1231: (REGNO (X) && (REGNO (X) < 32 || REGNO (X) >= FIRST_PSEUDO_REGISTER))
        !          1232: 
        !          1233: #else
        !          1234: 
        !          1235: /* Nonzero if X is a hard reg that can be used as an index.  */
        !          1236: #define REG_OK_FOR_INDEX_P(X) REGNO_OK_FOR_INDEX_P (REGNO (X))
        !          1237: /* Nonzero if X is a hard reg that can be used as a base reg.  */
        !          1238: #define REG_OK_FOR_BASE_P(X) REGNO_OK_FOR_BASE_P (REGNO (X))
        !          1239: 
        !          1240: #endif
        !          1241: 
        !          1242: /* GO_IF_LEGITIMATE_ADDRESS recognizes an RTL expression
        !          1243:    that is a valid memory address for an instruction.
        !          1244:    The MODE argument is the machine mode for the MEM expression
        !          1245:    that wants to use this address.
        !          1246: 
        !          1247:    On the HP-PA, the actual legitimate addresses must be
        !          1248:    REG+REG, REG+(REG*SCALE) or REG+SMALLINT.
        !          1249:    But we can treat a SYMBOL_REF as legitimate if it is part of this
        !          1250:    function's constant-pool, because such addresses can actually
        !          1251:    be output as REG+SMALLINT.  */
        !          1252: 
        !          1253: #define VAL_5_BITS_P(X) ((unsigned)(X) + 0x10 < 0x20)
        !          1254: #define INT_5_BITS(X) VAL_5_BITS_P (INTVAL (X))
        !          1255: 
        !          1256: #define VAL_U5_BITS_P(X) ((unsigned)(X) < 0x20)
        !          1257: #define INT_U5_BITS(X) VAL_U5_BITS_P (INTVAL (X))
        !          1258: 
        !          1259: #define VAL_11_BITS_P(X) ((unsigned)(X) + 0x400 < 0x800)
        !          1260: #define INT_11_BITS(X) VAL_11_BITS_P (INTVAL (X))
        !          1261: 
        !          1262: #define VAL_14_BITS_P(X) ((unsigned)(X) + 0x2000 < 0x4000)
        !          1263: #define INT_14_BITS(X) VAL_14_BITS_P (INTVAL (X))
        !          1264: 
        !          1265: #define GO_IF_LEGITIMATE_ADDRESS(MODE, X, ADDR)  \
        !          1266: {                                                      \
        !          1267:   if ((REG_P (X) && REG_OK_FOR_BASE_P (X))             \
        !          1268:       || ((GET_CODE (X) == PRE_DEC || GET_CODE (X) == POST_DEC         \
        !          1269:           || GET_CODE (X) == PRE_INC || GET_CODE (X) == POST_INC)      \
        !          1270:          && REG_P (XEXP (X, 0))                        \
        !          1271:          && REG_OK_FOR_BASE_P (XEXP (X, 0))))          \
        !          1272:     goto ADDR;                                         \
        !          1273:   else if (GET_CODE (X) == PLUS)                       \
        !          1274:     {                                                  \
        !          1275:       rtx base = 0, index;                             \
        !          1276:       if (flag_pic == 3 && XEXP (X, 0) == pic_offset_table_rtx)\
        !          1277:        {                                               \
        !          1278:          if (GET_CODE (XEXP (X, 1)) == REG             \
        !          1279:              && REG_OK_FOR_BASE_P (XEXP (X, 1)))       \
        !          1280:            goto ADDR;                                  \
        !          1281:          else if (flag_pic == 1                        \
        !          1282:                   && GET_CODE (XEXP (X, 1)) != REG     \
        !          1283:                   && GET_CODE (XEXP (X, 1)) != LO_SUM  \
        !          1284:                   && GET_CODE (XEXP (X, 1)) != MEM)    \
        !          1285:            goto ADDR;                                  \
        !          1286:        }                                               \
        !          1287:       else if (REG_P (XEXP (X, 0))                     \
        !          1288:          && REG_OK_FOR_BASE_P (XEXP (X, 0)))           \
        !          1289:        base = XEXP (X, 0), index = XEXP (X, 1);        \
        !          1290:       else if (REG_P (XEXP (X, 1))                     \
        !          1291:               && REG_OK_FOR_BASE_P (XEXP (X, 1)))      \
        !          1292:        base = XEXP (X, 1), index = XEXP (X, 0);        \
        !          1293:       if (base != 0)                                   \
        !          1294:        if (GET_CODE (index) == CONST_INT               \
        !          1295:            && ((INT_14_BITS (index) && (MODE) != SFmode && (MODE) != DFmode) \
        !          1296:                || INT_5_BITS (index)))                 \
        !          1297:          goto ADDR;                                    \
        !          1298:     }                                                  \
        !          1299:   else if (GET_CODE (X) == LO_SUM                      \
        !          1300:           && GET_CODE (XEXP (X, 0)) == REG             \
        !          1301:           && REG_OK_FOR_BASE_P (XEXP (X, 0))           \
        !          1302:           && CONSTANT_P (XEXP (X, 1))                  \
        !          1303:           && (MODE) != SFmode                          \
        !          1304:           && (MODE) != DFmode)                         \
        !          1305:     goto ADDR;                                         \
        !          1306:   else if (GET_CODE (X) == LO_SUM                      \
        !          1307:           && GET_CODE (XEXP (X, 0)) == SUBREG          \
        !          1308:           && GET_CODE (SUBREG_REG (XEXP (X, 0))) == REG\
        !          1309:           && REG_OK_FOR_BASE_P (SUBREG_REG (XEXP (X, 0)))\
        !          1310:           && CONSTANT_P (XEXP (X, 1))                  \
        !          1311:           && (MODE) != SFmode                          \
        !          1312:           && (MODE) != DFmode)                         \
        !          1313:     goto ADDR;                                         \
        !          1314:   else if (GET_CODE (X) == LABEL_REF                   \
        !          1315:           || (GET_CODE (X) == CONST_INT                \
        !          1316:               && INT_14_BITS (X)))                     \
        !          1317:     goto ADDR;                                         \
        !          1318: }
        !          1319: 
        !          1320: /* Try machine-dependent ways of modifying an illegitimate address
        !          1321:    to be legitimate.  If we find one, return the new, valid address.
        !          1322:    This macro is used in only one place: `memory_address' in explow.c.
        !          1323: 
        !          1324:    OLDX is the address as it was before break_out_memory_refs was called.
        !          1325:    In some cases it is useful to look at this to decide what needs to be done.
        !          1326: 
        !          1327:    MODE and WIN are passed so that this macro can use
        !          1328:    GO_IF_LEGITIMATE_ADDRESS.
        !          1329: 
        !          1330:    It is always safe for this macro to do nothing.  It exists to recognize
        !          1331:    opportunities to optimize the output.  */
        !          1332: 
        !          1333: extern struct rtx_def *hppa_legitimize_address ();
        !          1334: #define LEGITIMIZE_ADDRESS(X, OLDX, MODE, WIN) \
        !          1335: { rtx orig_x = (X);                            \
        !          1336:   (X) = hppa_legitimize_address (X, OLDX, MODE);       \
        !          1337:   if ((X) != orig_x && memory_address_p (MODE, X)) \
        !          1338:     goto WIN; }
        !          1339: 
        !          1340: /* Go to LABEL if ADDR (a legitimate address expression)
        !          1341:    has an effect that depends on the machine mode it is used for.  */
        !          1342: 
        !          1343: #define GO_IF_MODE_DEPENDENT_ADDRESS(ADDR,LABEL)       \
        !          1344:   if (GET_CODE (ADDR) == PRE_DEC       \
        !          1345:       || GET_CODE (ADDR) == POST_DEC   \
        !          1346:       || GET_CODE (ADDR) == PRE_INC    \
        !          1347:       || GET_CODE (ADDR) == POST_INC)  \
        !          1348:     goto LABEL
        !          1349: 
        !          1350: /* Define this macro if references to a symbol must be treated
        !          1351:    differently depending on something about the variable or
        !          1352:    function named by the symbol (such as what section it is in).
        !          1353: 
        !          1354:    The macro definition, if any, is executed immediately after the
        !          1355:    rtl for DECL or other node is created.
        !          1356:    The value of the rtl will be a `mem' whose address is a
        !          1357:    `symbol_ref'.
        !          1358: 
        !          1359:    The usual thing for this macro to do is to a flag in the
        !          1360:    `symbol_ref' (such as `SYMBOL_REF_FLAG') or to store a modified
        !          1361:    name string in the `symbol_ref' (if one bit is not enough
        !          1362:    information).
        !          1363: 
        !          1364:    On the HP-PA we use this to indicate if a symbol is in text or
        !          1365:    data space.  Also, function labels need special treatment. */
        !          1366: 
        !          1367: #define TEXT_SPACE_P(DECL)\
        !          1368:   (TREE_CODE (DECL) == FUNCTION_DECL                                   \
        !          1369:    || (TREE_CODE (DECL) == VAR_DECL                                    \
        !          1370:        && TREE_READONLY (DECL) && ! TREE_SIDE_EFFECTS (DECL)           \
        !          1371:        && !flag_pic)                                                   \
        !          1372:    || (*tree_code_type[(int) TREE_CODE (DECL)] == 'c'                  \
        !          1373:        && !(TREE_CODE (DECL) == STRING_CST && flag_writable_strings)))
        !          1374: 
        !          1375: #define FUNCTION_NAME_P(NAME) \
        !          1376: (*(NAME) == '@' || (*(NAME) == '*' && *((NAME) + 1) == '@'))
        !          1377: 
        !          1378: #define ENCODE_SECTION_INFO(DECL)\
        !          1379: do                                                     \
        !          1380:   { if (TEXT_SPACE_P (DECL))                           \
        !          1381:       {        rtx _rtl;                                       \
        !          1382:        if (TREE_CODE (DECL) == FUNCTION_DECL           \
        !          1383:            || TREE_CODE (DECL) == VAR_DECL)            \
        !          1384:          _rtl = DECL_RTL (DECL);                       \
        !          1385:        else                                            \
        !          1386:          _rtl = TREE_CST_RTL (DECL);                   \
        !          1387:        SYMBOL_REF_FLAG (XEXP (_rtl, 0)) = 1;           \
        !          1388:        if (TREE_CODE (DECL) == FUNCTION_DECL)          \
        !          1389:          hppa_encode_label (XEXP (DECL_RTL (DECL), 0));\
        !          1390:       }                                                        \
        !          1391:   }                                                    \
        !          1392: while (0)
        !          1393:   
        !          1394: /* Store the user-specified part of SYMBOL_NAME in VAR.
        !          1395:    This is sort of inverse to ENCODE_SECTION_INFO.  */
        !          1396: 
        !          1397: #define STRIP_NAME_ENCODING(VAR,SYMBOL_NAME)   \
        !          1398:   (VAR) = ((SYMBOL_NAME)  + ((SYMBOL_NAME)[0] == '*' ? \
        !          1399:                             1 + (SYMBOL_NAME)[1] == '@'\
        !          1400:                             : (SYMBOL_NAME)[0] == '@'))
        !          1401: 
        !          1402: /* Specify the machine mode that this machine uses
        !          1403:    for the index in the tablejump instruction.  */
        !          1404: #define CASE_VECTOR_MODE DImode
        !          1405: 
        !          1406: /* Define this if the tablejump instruction expects the table
        !          1407:    to contain offsets from the address of the table.
        !          1408:    Do not define this if the table should contain absolute addresses.  */
        !          1409: /* #define CASE_VECTOR_PC_RELATIVE */
        !          1410: 
        !          1411: #define CASE_DROPS_THROUGH
        !          1412: /* Specify the tree operation to be used to convert reals to integers.  */
        !          1413: #define IMPLICIT_FIX_EXPR FIX_ROUND_EXPR
        !          1414: 
        !          1415: /* This is the kind of divide that is easiest to do in the general case.  */
        !          1416: #define EASY_DIV_EXPR TRUNC_DIV_EXPR
        !          1417: 
        !          1418: /* Define this as 1 if `char' should by default be signed; else as 0.  */
        !          1419: #define DEFAULT_SIGNED_CHAR 1
        !          1420: 
        !          1421: /* Max number of bytes we can move from memory to memory
        !          1422:    in one reasonably fast instruction.  */
        !          1423: #define MOVE_MAX 8
        !          1424: 
        !          1425: /* Define if operations between registers always perform the operation
        !          1426:    on the full register even if a narrower mode is specified.  */
        !          1427: #define WORD_REGISTER_OPERATIONS
        !          1428: 
        !          1429: /* Define if loading in MODE, an integral mode narrower than BITS_PER_WORD
        !          1430:    will either zero-extend or sign-extend.  The value of this macro should
        !          1431:    be the code that says which one of the two operations is implicitly
        !          1432:    done, NIL if none.  */
        !          1433: #define LOAD_EXTEND_OP(MODE) ZERO_EXTEND
        !          1434: 
        !          1435: /* Nonzero if access to memory by bytes is slow and undesirable.  */
        !          1436: #define SLOW_BYTE_ACCESS 1
        !          1437: 
        !          1438: /* Do not break .stabs pseudos into continuations.  */
        !          1439: #define DBX_CONTIN_LENGTH 0
        !          1440: 
        !          1441: /* Value is 1 if truncating an integer of INPREC bits to OUTPREC bits
        !          1442:    is done just by pretending it is already truncated.  */
        !          1443: #define TRULY_NOOP_TRUNCATION(OUTPREC, INPREC) 1
        !          1444: 
        !          1445: /* We assume that the store-condition-codes instructions store 0 for false
        !          1446:    and some other value for true.  This is the value stored for true.  */
        !          1447: 
        !          1448: #define STORE_FLAG_VALUE 1
        !          1449: 
        !          1450: /* When a prototype says `char' or `short', really pass an `int'.  */
        !          1451: #define PROMOTE_PROTOTYPES
        !          1452: 
        !          1453: /* Specify the machine mode that pointers have.
        !          1454:    After generation of rtl, the compiler makes no further distinction
        !          1455:    between pointers and any other objects of this machine mode.  */
        !          1456: #define Pmode SImode
        !          1457: 
        !          1458: /* Add any extra modes needed to represent the condition code.
        !          1459: 
        !          1460:    HPPA floating comparisons produce condition codes. */
        !          1461: #define EXTRA_CC_MODES CCFPmode
        !          1462: 
        !          1463: /* Define the names for the modes specified above.  */
        !          1464: #define EXTRA_CC_NAMES "CCFP"
        !          1465: 
        !          1466: /* Given a comparison code (EQ, NE, etc.) and the first operand of a COMPARE,
        !          1467:    return the mode to be used for the comparison.  For floating-point, CCFPmode
        !          1468:    should be used.  CC_NOOVmode should be used when the first operand is a
        !          1469:    PLUS, MINUS, or NEG.  CCmode should be used when no special processing is
        !          1470:    needed.  */
        !          1471: #define SELECT_CC_MODE(OP,X,Y) \
        !          1472:   (GET_MODE_CLASS (GET_MODE (X)) == MODE_FLOAT ? CCFPmode : CCmode)    \
        !          1473: 
        !          1474: /* A function address in a call instruction
        !          1475:    is a byte address (for indexing purposes)
        !          1476:    so give the MEM rtx a byte's mode.  */
        !          1477: #define FUNCTION_MODE SImode
        !          1478:   
        !          1479: /* Define this if addresses of constant functions
        !          1480:    shouldn't be put through pseudo regs where they can be cse'd.
        !          1481:    Desirable on machines where ordinary constants are expensive
        !          1482:    but a CALL with constant address is cheap.  */
        !          1483: #define NO_FUNCTION_CSE
        !          1484: 
        !          1485: /* Define this to be nonzero if shift instructions ignore all but the low-order
        !          1486:    few bits. */
        !          1487: #define SHIFT_COUNT_TRUNCATED 1
        !          1488: 
        !          1489: /* Use atexit for static constructors/destructors, instead of defining
        !          1490:    our own exit function.  */
        !          1491: #define HAVE_ATEXIT
        !          1492: 
        !          1493: /* Compute the cost of computing a constant rtl expression RTX
        !          1494:    whose rtx-code is CODE.  The body of this macro is a portion
        !          1495:    of a switch statement.  If the code is computed here,
        !          1496:    return it with a return statement.  Otherwise, break from the switch.  */
        !          1497: 
        !          1498: #define CONST_COSTS(RTX,CODE,OUTER_CODE) \
        !          1499:   case CONST_INT:                                              \
        !          1500:     if (INTVAL (RTX) == 0) return 0;                           \
        !          1501:     if (INT_14_BITS (RTX)) return 1;                           \
        !          1502:   case HIGH:                                                   \
        !          1503:     return 2;                                                  \
        !          1504:   case CONST:                                                  \
        !          1505:   case LABEL_REF:                                              \
        !          1506:   case SYMBOL_REF:                                             \
        !          1507:     return 4;                                                  \
        !          1508:   case CONST_DOUBLE:                                           \
        !          1509:     if (RTX == CONST0_RTX (DFmode) || RTX == CONST0_RTX (SFmode)\
        !          1510:        && OUTER_CODE != SET)                                   \
        !          1511:       return 0;                                                        \
        !          1512:     else                                                       \
        !          1513:       return 8;
        !          1514: 
        !          1515: #define ADDRESS_COST(RTX) \
        !          1516:   (GET_CODE (RTX) == REG ? 1 : hppa_address_cost (RTX))
        !          1517: 
        !          1518: /* Compute extra cost of moving data between one register class
        !          1519:    and another.
        !          1520: 
        !          1521:    Make moves from SAR so expensive they should never happen. Used to
        !          1522:    have 0xffff here but that generates an overflow in rare cases.
        !          1523: 
        !          1524:    Copies involving a FP register and a non-FP register are relatively 
        !          1525:    expensive because they must go through memory.
        !          1526: 
        !          1527:    Other copies are reasonably cheap.  */
        !          1528: #define REGISTER_MOVE_COST(CLASS1, CLASS2) \
        !          1529:  (CLASS1 == SHIFT_REGS ? 0x100                                 \
        !          1530:   : FP_REG_CLASS_P (CLASS1) && ! FP_REG_CLASS_P (CLASS2) ? 16  \
        !          1531:   : FP_REG_CLASS_P (CLASS2) && ! FP_REG_CLASS_P (CLASS1) ? 16  \
        !          1532:   : 2)
        !          1533: 
        !          1534: 
        !          1535: /* Provide the costs of a rtl expression.  This is in the body of a
        !          1536:    switch on CODE.  The purpose for the cost of MULT is to encourage
        !          1537:    `synth_mult' to find a synthetic multiply when reasonable.  */
        !          1538: 
        !          1539: #define RTX_COSTS(X,CODE,OUTER_CODE)                   \
        !          1540:   case MULT:                                           \
        !          1541:     return TARGET_SNAKE && ! TARGET_DISABLE_FPREGS     \
        !          1542:       ? COSTS_N_INSNS (8) : COSTS_N_INSNS (20);        \
        !          1543:   case DIV:                                            \
        !          1544:   case UDIV:                                           \
        !          1545:   case MOD:                                            \
        !          1546:   case UMOD:                                           \
        !          1547:     return COSTS_N_INSNS (60);                         \
        !          1548:   case PLUS: /* this includes shNadd insns */          \
        !          1549:     return COSTS_N_INSNS (1) + 2;
        !          1550: 
        !          1551: /* Adjust the cost of dependencies.  */
        !          1552: 
        !          1553: #define ADJUST_COST(INSN,LINK,DEP,COST) \
        !          1554:   (COST) = pa_adjust_cost (INSN, LINK, DEP, COST)
        !          1555: 
        !          1556: /* Handling the special cases is going to get too complicated for a macro,
        !          1557:    just call `pa_adjust_insn_length' to do the real work.  */
        !          1558: #define ADJUST_INSN_LENGTH(INSN, LENGTH)       \
        !          1559:   LENGTH += pa_adjust_insn_length (INSN, LENGTH);
        !          1560: 
        !          1561: /* Enable a bug fix.  (This is for extra caution.)  */
        !          1562: #define SHORTEN_WITH_ADJUST_INSN_LENGTH
        !          1563: 
        !          1564: /* Millicode insns are actually function calls with some special
        !          1565:    constraints on arguments and register usage.
        !          1566: 
        !          1567:    Millicode calls always expect their arguments in the integer argument
        !          1568:    registers, and always return their result in %r29 (ret1).  They
        !          1569:    are expected to clobber their arguments, %r1, %r29, and %r31 and
        !          1570:    nothing else.
        !          1571: 
        !          1572:    These macros tell reorg that the references to arguments and 
        !          1573:    register clobbers for millicode calls do not appear to happen 
        !          1574:    until after the millicode call.  This allows reorg to put insns
        !          1575:    which set the argument registers into the delay slot of the millicode
        !          1576:    call -- thus they act more like traditional CALL_INSNs.
        !          1577: 
        !          1578:    get_attr_type will try to recognize the given insn, so make sure to
        !          1579:    filter out things it will not accept -- SEQUENCE, USE and CLOBBER insns
        !          1580:    in particular.  */
        !          1581: #define INSN_SETS_ARE_DELAYED(X) \
        !          1582:   ((GET_CODE (X) == INSN                       \
        !          1583:     && GET_CODE (PATTERN (X)) != SEQUENCE      \
        !          1584:     && GET_CODE (PATTERN (X)) != USE           \
        !          1585:     && GET_CODE (PATTERN (X)) != CLOBBER       \
        !          1586:     && get_attr_type (X) == TYPE_MILLI))
        !          1587: 
        !          1588: #define INSN_REFERENCES_ARE_DELAYED(X) \
        !          1589:   ((GET_CODE (X) == INSN                       \
        !          1590:     && GET_CODE (PATTERN (X)) != SEQUENCE      \
        !          1591:     && GET_CODE (PATTERN (X)) != USE           \
        !          1592:     && GET_CODE (PATTERN (X)) != CLOBBER       \
        !          1593:     && get_attr_type (X) == TYPE_MILLI))       
        !          1594: 
        !          1595: 
        !          1596: /* Control the assembler format that we output.  */
        !          1597: 
        !          1598: /* Output at beginning of assembler file.  */
        !          1599: 
        !          1600: #define ASM_FILE_START(FILE) \
        !          1601: do { fprintf (FILE, "\t.SPACE $PRIVATE$\n\
        !          1602: \t.SUBSPA $DATA$,QUAD=1,ALIGN=8,ACCESS=31\n\
        !          1603: \t.SUBSPA $BSS$,QUAD=1,ALIGN=8,ACCESS=31,ZERO,SORT=82\n\
        !          1604: \t.SPACE $TEXT$\n\
        !          1605: \t.SUBSPA $LIT$,QUAD=0,ALIGN=8,ACCESS=44\n\
        !          1606: \t.SUBSPA $CODE$,QUAD=0,ALIGN=8,ACCESS=44,CODE_ONLY\n\
        !          1607: \t.IMPORT $global$,DATA\n\
        !          1608: \t.IMPORT $$dyncall,MILLICODE\n");\
        !          1609:      if (profile_flag)\
        !          1610:        fprintf (FILE, "\t.IMPORT _mcount, CODE\n");\
        !          1611:    } while (0)
        !          1612: 
        !          1613: /* Output to assembler file text saying following lines
        !          1614:    may contain character constants, extra white space, comments, etc.  */
        !          1615: 
        !          1616: #define ASM_APP_ON ""
        !          1617: 
        !          1618: /* Output to assembler file text saying following lines
        !          1619:    no longer contain unusual constructs.  */
        !          1620: 
        !          1621: #define ASM_APP_OFF ""
        !          1622: 
        !          1623: /* We don't yet know how to identify GCC to HP-PA machines.  */
        !          1624: #define ASM_IDENTIFY_GCC(FILE) fprintf (FILE, "; gcc_compiled.:\n")
        !          1625: 
        !          1626: /* Output before code.  */
        !          1627: 
        !          1628: /* Supposedly the assembler rejects the command if there is no tab!  */
        !          1629: #define TEXT_SECTION_ASM_OP "\t.SPACE $TEXT$\n\t.SUBSPA $CODE$"
        !          1630: 
        !          1631: /* Output before read-only data.  */
        !          1632: 
        !          1633: /* Supposedly the assembler rejects the command if there is no tab!  */
        !          1634: #define READONLY_DATA_ASM_OP "\t.SPACE $TEXT$\n\t.SUBSPA $LIT$"
        !          1635: 
        !          1636: #if 0
        !          1637: /* This has apparently triggered a latent GAS bug which manifests itself
        !          1638:    as numerous warnings from the debugger of the form:
        !          1639: 
        !          1640:    During symbol reading, inner block not inside outer block in ...
        !          1641:    inner block not inside outer block in ...
        !          1642: 
        !          1643:    Or as local variables not being accessable from the debugger.
        !          1644: 
        !          1645:    Disable $LIT$ for now.  Try it with GAS-2 when it is functional (I
        !          1646:    am not even going to try to fix this in GAS-1).  */
        !          1647: #define READONLY_DATA_SECTION readonly_data
        !          1648: #endif
        !          1649: 
        !          1650: /* Output before writable data.  */
        !          1651: 
        !          1652: /* Supposedly the assembler rejects the command if there is no tab!  */
        !          1653: #define DATA_SECTION_ASM_OP "\t.SPACE $PRIVATE$\n\t.SUBSPA $DATA$"
        !          1654: 
        !          1655: /* Output before uninitialized data.  */
        !          1656: 
        !          1657: #define BSS_SECTION_ASM_OP "\t.SPACE $PRIVATE$\n\t.SUBSPA $BSS$"
        !          1658: 
        !          1659: /* Define the .bss section for ASM_OUTPUT_LOCAL to use. */
        !          1660: 
        !          1661: #define EXTRA_SECTIONS in_bss, in_readonly_data
        !          1662: 
        !          1663: #define EXTRA_SECTION_FUNCTIONS                                                \
        !          1664: void                                                                   \
        !          1665: bss_section ()                                                         \
        !          1666: {                                                                      \
        !          1667:   if (in_section != in_bss)                                            \
        !          1668:     {                                                                  \
        !          1669:       fprintf (asm_out_file, "%s\n", BSS_SECTION_ASM_OP);              \
        !          1670:       in_section = in_bss;                                             \
        !          1671:     }                                                                  \
        !          1672: }                                                                      \
        !          1673: void                                                                   \
        !          1674: readonly_data ()                                                       \
        !          1675: {                                                                      \
        !          1676:   if (in_section != in_readonly_data)                                  \
        !          1677:     {                                                                  \
        !          1678:       fprintf (asm_out_file, "%s\n", READONLY_DATA_ASM_OP);            \
        !          1679:       in_section = in_readonly_data;                                   \
        !          1680:     }                                                                  \
        !          1681: }
        !          1682: 
        !          1683: 
        !          1684: /* How to refer to registers in assembler output.
        !          1685:    This sequence is indexed by compiler's hard-register-number (see above).  */
        !          1686: 
        !          1687: #define REGISTER_NAMES \
        !          1688: {"0", "%r1", "%r2", "%r3", "%r4", "%r5", "%r6", "%r7",                 \
        !          1689:  "%r8", "%r9", "%r10", "%r11", "%r12", "%r13", "%r14", "%r15",         \
        !          1690:  "%r16", "%r17", "%r18", "%r19", "%r20", "%r21", "%r22", "%r23",       \
        !          1691:  "%r24", "%r25", "%r26", "%r27", "%r28", "%r29", "%r30", "%r31",       \
        !          1692:  "%fr4", "%fr5", "%fr6", "%fr7",       \
        !          1693:  "%fr8", "%fr9", "%fr10", "%fr11", "%fr12", "%fr13", "%fr14", "%fr15", \
        !          1694:  "%fr4", "%fr4R", "%fr5", "%fr5R", "%fr6", "%fr6R", "%fr7", "%fr7R",   \
        !          1695:  "%fr8", "%fr8R", "%fr9", "%fr9R", "%fr10", "%fr10R", "%fr11", "%fr11R",\
        !          1696:  "%fr12", "%fr12R", "%fr13", "%fr13R", "%fr14", "%fr14R", "%fr15", "%fr15R",\
        !          1697:  "%fr16", "%fr16R", "%fr17", "%fr17R", "%fr18", "%fr18R", "%fr19", "%fr19R",\
        !          1698:  "%fr20", "%fr20R", "%fr21", "%fr21R", "%fr22", "%fr22R", "%fr23", "%fr23R",\
        !          1699:  "%fr24", "%fr24R", "%fr25", "%fr25R", "%fr26", "%fr26R", "%fr27", "%fr27R",\
        !          1700:  "%fr28", "%fr28R", "%fr29", "%fr29R", "%fr30", "%fr30R", "%fr31", "%fr31R",\
        !          1701:  "SAR"}
        !          1702: 
        !          1703: /* How to renumber registers for dbx and gdb.  */
        !          1704: 
        !          1705: #define DBX_REGISTER_NUMBER(REGNO) (REGNO)
        !          1706: 
        !          1707: /* This is how to output the definition of a user-level label named NAME,
        !          1708:    such as the label on a static function or variable NAME.  */
        !          1709: 
        !          1710: #define ASM_OUTPUT_LABEL(FILE, NAME)   \
        !          1711:   do { assemble_name (FILE, NAME);     \
        !          1712:        if (TARGET_GAS)                 \
        !          1713:         fputc (':', FILE);             \
        !          1714:        fputc ('\n', FILE); } while (0)
        !          1715: 
        !          1716: /* This is how to output a command to make the user-level label named NAME
        !          1717:    defined for reference from other files.  */
        !          1718: 
        !          1719: #define ASM_OUTPUT_EXTERNAL(FILE, DECL, NAME)  \
        !          1720:   do { fputs ("\t.IMPORT ", FILE);                             \
        !          1721:         assemble_name (FILE, NAME);                            \
        !          1722:        if (FUNCTION_NAME_P (NAME))                                     \
        !          1723:         fputs (",CODE\n", FILE);                               \
        !          1724:        else                                                    \
        !          1725:         fputs (",DATA\n", FILE);                               \
        !          1726:      } while (0)
        !          1727: 
        !          1728: /* hpux ld doesn't output the object file name, or anything useful at
        !          1729:    all, to indicate the start of an object file's symbols. This screws
        !          1730:    up gdb, so we'll output this magic cookie at the end of an object
        !          1731:    file with debugging symbols */
        !          1732: 
        !          1733: #define ASM_FILE_END(FILE) \
        !          1734:   do { if (write_symbols == DBX_DEBUG)\
        !          1735:         { fputs (TEXT_SECTION_ASM_OP, FILE);\
        !          1736:           fputs ("\n\t.stabs \"end_file.\",4,0,0,Ltext_end\nLtext_end:\n",\
        !          1737:                  (FILE));\
        !          1738:         }\
        !          1739:      } while (0)
        !          1740: 
        !          1741: /* The bogus HP assembler requires ALL external references to be 
        !          1742:    "imported", even library calls. They look a bit different, so
        !          1743:    here's this macro. */
        !          1744: 
        !          1745: #define ASM_OUTPUT_EXTERNAL_LIBCALL(FILE, RTL) \
        !          1746:   do { fputs ("\t.IMPORT ", FILE);                                     \
        !          1747:        assemble_name (FILE, XSTR ((RTL), 0));                          \
        !          1748:        fputs (",CODE\n", FILE);                                                \
        !          1749:      } while (0)
        !          1750: 
        !          1751: #define ASM_GLOBALIZE_LABEL(FILE, NAME)                                        \
        !          1752:   do { fputs ("\t.EXPORT ", FILE); assemble_name (FILE, NAME);         \
        !          1753:        if (FUNCTION_NAME_P (NAME))                                     \
        !          1754:         fputs (",CODE\n", FILE);                                       \
        !          1755:        else                                                            \
        !          1756:         fputs (",DATA\n", FILE);} while (0)
        !          1757: 
        !          1758: /* This is how to output a reference to a user-level label named NAME.
        !          1759:    `assemble_name' uses this.  */
        !          1760: 
        !          1761: #define ASM_OUTPUT_LABELREF(FILE,NAME) \
        !          1762:   fprintf ((FILE), "%s", (NAME) + (FUNCTION_NAME_P (NAME) ? 1 : 0))
        !          1763: 
        !          1764: /* This is how to output an internal numbered label where
        !          1765:    PREFIX is the class of label and NUM is the number within the class.  */
        !          1766: 
        !          1767: #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM)     \
        !          1768:   {fprintf (FILE, "%s$%04d", PREFIX, NUM);             \
        !          1769:    if (TARGET_GAS)                                     \
        !          1770:      fputs (":\n", FILE);                              \
        !          1771:    else                                                        \
        !          1772:      fputs ("\n", FILE);}
        !          1773: 
        !          1774: #define STRING_SECTION_NAME "STRING"
        !          1775: 
        !          1776: /* This is how to store into the string LABEL
        !          1777:    the symbol_ref name of an internal numbered label where
        !          1778:    PREFIX is the class of label and NUM is the number within the class.
        !          1779:    This is suitable for output with `assemble_name'.  */
        !          1780: 
        !          1781: #define ASM_GENERATE_INTERNAL_LABEL(LABEL,PREFIX,NUM)  \
        !          1782:   sprintf (LABEL, "*%s$%04d", PREFIX, NUM)
        !          1783: 
        !          1784: /* This is how to output an assembler line defining a `double' constant.  */
        !          1785: 
        !          1786: #define ASM_OUTPUT_DOUBLE(FILE,VALUE)  \
        !          1787:   do { union { double d; int i[2];} __u;       \
        !          1788:     __u.d = (VALUE);                           \
        !          1789:     fprintf (FILE, "\t; .double %.20e\n\t.word %d ; = 0x%x\n\t.word %d ; = 0x%x\n",    \
        !          1790:             __u.d, __u.i[0], __u.i[0], __u.i[1], __u.i[1]);    \
        !          1791:   } while (0)
        !          1792: 
        !          1793: /* This is how to output an assembler line defining a `float' constant.  */
        !          1794: 
        !          1795: #define ASM_OUTPUT_FLOAT(FILE,VALUE)  \
        !          1796:   do { union { float f; int i;} __u;           \
        !          1797:     __u.f = (VALUE);                           \
        !          1798:     fprintf (FILE, "\t; .float %.12e\n\t.word %d ; = 0x%x\n", __u.f, __u.i, __u.i); \
        !          1799:   } while (0)
        !          1800: 
        !          1801: /* This is how to output an assembler line defining an `int' constant.  */
        !          1802: 
        !          1803: #define ASM_OUTPUT_INT(FILE,VALUE)  \
        !          1804: { fprintf (FILE, "\t.word ");                  \
        !          1805:   if (function_label_operand (VALUE, VOIDmode))        \
        !          1806:     fprintf (FILE, "P%%");                     \
        !          1807:   output_addr_const (FILE, (VALUE));           \
        !          1808:   fprintf (FILE, "\n");}
        !          1809: 
        !          1810: /* Likewise for `short' and `char' constants.  */
        !          1811: 
        !          1812: #define ASM_OUTPUT_SHORT(FILE,VALUE)  \
        !          1813: ( fprintf (FILE, "\t.half "),                  \
        !          1814:   output_addr_const (FILE, (VALUE)),           \
        !          1815:   fprintf (FILE, "\n"))
        !          1816: 
        !          1817: #define ASM_OUTPUT_CHAR(FILE,VALUE)  \
        !          1818: ( fprintf (FILE, "\t.byte "),                  \
        !          1819:   output_addr_const (FILE, (VALUE)),           \
        !          1820:   fprintf (FILE, "\n"))
        !          1821: 
        !          1822: /* This is how to output an assembler line for a numeric constant byte.  */
        !          1823: 
        !          1824: #define ASM_OUTPUT_BYTE(FILE,VALUE)  \
        !          1825:   fprintf (FILE, "\t.byte 0x%x\n", (VALUE))
        !          1826: 
        !          1827: #define ASM_OUTPUT_ASCII(FILE, P, SIZE)  \
        !          1828:   output_ascii ((FILE), (P), (SIZE))
        !          1829: 
        !          1830: #define ASM_OUTPUT_REG_PUSH(FILE,REGNO)
        !          1831: #define ASM_OUTPUT_REG_POP(FILE,REGNO) 
        !          1832: /* This is how to output an element of a case-vector that is absolute.
        !          1833:    Note that this method makes filling these branch delay slots
        !          1834:    impossible.  */
        !          1835: 
        !          1836: #define ASM_OUTPUT_ADDR_VEC_ELT(FILE, VALUE)  \
        !          1837:   fprintf (FILE, "\tb L$%04d\n\tnop\n", VALUE)
        !          1838: 
        !          1839: /* Jump tables are executable code and live in the TEXT section on the PA.  */
        !          1840: #define JUMP_TABLES_IN_TEXT_SECTION
        !          1841: 
        !          1842: /* This is how to output an element of a case-vector that is relative.
        !          1843:    (The HP-PA does not use such vectors,
        !          1844:    but we must define this macro anyway.)  */
        !          1845: 
        !          1846: #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL)  \
        !          1847:   fprintf (FILE, "\tword L%d-L%d\n", VALUE, REL)
        !          1848: 
        !          1849: /* This is how to output an assembler line
        !          1850:    that says to advance the location counter
        !          1851:    to a multiple of 2**LOG bytes.  */
        !          1852: 
        !          1853: #define ASM_OUTPUT_ALIGN(FILE,LOG)     \
        !          1854:     fprintf (FILE, "\t.align %d\n", (1<<(LOG)))
        !          1855: 
        !          1856: #define ASM_OUTPUT_SKIP(FILE,SIZE)  \
        !          1857:   fprintf (FILE, "\t.blockz %d\n", (SIZE))
        !          1858: 
        !          1859: /* This says how to output an assembler line
        !          1860:    to define a global common symbol.  */
        !          1861: 
        !          1862: /* Supposedly the assembler rejects the command if there is no tab!  */
        !          1863: 
        !          1864: 
        !          1865: #define ASM_OUTPUT_COMMON(FILE, NAME, SIZE, ROUNDED)  \
        !          1866: { bss_section ();                                      \
        !          1867:   assemble_name ((FILE), (NAME));                      \
        !          1868:   if (TARGET_GAS)                                      \
        !          1869:     fputc (':', (FILE));                               \
        !          1870:   fputs ("\t.comm ", (FILE));                          \
        !          1871:   fprintf ((FILE), "%d\n", (ROUNDED));}
        !          1872: 
        !          1873: /* This says how to output an assembler line
        !          1874:    to define a local common symbol.  */
        !          1875: 
        !          1876: #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE, ROUNDED)  \
        !          1877: { bss_section ();                                              \
        !          1878:   fprintf ((FILE), "\t.align %d\n", (SIZE) <= 4 ? 4 : 8);      \
        !          1879:   assemble_name ((FILE), (NAME));                              \
        !          1880:   if (TARGET_GAS)                                      \
        !          1881:     fputc (':', (FILE));                               \
        !          1882:   fprintf ((FILE), "\n\t.block %d\n", (ROUNDED));}
        !          1883: 
        !          1884: /* Store in OUTPUT a string (made with alloca) containing
        !          1885:    an assembler-name for a local static variable named NAME.
        !          1886:    LABELNO is an integer which is different for each call.  */
        !          1887: 
        !          1888: #define ASM_FORMAT_PRIVATE_NAME(OUTPUT, NAME, LABELNO) \
        !          1889: ( (OUTPUT) = (char *) alloca (strlen ((NAME)) + 12),   \
        !          1890:   sprintf ((OUTPUT), "%s___%d", (NAME), (LABELNO)))
        !          1891: 
        !          1892: /* Define the parentheses used to group arithmetic operations
        !          1893:    in assembler code.  */
        !          1894: 
        !          1895: #define ASM_OPEN_PAREN "("
        !          1896: #define ASM_CLOSE_PAREN ")"
        !          1897: 
        !          1898: /* Define results of standard character escape sequences.  */
        !          1899: #define TARGET_BELL 007
        !          1900: #define TARGET_BS 010
        !          1901: #define TARGET_TAB 011
        !          1902: #define TARGET_NEWLINE 012
        !          1903: #define TARGET_VT 013
        !          1904: #define TARGET_FF 014
        !          1905: #define TARGET_CR 015
        !          1906: 
        !          1907: #define PRINT_OPERAND_PUNCT_VALID_P(CHAR) \
        !          1908:   ((CHAR) == '@' || (CHAR) == '#' || (CHAR) == '*' \
        !          1909:    || (CHAR) == '^' || (CHAR) == '\'')
        !          1910: 
        !          1911: /* Print operand X (an rtx) in assembler syntax to file FILE.
        !          1912:    CODE is a letter or dot (`z' in `%z0') or 0 if no letter was specified.
        !          1913:    For `%' followed by punctuation, CODE is the punctuation and X is null.
        !          1914: 
        !          1915:    On the HP-PA, the CODE can be `r', meaning this is a register-only operand
        !          1916:    and an immediate zero should be represented as `r0'.
        !          1917: 
        !          1918:    Several % codes are defined:
        !          1919:    O an operation
        !          1920:    C compare conditions
        !          1921:    N extract conditions
        !          1922:    M modifier to handle preincrement addressing for memory refs.
        !          1923:    F modifier to handle preincrement addressing for fp memory refs */
        !          1924: 
        !          1925: #define PRINT_OPERAND(FILE, X, CODE) print_operand (FILE, X, CODE)
        !          1926: 
        !          1927: 
        !          1928: /* Print a memory address as an operand to reference that memory location.  */
        !          1929: 
        !          1930: #define PRINT_OPERAND_ADDRESS(FILE, ADDR)  \
        !          1931: { register rtx addr = ADDR;                                            \
        !          1932:   register rtx base;                                                   \
        !          1933:   int offset;                                                          \
        !          1934:   switch (GET_CODE (addr))                                             \
        !          1935:     {                                                                  \
        !          1936:     case REG:                                                          \
        !          1937:       fprintf (FILE, "0(0,%s)", reg_names [REGNO (addr)]);             \
        !          1938:       break;                                                           \
        !          1939:     case PLUS:                                                         \
        !          1940:       if (GET_CODE (XEXP (addr, 0)) == CONST_INT)                      \
        !          1941:        offset = INTVAL (XEXP (addr, 0)), base = XEXP (addr, 1);        \
        !          1942:       else if (GET_CODE (XEXP (addr, 1)) == CONST_INT)                 \
        !          1943:        offset = INTVAL (XEXP (addr, 1)), base = XEXP (addr, 0);        \
        !          1944:       else                                                             \
        !          1945:        abort ();                                                       \
        !          1946:       fprintf (FILE, "%d(0,%s)", offset, reg_names [REGNO (base)]);    \
        !          1947:       break;                                                           \
        !          1948:     case LO_SUM:                                                       \
        !          1949:       fprintf (FILE, "R%c", PA_QUOTE);                                 \
        !          1950:       output_global_address (FILE, XEXP (addr, 1));                    \
        !          1951:       fputs ("(", FILE);                                               \
        !          1952:       output_operand (XEXP (addr, 0), 0);                              \
        !          1953:       fputs (")", FILE);                                               \
        !          1954:       break;                                                           \
        !          1955:     case CONST_INT:                                                    \
        !          1956:       fprintf (FILE, "%d(0,0)", INTVAL (addr));                                \
        !          1957:       break;                                                           \
        !          1958:     default:                                                           \
        !          1959:       output_addr_const (FILE, addr);                                  \
        !          1960:     }}
        !          1961: 
        !          1962: 
        !          1963: /* Define functions in pa.c and used in insn-output.c.  */
        !          1964: 
        !          1965: extern char *output_and ();
        !          1966: extern char *output_ior ();
        !          1967: extern char *output_move_double ();
        !          1968: extern char *output_fp_move_double ();
        !          1969: extern char *output_block_move ();
        !          1970: extern char *output_scc_insn ();
        !          1971: extern char *output_cbranch ();
        !          1972: extern char *output_bb ();
        !          1973: extern char *output_dbra ();
        !          1974: extern char *output_movb ();
        !          1975: extern char *output_return ();
        !          1976: extern char *output_call ();
        !          1977: extern char *output_floatsisf2 ();
        !          1978: extern char *output_floatsidf2 ();
        !          1979: extern char *output_mul_insn ();
        !          1980: extern char *output_div_insn ();
        !          1981: extern char *output_mod_insn ();
        !          1982: extern char *singlemove_string ();
        !          1983: extern void output_arg_descriptor ();
        !          1984: extern void output_global_address ();
        !          1985: extern struct rtx_def *legitimize_pic_address ();
        !          1986: extern struct rtx_def *gen_cmp_fp ();
        !          1987: extern void hppa_encode_label ();
        !          1988: 
        !          1989: extern struct rtx_def *hppa_save_pic_table_rtx;

unix.superglobalmegacorp.com

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