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

unix.superglobalmegacorp.com

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