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

1.1     ! root        1: /* Definitions of target machine for GNU compiler, for Sun SPARC.
        !             2:    Copyright (C) 1987, 1988, 1989, 1992 Free Software Foundation, Inc.
        !             3:    Contributed by Michael Tiemann ([email protected]).
        !             4: 
        !             5: This file is part of GNU CC.
        !             6: 
        !             7: GNU CC is free software; you can redistribute it and/or modify
        !             8: it under the terms of the GNU General Public License as published by
        !             9: the Free Software Foundation; either version 2, or (at your option)
        !            10: any later version.
        !            11: 
        !            12: GNU CC is distributed in the hope that it will be useful,
        !            13: but WITHOUT ANY WARRANTY; without even the implied warranty of
        !            14: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
        !            15: GNU General Public License for more details.
        !            16: 
        !            17: You should have received a copy of the GNU General Public License
        !            18: along with GNU CC; see the file COPYING.  If not, write to
        !            19: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
        !            20: 
        !            21: /* Note that some other tm.h files include this one and then override
        !            22:    many of the definitions that relate to assembler syntax.  */
        !            23: 
        !            24: #define LIB_SPEC "%{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p} %{g:-lg} \
        !            25:   %{a:/usr/lib/bb_link.o}"
        !            26: 
        !            27: /* Provide required defaults for linker -e and -d switches.  */
        !            28: 
        !            29: #define LINK_SPEC \
        !            30:  "%{!nostdlib:%{!r*:%{!e*:-e start}}} -dc -dp %{static:-Bstatic} %{assert*}"
        !            31: 
        !            32: /* Special flags to the Sun-4 assembler when using pipe for input.  */
        !            33: 
        !            34: #define ASM_SPEC " %| %{fpic:-k} %{fPIC:-k}"
        !            35: 
        !            36: /* Define macros to distinguish architectures.  */
        !            37: #define CPP_SPEC "%{msparclite:-D__sparclite__} %{mf930:-D__sparclite__} \
        !            38: %{mf934:-D__sparclite__} %{mv8:-D__sparc_v8__}"
        !            39: 
        !            40: /* Prevent error on `-sun4' and `-target sun4' options.  */
        !            41: /* This used to translate -dalign to -malign, but that is no good
        !            42:    because it can't turn off the usual meaning of making debugging dumps.  */
        !            43: 
        !            44: #define CC1_SPEC "%{sun4:} %{target:}"
        !            45: 
        !            46: #define PTRDIFF_TYPE "int"
        !            47: /* In 2.4 it should work to delete this.
        !            48:    #define SIZE_TYPE "int"  */
        !            49: #define WCHAR_TYPE "short unsigned int"
        !            50: #define WCHAR_TYPE_SIZE 16
        !            51: 
        !            52: /* Omit frame pointer at high optimization levels.  */
        !            53:   
        !            54: #define OPTIMIZATION_OPTIONS(OPTIMIZE) \
        !            55: {                                                              \
        !            56:   if (OPTIMIZE >= 2)                                           \
        !            57:     {                                                          \
        !            58:       flag_omit_frame_pointer = 1;                             \
        !            59:     }                                                          \
        !            60: }
        !            61: 
        !            62: /* To make profiling work with -f{pic,PIC}, we need to emit the profiling
        !            63:    code into the rtl.  Also, if we are profiling, we cannot eliminate
        !            64:    the frame pointer (because the return address will get smashed).  */
        !            65: 
        !            66: #define OVERRIDE_OPTIONS \
        !            67: {                                              \
        !            68:   if (profile_flag || profile_block_flag)      \
        !            69:     flag_omit_frame_pointer = 0, flag_pic = 0; \
        !            70:   SUBTARGET_OVERRIDE_OPTIONS                   \
        !            71:   }
        !            72: 
        !            73: /* This is meant to be redefined in the host dependent files */
        !            74: #define SUBTARGET_OVERRIDE_OPTIONS
        !            75: 
        !            76: /* These compiler options take an argument.  We ignore -target for now.  */
        !            77: 
        !            78: #define WORD_SWITCH_TAKES_ARG(STR)                             \
        !            79:  (DEFAULT_WORD_SWITCH_TAKES_ARG (STR)                          \
        !            80:   || !strcmp (STR, "target") || !strcmp (STR, "assert"))
        !            81: 
        !            82: /* Names to predefine in the preprocessor for this target machine.  */
        !            83: 
        !            84: /* The GCC_NEW_VARARGS macro is so that old versions of gcc can compile
        !            85:    new versions, which have an incompatible va-sparc.h file.  This matters
        !            86:    because gcc does "gvarargs.h" instead of <varargs.h>, and thus gets the
        !            87:    wrong varargs file when it is compiled with a different version of gcc.  */
        !            88: 
        !            89: #define CPP_PREDEFINES \
        !            90:   "-Dsparc -Dsun -Dunix -D__GCC_NEW_VARARGS__ \
        !            91:    -Asystem(unix) -Asystem(bsd) -Acpu(sparc) -Amachine(sparc)"
        !            92: 
        !            93: /* Print subsidiary information on the compiler version in use.  */
        !            94: 
        !            95: #define TARGET_VERSION fprintf (stderr, " (sparc)");
        !            96: 
        !            97: /* Generate DBX debugging information.  */
        !            98: 
        !            99: #define DBX_DEBUGGING_INFO
        !           100: 
        !           101: /* Run-time compilation parameters selecting different hardware subsets.  */
        !           102: 
        !           103: extern int target_flags;
        !           104: 
        !           105: /* Nonzero if we should generate code to use the fpu.  */
        !           106: #define TARGET_FPU (target_flags & 1)
        !           107: 
        !           108: /* Nonzero if we should use FUNCTION_EPILOGUE.  Otherwise, we
        !           109:    use fast return insns, but lose some generality.  */
        !           110: #define TARGET_EPILOGUE (target_flags & 2)
        !           111: 
        !           112: /* Nonzero if we should assume that double pointers might be unaligned.
        !           113:    This can happen when linking gcc compiled code with other compilers,
        !           114:    because the ABI only guarantees 4 byte alignment.  */
        !           115: #define TARGET_UNALIGNED_DOUBLES (target_flags & 4)
        !           116: 
        !           117: /* Nonzero means that we should generate code for a v8 sparc.  */
        !           118: #define TARGET_V8 (target_flags & 64)
        !           119: 
        !           120: /* Nonzero means that we should generate code for a sparclite.
        !           121:    This enables the sparclite specific instructions, but does not affect
        !           122:    whether FPU instructions are emitted.  */
        !           123: #define TARGET_SPARCLITE (target_flags & 128)
        !           124: 
        !           125: /* Nonzero means that we should generate code using a flat register window
        !           126:    model, i.e. no save/restore instructions are generated, in the most
        !           127:    efficient manner.  This code is not compatible with normal sparc code.  */
        !           128: /* This is not a user selectable option yet, because it requires changes
        !           129:    that are not yet switchable via command line arguments.  */
        !           130: #define TARGET_FRW (target_flags & 256)
        !           131: 
        !           132: /* Nonzero means that we should generate code using a flat register window
        !           133:    model, i.e. no save/restore instructions are generated, but which is
        !           134:    compatible with normal sparc code.   This is the same as above, except
        !           135:    that the frame pointer is %l6 instead of %fp.  This code is not as efficient
        !           136:    as TARGET_FRW, because it has one less allocatable register.  */
        !           137: /* This is not a user selectable option yet, because it requires changes
        !           138:    that are not yet switchable via command line arguments.  */
        !           139: #define TARGET_FRW_COMPAT (target_flags & 512)
        !           140: 
        !           141: /* Macro to define tables used to set the flags.
        !           142:    This is a list in braces of pairs in braces,
        !           143:    each pair being { "NAME", VALUE }
        !           144:    where VALUE is the bits to set or minus the bits to clear.
        !           145:    An empty string NAME is used to identify the default VALUE.  */
        !           146: 
        !           147: /* The Fujitsu MB86930 is the original sparclite chip, with no fpu.
        !           148:    The Fujitsu MB86934 is the recent sparclite chip, with an fup.
        !           149:    We use -mf930 and -mf934 options to choose which.
        !           150:    ??? These should perhaps be -mcpu= options.  */
        !           151: 
        !           152: #define TARGET_SWITCHES  \
        !           153:   { {"fpu", 1},                        \
        !           154:     {"no-fpu", -1},            \
        !           155:     {"hard-float", 1},         \
        !           156:     {"soft-float", -1},                \
        !           157:     {"epilogue", 2},           \
        !           158:     {"no-epilogue", -2},       \
        !           159:     {"unaligned-doubles", 4},  \
        !           160:     {"no-unaligned-doubles", -4},\
        !           161:     {"v8", 64},                        \
        !           162:     {"no-v8", -64},            \
        !           163:     {"sparclite", 128},                \
        !           164:     {"no-sparclite", -128},    \
        !           165: /*  {"frw", 256}, */           \
        !           166: /*  {"no-frw", -256}, */       \
        !           167: /*  {"frw-compat", 256+512}, */        \
        !           168: /*  {"no-frw-compat", -(256+512)}, */ \
        !           169:     {"f930", 128},             \
        !           170:     {"f930", -1},              \
        !           171:     {"f934", 128},             \
        !           172:     SUBTARGET_SWITCHES         \
        !           173:     { "", TARGET_DEFAULT}}
        !           174: 
        !           175: #define TARGET_DEFAULT 3
        !           176: 
        !           177: /* This is meant to be redefined in the host dependent files */
        !           178: #define SUBTARGET_SWITCHES
        !           179: 
        !           180: /* target machine storage layout */
        !           181: 
        !           182: #if 0
        !           183: /* ??? This does not work in SunOS 4.x, so it is not enabled here.
        !           184:    Instead, it is enabled in sol2.h, because it does work under Solaris.  */
        !           185: /* Define for support of TFmode long double and REAL_ARITHMETIC.
        !           186:    Sparc ABI says that long double is 4 words.  */
        !           187: #define LONG_DOUBLE_TYPE_SIZE 128
        !           188: #endif
        !           189: 
        !           190: /* Define for cross-compilation to a sparc target with no TFmode from a host
        !           191:    with a different float format (e.g. VAX).  */
        !           192: #define REAL_ARITHMETIC
        !           193: 
        !           194: /* Define this if most significant bit is lowest numbered
        !           195:    in instructions that operate on numbered bit-fields.  */
        !           196: #define BITS_BIG_ENDIAN 1
        !           197: 
        !           198: /* Define this if most significant byte of a word is the lowest numbered.  */
        !           199: /* This is true on the SPARC.  */
        !           200: #define BYTES_BIG_ENDIAN 1
        !           201: 
        !           202: /* Define this if most significant word of a multiword number is the lowest
        !           203:    numbered.  */
        !           204: /* Doubles are stored in memory with the high order word first.  This
        !           205:    matters when cross-compiling.  */
        !           206: #define WORDS_BIG_ENDIAN 1
        !           207: 
        !           208: /* number of bits in an addressable storage unit */
        !           209: #define BITS_PER_UNIT 8
        !           210: 
        !           211: /* Width in bits of a "word", which is the contents of a machine register.
        !           212:    Note that this is not necessarily the width of data type `int';
        !           213:    if using 16-bit ints on a 68000, this would still be 32.
        !           214:    But on a machine with 16-bit registers, this would be 16.  */
        !           215: #define BITS_PER_WORD 32
        !           216: #define MAX_BITS_PER_WORD 32
        !           217: 
        !           218: /* Width of a word, in units (bytes).  */
        !           219: #define UNITS_PER_WORD 4
        !           220: 
        !           221: /* Width in bits of a pointer.
        !           222:    See also the macro `Pmode' defined below.  */
        !           223: #define POINTER_SIZE 32
        !           224: 
        !           225: /* Allocation boundary (in *bits*) for storing arguments in argument list.  */
        !           226: #define PARM_BOUNDARY 32
        !           227: 
        !           228: /* Boundary (in *bits*) on which stack pointer should be aligned.  */
        !           229: #define STACK_BOUNDARY 64
        !           230: 
        !           231: /* ALIGN FRAMES on double word boundaries */
        !           232: 
        !           233: #define SPARC_STACK_ALIGN(LOC) (((LOC)+7) & 0xfffffff8)
        !           234: 
        !           235: /* Allocation boundary (in *bits*) for the code of a function.  */
        !           236: #define FUNCTION_BOUNDARY 32
        !           237: 
        !           238: /* Alignment of field after `int : 0' in a structure.  */
        !           239: #define EMPTY_FIELD_BOUNDARY 32
        !           240: 
        !           241: /* Every structure's size must be a multiple of this.  */
        !           242: #define STRUCTURE_SIZE_BOUNDARY 8
        !           243: 
        !           244: /* A bitfield declared as `int' forces `int' alignment for the struct.  */
        !           245: #define PCC_BITFIELD_TYPE_MATTERS 1
        !           246: 
        !           247: /* No data type wants to be aligned rounder than this.  */
        !           248: #define BIGGEST_ALIGNMENT 64
        !           249: 
        !           250: /* The best alignment to use in cases where we have a choice.  */
        !           251: #define FASTEST_ALIGNMENT 64
        !           252: 
        !           253: /* Make strings word-aligned so strcpy from constants will be faster.  */
        !           254: #define CONSTANT_ALIGNMENT(EXP, ALIGN)  \
        !           255:   ((TREE_CODE (EXP) == STRING_CST      \
        !           256:     && (ALIGN) < FASTEST_ALIGNMENT)    \
        !           257:    ? FASTEST_ALIGNMENT : (ALIGN))
        !           258: 
        !           259: /* Make arrays of chars word-aligned for the same reasons.  */
        !           260: #define DATA_ALIGNMENT(TYPE, ALIGN)            \
        !           261:   (TREE_CODE (TYPE) == ARRAY_TYPE              \
        !           262:    && TYPE_MODE (TREE_TYPE (TYPE)) == QImode   \
        !           263:    && (ALIGN) < FASTEST_ALIGNMENT ? FASTEST_ALIGNMENT : (ALIGN))
        !           264: 
        !           265: /* Set this nonzero if move instructions will actually fail to work
        !           266:    when given unaligned data.  */
        !           267: #define STRICT_ALIGNMENT 1
        !           268: 
        !           269: /* Things that must be doubleword aligned cannot go in the text section,
        !           270:    because the linker fails to align the text section enough!
        !           271:    Put them in the data section.  */
        !           272: #define MAX_TEXT_ALIGN 32
        !           273: 
        !           274: #define SELECT_SECTION(T,RELOC)                                                \
        !           275: {                                                                      \
        !           276:   if (TREE_CODE (T) == VAR_DECL)                                       \
        !           277:     {                                                                  \
        !           278:       if (TREE_READONLY (T) && ! TREE_SIDE_EFFECTS (T)                 \
        !           279:          && DECL_ALIGN (T) <= MAX_TEXT_ALIGN                           \
        !           280:          && ! (flag_pic && (RELOC)))                                   \
        !           281:        text_section ();                                                \
        !           282:       else                                                             \
        !           283:        data_section ();                                                \
        !           284:     }                                                                  \
        !           285:   else if (TREE_CODE (T) == CONSTRUCTOR)                               \
        !           286:     {                                                                  \
        !           287:       if (flag_pic != 0 && (RELOC) != 0)                               \
        !           288:        data_section ();                                                \
        !           289:     }                                                                  \
        !           290:   else if (*tree_code_type[(int) TREE_CODE (T)] == 'c')                        \
        !           291:     {                                                                  \
        !           292:       if ((TREE_CODE (T) == STRING_CST && flag_writable_strings)       \
        !           293:          || TYPE_ALIGN (TREE_TYPE (T)) > MAX_TEXT_ALIGN)               \
        !           294:        data_section ();                                                \
        !           295:       else                                                             \
        !           296:        text_section ();                                                \
        !           297:     }                                                                  \
        !           298: }
        !           299: 
        !           300: /* Use text section for a constant
        !           301:    unless we need more alignment than that offers.  */
        !           302: #define SELECT_RTX_SECTION(MODE, X)            \
        !           303: {                                              \
        !           304:   if (GET_MODE_BITSIZE (MODE) <= MAX_TEXT_ALIGN \
        !           305:       && ! (flag_pic && symbolic_operand (X)))  \
        !           306:     text_section ();                           \
        !           307:   else                                         \
        !           308:     data_section ();                           \
        !           309: }
        !           310: 
        !           311: /* Standard register usage.  */
        !           312: 
        !           313: /* Number of actual hardware registers.
        !           314:    The hardware registers are assigned numbers for the compiler
        !           315:    from 0 to just below FIRST_PSEUDO_REGISTER.
        !           316:    All registers that the compiler knows about must be given numbers,
        !           317:    even those that are not normally considered general registers.
        !           318: 
        !           319:    SPARC has 32 integer registers and 32 floating point registers.  */
        !           320: 
        !           321: #define FIRST_PSEUDO_REGISTER 64
        !           322: 
        !           323: /* 1 for registers that have pervasive standard uses
        !           324:    and are not available for the register allocator.
        !           325:    g0 is used for the condition code and not to represent %g0, which is
        !           326:    hardwired to 0, so reg 0 is *not* fixed.
        !           327:    g1 through g4 are free to use as temporaries.
        !           328:    g5 through g7 are reserved for the operating system.  */
        !           329: #define FIXED_REGISTERS  \
        !           330:  {0, 0, 0, 0, 0, 1, 1, 1,      \
        !           331:   0, 0, 0, 0, 0, 0, 1, 0,      \
        !           332:   0, 0, 0, 0, 0, 0, 0, 0,      \
        !           333:   0, 0, 0, 0, 0, 0, 1, 1,      \
        !           334:                                \
        !           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: 
        !           340: /* 1 for registers not available across function calls.
        !           341:    These must include the FIXED_REGISTERS and also any
        !           342:    registers that can be used without being saved.
        !           343:    The latter must include the registers where values are returned
        !           344:    and the register where structure-value addresses are passed.
        !           345:    Aside from that, you can include as many other registers as you like.  */
        !           346: #define CALL_USED_REGISTERS  \
        !           347:  {1, 1, 1, 1, 1, 1, 1, 1,      \
        !           348:   1, 1, 1, 1, 1, 1, 1, 1,      \
        !           349:   0, 0, 0, 0, 0, 0, 0, 0,      \
        !           350:   0, 0, 0, 0, 0, 0, 1, 1,      \
        !           351:                                \
        !           352:   1, 1, 1, 1, 1, 1, 1, 1,      \
        !           353:   1, 1, 1, 1, 1, 1, 1, 1,      \
        !           354:   1, 1, 1, 1, 1, 1, 1, 1,      \
        !           355:   1, 1, 1, 1, 1, 1, 1, 1}
        !           356: 
        !           357: /* If !TARGET_FPU, then make the fp registers fixed so that they won't
        !           358:    be allocated.  */
        !           359: 
        !           360: #define CONDITIONAL_REGISTER_USAGE                             \
        !           361: do                                                             \
        !           362:   {                                                            \
        !           363:     if (! TARGET_FPU)                                          \
        !           364:       {                                                                \
        !           365:        int regno;                                              \
        !           366:        for (regno = 32; regno < 64; regno++)                   \
        !           367:          fixed_regs[regno] = 1;                                \
        !           368:       }                                                                \
        !           369:   }                                                            \
        !           370: while (0)
        !           371: 
        !           372: /* Return number of consecutive hard regs needed starting at reg REGNO
        !           373:    to hold something of mode MODE.
        !           374:    This is ordinarily the length in words of a value of mode MODE
        !           375:    but can be less for certain modes in special long registers.
        !           376: 
        !           377:    On SPARC, ordinary registers hold 32 bits worth;
        !           378:    this means both integer and floating point registers.
        !           379: 
        !           380:    We use vectors to keep this information about registers.  */
        !           381: 
        !           382: /* How many hard registers it takes to make a register of this mode.  */
        !           383: extern int hard_regno_nregs[];
        !           384: 
        !           385: #define HARD_REGNO_NREGS(REGNO, MODE)   \
        !           386:   ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD)
        !           387: 
        !           388: /* Value is 1 if register/mode pair is acceptable on sparc.  */
        !           389: extern int hard_regno_mode_ok[FIRST_PSEUDO_REGISTER];
        !           390: 
        !           391: /* Value is 1 if hard register REGNO can hold a value of machine-mode MODE.
        !           392:    On SPARC, the cpu registers can hold any mode but the float registers
        !           393:    can only hold SFmode or DFmode.  See sparc.c for how we
        !           394:    initialize this.  */
        !           395: #define HARD_REGNO_MODE_OK(REGNO, MODE) \
        !           396:   ((hard_regno_mode_ok[REGNO] & (1<<(int)(MODE))) != 0)
        !           397: 
        !           398: /* Value is 1 if it is a good idea to tie two pseudo registers
        !           399:    when one has mode MODE1 and one has mode MODE2.
        !           400:    If HARD_REGNO_MODE_OK could produce different values for MODE1 and MODE2,
        !           401:    for any hard reg, then this must be 0 for correct output.  */
        !           402: #define MODES_TIEABLE_P(MODE1, MODE2) \
        !           403:   ((MODE1) == (MODE2) || GET_MODE_CLASS (MODE1) == GET_MODE_CLASS (MODE2))
        !           404: 
        !           405: /* Specify the registers used for certain standard purposes.
        !           406:    The values of these macros are register numbers.  */
        !           407: 
        !           408: /* SPARC pc isn't overloaded on a register that the compiler knows about.  */
        !           409: /* #define PC_REGNUM  */
        !           410: 
        !           411: /* Register to use for pushing function arguments.  */
        !           412: #define STACK_POINTER_REGNUM 14
        !           413: 
        !           414: /* Actual top-of-stack address is 92 greater than the contents
        !           415:    of the stack pointer register.  92 = 68 + 24.  64 bytes reserving space
        !           416:    for the ins and local registers, 4 byte for structure return address, and
        !           417:    24 bytes for the 6 register parameters.  */
        !           418: #define STACK_POINTER_OFFSET FIRST_PARM_OFFSET(0)
        !           419: 
        !           420: /* Base register for access to local variables of the function.  */
        !           421: #define FRAME_POINTER_REGNUM 30
        !           422: 
        !           423: #if 0
        !           424: /* Register that is used for the return address.  */
        !           425: #define RETURN_ADDR_REGNUM 15
        !           426: #endif
        !           427: 
        !           428: /* Value should be nonzero if functions must have frame pointers.
        !           429:    Zero means the frame pointer need not be set up (and parms
        !           430:    may be accessed via the stack pointer) in functions that seem suitable.
        !           431:    This is computed in `reload', in reload1.c.
        !           432: 
        !           433:    Used in flow.c, global.c, and reload1.c.  */
        !           434: extern int leaf_function;
        !           435: 
        !           436: #define FRAME_POINTER_REQUIRED \
        !           437:   (! (leaf_function_p () && only_leaf_regs_used ()))
        !           438: 
        !           439: /* C statement to store the difference between the frame pointer
        !           440:    and the stack pointer values immediately after the function prologue.
        !           441: 
        !           442:    Note, we always pretend that this is a leaf function because if
        !           443:    it's not, there's no point in trying to eliminate the
        !           444:    frame pointer.  If it is a leaf function, we guessed right!  */
        !           445: #define INITIAL_FRAME_POINTER_OFFSET(VAR) \
        !           446:   ((VAR) = (TARGET_FRW ? sparc_frw_compute_frame_size (get_frame_size ()) \
        !           447:            : compute_frame_size (get_frame_size (), 1)))
        !           448: 
        !           449: /* Base register for access to arguments of the function.  */
        !           450: #define ARG_POINTER_REGNUM 30
        !           451: 
        !           452: /* Register in which static-chain is passed to a function.  This must
        !           453:    not be a register used by the prologue.  */
        !           454: #define STATIC_CHAIN_REGNUM 2
        !           455: 
        !           456: /* Register which holds offset table for position-independent
        !           457:    data references.  */
        !           458: 
        !           459: #define PIC_OFFSET_TABLE_REGNUM 23
        !           460: 
        !           461: #define INITIALIZE_PIC initialize_pic ()
        !           462: #define FINALIZE_PIC finalize_pic ()
        !           463: 
        !           464: /* Sparc ABI says that quad-precision floats and all structures are returned
        !           465:    in memory.  */
        !           466: #define RETURN_IN_MEMORY(TYPE) \
        !           467:   (TYPE_MODE (TYPE) == BLKmode || TYPE_MODE (TYPE) == TFmode)
        !           468: 
        !           469: /* Functions which return large structures get the address
        !           470:    to place the wanted value at offset 64 from the frame.
        !           471:    Must reserve 64 bytes for the in and local registers.  */
        !           472: /* Used only in other #defines in this file.  */
        !           473: #define STRUCT_VALUE_OFFSET 64
        !           474: 
        !           475: #define STRUCT_VALUE \
        !           476:   gen_rtx (MEM, Pmode,                                 \
        !           477:           gen_rtx (PLUS, Pmode, stack_pointer_rtx,     \
        !           478:                    gen_rtx (CONST_INT, VOIDmode, STRUCT_VALUE_OFFSET)))
        !           479: #define STRUCT_VALUE_INCOMING \
        !           480:   gen_rtx (MEM, Pmode,                                 \
        !           481:           gen_rtx (PLUS, Pmode, frame_pointer_rtx,     \
        !           482:                    gen_rtx (CONST_INT, VOIDmode, STRUCT_VALUE_OFFSET)))
        !           483: 
        !           484: /* Define the classes of registers for register constraints in the
        !           485:    machine description.  Also define ranges of constants.
        !           486: 
        !           487:    One of the classes must always be named ALL_REGS and include all hard regs.
        !           488:    If there is more than one class, another class must be named NO_REGS
        !           489:    and contain no registers.
        !           490: 
        !           491:    The name GENERAL_REGS must be the name of a class (or an alias for
        !           492:    another name such as ALL_REGS).  This is the class of registers
        !           493:    that is allowed by "g" or "r" in a register constraint.
        !           494:    Also, registers outside this class are allocated only when
        !           495:    instructions express preferences for them.
        !           496: 
        !           497:    The classes must be numbered in nondecreasing order; that is,
        !           498:    a larger-numbered class must never be contained completely
        !           499:    in a smaller-numbered class.
        !           500: 
        !           501:    For any two classes, it is very desirable that there be another
        !           502:    class that represents their union.  */
        !           503: 
        !           504: /* The SPARC has two kinds of registers, general and floating point.  */
        !           505: 
        !           506: enum reg_class { NO_REGS, GENERAL_REGS, FP_REGS, ALL_REGS, LIM_REG_CLASSES };
        !           507: 
        !           508: #define N_REG_CLASSES (int) LIM_REG_CLASSES
        !           509: 
        !           510: /* Give names of register classes as strings for dump file.   */
        !           511: 
        !           512: #define REG_CLASS_NAMES \
        !           513:  {"NO_REGS", "GENERAL_REGS", "FP_REGS", "ALL_REGS" }
        !           514: 
        !           515: /* Define which registers fit in which classes.
        !           516:    This is an initializer for a vector of HARD_REG_SET
        !           517:    of length N_REG_CLASSES.  */
        !           518: 
        !           519: #if 0 && defined (__GNUC__)
        !           520: #define REG_CLASS_CONTENTS {0LL, 0xfffffffeLL, 0xffffffff00000000LL, 0xfffffffffffffffeLL}
        !           521: #else
        !           522: #define REG_CLASS_CONTENTS {{0, 0}, {-2, 0}, {0, -1}, {-2, -1}}
        !           523: #endif
        !           524: 
        !           525: /* The same information, inverted:
        !           526:    Return the class number of the smallest class containing
        !           527:    reg number REGNO.  This could be a conditional expression
        !           528:    or could index an array.  */
        !           529: 
        !           530: #define REGNO_REG_CLASS(REGNO) \
        !           531:   ((REGNO) >= 32 ? FP_REGS : (REGNO) == 0 ? NO_REGS : GENERAL_REGS)
        !           532: 
        !           533: /* This is the order in which to allocate registers
        !           534:    normally.  
        !           535:    
        !           536:    We put %f0/%f1 last among the float registers, so as to make it more
        !           537:    likely that a pseudo-register which dies in the float return register
        !           538:    will get allocated to the float return register, thus saving a move
        !           539:    instruction at the end of the function.  */
        !           540: #define REG_ALLOC_ORDER \
        !           541: { 8, 9, 10, 11, 12, 13, 2, 3,          \
        !           542:   15, 16, 17, 18, 19, 20, 21, 22,      \
        !           543:   23, 24, 25, 26, 27, 28, 29, 31,      \
        !           544:   34, 35, 36, 37, 38, 39,              \
        !           545:   40, 41, 42, 43, 44, 45, 46, 47,      \
        !           546:   48, 49, 50, 51, 52, 53, 54, 55,      \
        !           547:   56, 57, 58, 59, 60, 61, 62, 63,      \
        !           548:   32, 33,                              \
        !           549:   1, 4, 5, 6, 7, 0, 14, 30}
        !           550: 
        !           551: /* This is the order in which to allocate registers for
        !           552:    leaf functions.  If all registers can fit in the "i" registers,
        !           553:    then we have the possibility of having a leaf function.  */
        !           554: #define REG_LEAF_ALLOC_ORDER \
        !           555: { 2, 3, 24, 25, 26, 27, 28, 29,                \
        !           556:   15, 8, 9, 10, 11, 12, 13,            \
        !           557:   16, 17, 18, 19, 20, 21, 22, 23,      \
        !           558:   34, 35, 36, 37, 38, 39,              \
        !           559:   40, 41, 42, 43, 44, 45, 46, 47,      \
        !           560:   48, 49, 50, 51, 52, 53, 54, 55,      \
        !           561:   56, 57, 58, 59, 60, 61, 62, 63,      \
        !           562:   32, 33,                              \
        !           563:   1, 4, 5, 6, 7, 0, 14, 30, 31}
        !           564: 
        !           565: #define ORDER_REGS_FOR_LOCAL_ALLOC order_regs_for_local_alloc ()
        !           566: 
        !           567: #define LEAF_REGISTERS \
        !           568: { 1, 1, 1, 1, 1, 1, 1, 1,      \
        !           569:   0, 0, 0, 0, 0, 0, 1, 0,      \
        !           570:   0, 0, 0, 0, 0, 0, 0, 0,      \
        !           571:   1, 1, 1, 1, 1, 1, 0, 1,      \
        !           572:   1, 1, 1, 1, 1, 1, 1, 1,      \
        !           573:   1, 1, 1, 1, 1, 1, 1, 1,      \
        !           574:   1, 1, 1, 1, 1, 1, 1, 1,      \
        !           575:   1, 1, 1, 1, 1, 1, 1, 1}
        !           576: 
        !           577: extern char leaf_reg_remap[];
        !           578: #define LEAF_REG_REMAP(REGNO) (leaf_reg_remap[REGNO])
        !           579: extern char leaf_reg_backmap[];
        !           580: #define LEAF_REG_BACKMAP(REGNO) (leaf_reg_backmap[REGNO])
        !           581: 
        !           582: /* The class value for index registers, and the one for base regs.  */
        !           583: #define INDEX_REG_CLASS GENERAL_REGS
        !           584: #define BASE_REG_CLASS GENERAL_REGS
        !           585: 
        !           586: /* Get reg_class from a letter such as appears in the machine description.  */
        !           587: 
        !           588: #define REG_CLASS_FROM_LETTER(C) \
        !           589:   ((C) == 'f' ? FP_REGS : (C) == 'r' ? GENERAL_REGS : NO_REGS)
        !           590: 
        !           591: /* The letters I, J, K, L and M in a register constraint string
        !           592:    can be used to stand for particular ranges of immediate operands.
        !           593:    This macro defines what the ranges are.
        !           594:    C is the letter, and VALUE is a constant value.
        !           595:    Return 1 if VALUE is in the range specified by C.
        !           596: 
        !           597:    For SPARC, `I' is used for the range of constants an insn
        !           598:    can actually contain.
        !           599:    `J' is used for the range which is just zero (since that is R0).
        !           600:    `K' is used for constants which can be loaded with a single sethi insn.  */
        !           601: 
        !           602: #define SMALL_INT(X) ((unsigned) (INTVAL (X) + 0x1000) < 0x2000)
        !           603: 
        !           604: #define CONST_OK_FOR_LETTER_P(VALUE, C)  \
        !           605:   ((C) == 'I' ? (unsigned) ((VALUE) + 0x1000) < 0x2000 \
        !           606:    : (C) == 'J' ? (VALUE) == 0                         \
        !           607:    : (C) == 'K' ? ((VALUE) & 0x3ff) == 0               \
        !           608:    : 0)
        !           609: 
        !           610: /* Similar, but for floating constants, and defining letters G and H.
        !           611:    Here VALUE is the CONST_DOUBLE rtx itself.  */
        !           612: 
        !           613: #define CONST_DOUBLE_OK_FOR_LETTER_P(VALUE, C) \
        !           614:   ((C) == 'G' ? fp_zero_operand (VALUE)                        \
        !           615:    : (C) == 'H' ? arith_double_operand (VALUE, DImode) \
        !           616:    : 0)
        !           617: 
        !           618: /* Given an rtx X being reloaded into a reg required to be
        !           619:    in class CLASS, return the class of reg to actually use.
        !           620:    In general this is just CLASS; but on some machines
        !           621:    in some cases it is preferable to use a more restrictive class.  */
        !           622: /* We can't load constants into FP registers.  We can't load any FP constant
        !           623:    if an 'E' constraint fails to match it.  */
        !           624: #define PREFERRED_RELOAD_CLASS(X,CLASS)                        \
        !           625:   (CONSTANT_P (X)                                      \
        !           626:    && ((CLASS) == FP_REGS                              \
        !           627:        || (GET_MODE_CLASS (GET_MODE (X)) == MODE_FLOAT \
        !           628:           && (HOST_FLOAT_FORMAT != IEEE_FLOAT_FORMAT   \
        !           629:               || HOST_BITS_PER_INT != BITS_PER_WORD))) \
        !           630:    ? NO_REGS : (CLASS))
        !           631: 
        !           632: /* Return the register class of a scratch register needed to load IN into
        !           633:    a register of class CLASS in MODE.
        !           634: 
        !           635:    On the SPARC, when PIC, we need a temporary when loading some addresses
        !           636:    into a register.
        !           637: 
        !           638:    Also, we need a temporary when loading/storing a HImode/QImode value
        !           639:    between memory and the FPU registers.  This can happen when combine puts
        !           640:    a paradoxical subreg in a float/fix conversion insn.  */
        !           641: 
        !           642: #define SECONDARY_INPUT_RELOAD_CLASS(CLASS, MODE, IN)          \
        !           643:   (((CLASS) == FP_REGS && ((MODE) == HImode || (MODE) == QImode)\
        !           644:       && (GET_CODE (IN) == MEM                                 \
        !           645:          || ((GET_CODE (IN) == REG || GET_CODE (IN) == SUBREG) \
        !           646:              && true_regnum (IN) == -1))) ? GENERAL_REGS : NO_REGS)
        !           647: 
        !           648: #define SECONDARY_OUTPUT_RELOAD_CLASS(CLASS, MODE, IN)         \
        !           649:   ((CLASS) == FP_REGS && ((MODE) == HImode || (MODE) == QImode)        \
        !           650:    && (GET_CODE (IN) == MEM                                    \
        !           651:        || ((GET_CODE (IN) == REG || GET_CODE (IN) == SUBREG)   \
        !           652:           && true_regnum (IN) == -1)) ? GENERAL_REGS : NO_REGS)
        !           653: 
        !           654: /* On SPARC it is not possible to directly move data between 
        !           655:    GENERAL_REGS and FP_REGS.  */
        !           656: #define SECONDARY_MEMORY_NEEDED(CLASS1, CLASS2, MODE)  \
        !           657:   (((CLASS1) == FP_REGS && (CLASS2) == GENERAL_REGS)   \
        !           658:    || ((CLASS1) == GENERAL_REGS && (CLASS2) == FP_REGS))
        !           659: 
        !           660: /* Return the stack location to use for secondary memory needed reloads.  */
        !           661: #define SECONDARY_MEMORY_NEEDED_RTX(MODE) \
        !           662:   gen_rtx (MEM, MODE, gen_rtx (PLUS, Pmode, frame_pointer_rtx, \
        !           663:           GEN_INT (STARTING_FRAME_OFFSET)))
        !           664: 
        !           665: /* Return the maximum number of consecutive registers
        !           666:    needed to represent mode MODE in a register of class CLASS.  */
        !           667: /* On SPARC, this is the size of MODE in words.  */
        !           668: #define CLASS_MAX_NREGS(CLASS, MODE)   \
        !           669:   ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD)
        !           670: 
        !           671: /* Stack layout; function entry, exit and calling.  */
        !           672: 
        !           673: /* Define the number of register that can hold parameters.
        !           674:    These two macros are used only in other macro definitions below.  */
        !           675: #define NPARM_REGS 6
        !           676: 
        !           677: /* Define this if pushing a word on the stack
        !           678:    makes the stack pointer a smaller address.  */
        !           679: #define STACK_GROWS_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: /* This is 16 to allow space for one TFmode floating point value.  */
        !           692: #define STARTING_FRAME_OFFSET (-16)
        !           693: 
        !           694: /* If we generate an insn to push BYTES bytes,
        !           695:    this says how many the stack pointer really advances by.
        !           696:    On SPARC, don't define this because there are no push insns.  */
        !           697: /*  #define PUSH_ROUNDING(BYTES) */
        !           698: 
        !           699: /* Offset of first parameter from the argument pointer register value.
        !           700:    This is 64 for the ins and locals, plus 4 for the struct-return reg
        !           701:    even if this function isn't going to use it.  */
        !           702: #define FIRST_PARM_OFFSET(FNDECL) (STRUCT_VALUE_OFFSET + UNITS_PER_WORD)
        !           703: 
        !           704: /* When a parameter is passed in a register, stack space is still
        !           705:    allocated for it.  */
        !           706: #define REG_PARM_STACK_SPACE(DECL) (NPARM_REGS * UNITS_PER_WORD)
        !           707: 
        !           708: /* Keep the stack pointer constant throughout the function.
        !           709:    This is both an optimization and a necessity: longjmp
        !           710:    doesn't behave itself when the stack pointer moves within
        !           711:    the function!  */
        !           712: #define ACCUMULATE_OUTGOING_ARGS
        !           713: 
        !           714: /* Value is the number of bytes of arguments automatically
        !           715:    popped when returning from a subroutine call.
        !           716:    FUNTYPE is the data type of the function (as a tree),
        !           717:    or for a library call it is an identifier node for the subroutine name.
        !           718:    SIZE is the number of bytes of arguments passed on the stack.  */
        !           719: 
        !           720: #define RETURN_POPS_ARGS(FUNTYPE,SIZE) 0
        !           721: 
        !           722: /* Some subroutine macros specific to this machine.
        !           723:    When !TARGET_FPU, put float return values in the general registers,
        !           724:    since we don't have any fp registers.  */
        !           725: #define BASE_RETURN_VALUE_REG(MODE) \
        !           726:  (((MODE) == SFmode || (MODE) == DFmode) && TARGET_FPU ? 32 : 8)
        !           727: #define BASE_OUTGOING_VALUE_REG(MODE) \
        !           728:  (((MODE) == SFmode || (MODE) == DFmode) && TARGET_FPU ? 32    \
        !           729:   : (TARGET_FRW ? 8 : 24))
        !           730: #define BASE_PASSING_ARG_REG(MODE) (8)
        !           731: #define BASE_INCOMING_ARG_REG(MODE) (TARGET_FRW ? 8 : 24)
        !           732: 
        !           733: /* Define this macro if the target machine has "register windows".  This
        !           734:    C expression returns the register number as seen by the called function
        !           735:    corresponding to register number OUT as seen by the calling function.
        !           736:    Return OUT if register number OUT is not an outbound register.  */
        !           737: 
        !           738: #define INCOMING_REGNO(OUT) \
        !           739:  ((TARGET_FRW || (OUT) < 8 || (OUT) > 15) ? (OUT) : (OUT) + 16)
        !           740: 
        !           741: /* Define this macro if the target machine has "register windows".  This
        !           742:    C expression returns the register number as seen by the calling function
        !           743:    corresponding to register number IN as seen by the called function.
        !           744:    Return IN if register number IN is not an inbound register.  */
        !           745: 
        !           746: #define OUTGOING_REGNO(IN) \
        !           747:  ((TARGET_FRW || (IN) < 24 || (IN) > 31) ? (IN) : (IN) - 16)
        !           748: 
        !           749: /* Define how to find the value returned by a function.
        !           750:    VALTYPE is the data type of the value (as a tree).
        !           751:    If the precise function being called is known, FUNC is its FUNCTION_DECL;
        !           752:    otherwise, FUNC is 0.  */
        !           753: 
        !           754: /* On SPARC the value is found in the first "output" register.  */
        !           755: 
        !           756: #define FUNCTION_VALUE(VALTYPE, FUNC)  \
        !           757:   gen_rtx (REG, TYPE_MODE (VALTYPE), BASE_RETURN_VALUE_REG (TYPE_MODE (VALTYPE)))
        !           758: 
        !           759: /* But the called function leaves it in the first "input" register.  */
        !           760: 
        !           761: #define FUNCTION_OUTGOING_VALUE(VALTYPE, FUNC)  \
        !           762:   gen_rtx (REG, TYPE_MODE (VALTYPE), BASE_OUTGOING_VALUE_REG (TYPE_MODE (VALTYPE)))
        !           763: 
        !           764: /* Define how to find the value returned by a library function
        !           765:    assuming the value has mode MODE.  */
        !           766: 
        !           767: #define LIBCALL_VALUE(MODE)    \
        !           768:   gen_rtx (REG, MODE, BASE_RETURN_VALUE_REG (MODE))
        !           769: 
        !           770: /* 1 if N is a possible register number for a function value
        !           771:    as seen by the caller.
        !           772:    On SPARC, the first "output" reg is used for integer values,
        !           773:    and the first floating point register is used for floating point values.  */
        !           774: 
        !           775: #define FUNCTION_VALUE_REGNO_P(N) ((N) == 8 || (N) == 32)
        !           776: 
        !           777: /* Define the size of space to allocate for the return value of an
        !           778:    untyped_call.  */
        !           779: 
        !           780: #define APPLY_RESULT_SIZE 16
        !           781: 
        !           782: /* 1 if N is a possible register number for function argument passing.
        !           783:    On SPARC, these are the "output" registers.  */
        !           784: 
        !           785: #define FUNCTION_ARG_REGNO_P(N) ((N) < 14 && (N) > 7)
        !           786: 
        !           787: /* Define a data type for recording info about an argument list
        !           788:    during the scan of that argument list.  This data type should
        !           789:    hold all necessary information about the function itself
        !           790:    and about the args processed so far, enough to enable macros
        !           791:    such as FUNCTION_ARG to determine where the next arg should go.
        !           792: 
        !           793:    On SPARC, this is a single integer, which is a number of words
        !           794:    of arguments scanned so far (including the invisible argument,
        !           795:    if any, which holds the structure-value-address).
        !           796:    Thus 7 or more means all following args should go on the stack.  */
        !           797: 
        !           798: #define CUMULATIVE_ARGS int
        !           799: 
        !           800: #define ROUND_ADVANCE(SIZE)    \
        !           801:   ((SIZE + UNITS_PER_WORD - 1) / UNITS_PER_WORD)
        !           802: 
        !           803: /* Initialize a variable CUM of type CUMULATIVE_ARGS
        !           804:    for a call to a function whose data type is FNTYPE.
        !           805:    For a library call, FNTYPE is 0.
        !           806: 
        !           807:    On SPARC, the offset always starts at 0: the first parm reg is always
        !           808:    the same reg.  */
        !           809: 
        !           810: #define INIT_CUMULATIVE_ARGS(CUM,FNTYPE,LIBNAME) ((CUM) = 0)
        !           811: 
        !           812: /* Update the data in CUM to advance over an argument
        !           813:    of mode MODE and data type TYPE.
        !           814:    (TYPE is null for libcalls where that information may not be available.)  */
        !           815: 
        !           816: #define FUNCTION_ARG_ADVANCE(CUM, MODE, TYPE, NAMED)   \
        !           817:   ((CUM) += ((MODE) != BLKmode                         \
        !           818:             ? ROUND_ADVANCE (GET_MODE_SIZE (MODE))     \
        !           819:             : ROUND_ADVANCE (int_size_in_bytes (TYPE))))
        !           820: 
        !           821: /* Determine where to put an argument to a function.
        !           822:    Value is zero to push the argument on the stack,
        !           823:    or a hard register in which to store the argument.
        !           824: 
        !           825:    MODE is the argument's machine mode.
        !           826:    TYPE is the data type of the argument (as a tree).
        !           827:     This is null for libcalls where that information may
        !           828:     not be available.
        !           829:    CUM is a variable of type CUMULATIVE_ARGS which gives info about
        !           830:     the preceding args and about the function being called.
        !           831:    NAMED is nonzero if this argument is a named parameter
        !           832:     (otherwise it is an extra parameter matching an ellipsis).  */
        !           833: 
        !           834: /* On SPARC the first six args are normally in registers
        !           835:    and the rest are pushed.  Any arg that starts within the first 6 words
        !           836:    is at least partially passed in a register unless its data type forbids.  */
        !           837: 
        !           838: #define FUNCTION_ARG(CUM, MODE, TYPE, NAMED)                           \
        !           839: ((CUM) < NPARM_REGS                                                    \
        !           840:  && ((TYPE)==0 || ! TREE_ADDRESSABLE ((tree)(TYPE)))                   \
        !           841:  && ((TYPE)==0 || (MODE) != BLKmode                                    \
        !           842:      || (TYPE_ALIGN ((TYPE)) % PARM_BOUNDARY == 0))                    \
        !           843:  ? gen_rtx (REG, (MODE), (BASE_PASSING_ARG_REG (MODE) + (CUM)))                \
        !           844:  : 0)
        !           845: 
        !           846: /* Define where a function finds its arguments.
        !           847:    This is different from FUNCTION_ARG because of register windows.  */
        !           848: 
        !           849: #define FUNCTION_INCOMING_ARG(CUM, MODE, TYPE, NAMED)                  \
        !           850: ((CUM) < NPARM_REGS                                                    \
        !           851:  && ((TYPE)==0 || ! TREE_ADDRESSABLE ((tree)(TYPE)))                   \
        !           852:  && ((TYPE)==0 || (MODE) != BLKmode                                    \
        !           853:      || (TYPE_ALIGN ((TYPE)) % PARM_BOUNDARY == 0))                    \
        !           854:  ? gen_rtx (REG, (MODE), (BASE_INCOMING_ARG_REG (MODE) + (CUM)))       \
        !           855:  : 0)
        !           856: 
        !           857: /* For an arg passed partly in registers and partly in memory,
        !           858:    this is the number of registers used.
        !           859:    For args passed entirely in registers or entirely in memory, zero.
        !           860:    Any arg that starts in the first 6 regs but won't entirely fit in them
        !           861:    needs partial registers on the Sparc.  */
        !           862: 
        !           863: #define FUNCTION_ARG_PARTIAL_NREGS(CUM, MODE, TYPE, NAMED)             \
        !           864:   ((CUM) < NPARM_REGS                                                  \
        !           865:     && ((TYPE)==0 || ! TREE_ADDRESSABLE ((tree)(TYPE)))                        \
        !           866:     && ((TYPE)==0 || (MODE) != BLKmode                                 \
        !           867:        || (TYPE_ALIGN ((TYPE)) % PARM_BOUNDARY == 0))                  \
        !           868:     && ((CUM) + ((MODE) == BLKmode                                     \
        !           869:                 ? ROUND_ADVANCE (int_size_in_bytes (TYPE))             \
        !           870:                 : ROUND_ADVANCE (GET_MODE_SIZE (MODE))) - NPARM_REGS > 0)\
        !           871:    ? (NPARM_REGS - (CUM))                                              \
        !           872:    : 0)
        !           873: 
        !           874: /* The SPARC ABI stipulates passing struct arguments (of any size) and
        !           875:    quad-precision floats by invisible reference.  */
        !           876: #define FUNCTION_ARG_PASS_BY_REFERENCE(CUM, MODE, TYPE, NAMED)         \
        !           877:   ((TYPE && (TREE_CODE (TYPE) == RECORD_TYPE                           \
        !           878:            || TREE_CODE (TYPE) == UNION_TYPE))                         \
        !           879:    || (MODE == TFmode))
        !           880: 
        !           881: /* Define the information needed to generate branch and scc insns.  This is
        !           882:    stored from the compare operation.  Note that we can't use "rtx" here
        !           883:    since it hasn't been defined!  */
        !           884: 
        !           885: extern struct rtx_def *sparc_compare_op0, *sparc_compare_op1;
        !           886: 
        !           887: /* Define the function that build the compare insn for scc and bcc.  */
        !           888: 
        !           889: extern struct rtx_def *gen_compare_reg ();
        !           890: 
        !           891: /* Generate the special assembly code needed to tell the assembler whatever
        !           892:    it might need to know about the return value of a function.
        !           893: 
        !           894:    For Sparc assemblers, we need to output a .proc pseudo-op which conveys
        !           895:    information to the assembler relating to peephole optimization (done in
        !           896:    the assembler).  */
        !           897: 
        !           898: #define ASM_DECLARE_RESULT(FILE, RESULT) \
        !           899:   fprintf ((FILE), "\t.proc\t0%o\n", sparc_type_code (TREE_TYPE (RESULT)))
        !           900: 
        !           901: /* Output the label for a function definition.  */
        !           902: 
        !           903: #define ASM_DECLARE_FUNCTION_NAME(FILE, NAME, DECL)                    \
        !           904: do {                                                                   \
        !           905:   ASM_DECLARE_RESULT (FILE, DECL_RESULT (DECL));                       \
        !           906:   ASM_OUTPUT_LABEL (FILE, NAME);                                       \
        !           907: } while (0)
        !           908: 
        !           909: /* This macro generates the assembly code for function entry.
        !           910:    FILE is a stdio stream to output the code to.
        !           911:    SIZE is an int: how many units of temporary storage to allocate.
        !           912:    Refer to the array `regs_ever_live' to determine which registers
        !           913:    to save; `regs_ever_live[I]' is nonzero if register number I
        !           914:    is ever used in the function.  This macro is responsible for
        !           915:    knowing which registers should not be saved even if used.  */
        !           916: 
        !           917: /* On SPARC, move-double insns between fpu and cpu need an 8-byte block
        !           918:    of memory.  If any fpu reg is used in the function, we allocate
        !           919:    such a block here, at the bottom of the frame, just in case it's needed.
        !           920: 
        !           921:    If this function is a leaf procedure, then we may choose not
        !           922:    to do a "save" insn.  The decision about whether or not
        !           923:    to do this is made in regclass.c.  */
        !           924: 
        !           925: #define FUNCTION_PROLOGUE(FILE, SIZE)                          \
        !           926:   (TARGET_FRW ? sparc_frw_output_function_prologue (FILE, SIZE, leaf_function)\
        !           927:    : output_function_prologue (FILE, SIZE, leaf_function))
        !           928: 
        !           929: /* Output assembler code to FILE to increment profiler label # LABELNO
        !           930:    for profiling a function entry.  */
        !           931: 
        !           932: #define FUNCTION_PROFILER(FILE, LABELNO)                       \
        !           933:   do {                                                         \
        !           934:     fputs ("\tsethi %hi(", (FILE));                            \
        !           935:     ASM_OUTPUT_INTERNAL_LABELREF (FILE, "LP", LABELNO);                \
        !           936:     fputs ("),%o0\n\tcall mcount\n\tor %lo(", (FILE));         \
        !           937:     ASM_OUTPUT_INTERNAL_LABELREF (FILE, "LP", LABELNO);                \
        !           938:     fputs ("),%o0,%o0\n", (FILE));                             \
        !           939:   } while (0)
        !           940: 
        !           941: /* Output assembler code to FILE to initialize this source file's
        !           942:    basic block profiling info, if that has not already been done.  */
        !           943: /* FIXME -- this does not parameterize how it generates labels (like the
        !           944:    above FUNCTION_PROFILER).  Broken on Solaris-2.   [email protected] */
        !           945: 
        !           946: #define FUNCTION_BLOCK_PROFILER(FILE, LABELNO)  \
        !           947:   fprintf (FILE, "\tsethi %%hi(LPBX0),%%o0\n\tld [%%lo(LPBX0)+%%o0],%%o1\n\ttst %%o1\n\tbne LPY%d\n\tadd %%o0,%%lo(LPBX0),%%o0\n\tcall ___bb_init_func\n\tnop\nLPY%d:\n",  \
        !           948:           (LABELNO), (LABELNO))
        !           949: 
        !           950: /* Output assembler code to FILE to increment the entry-count for
        !           951:    the BLOCKNO'th basic block in this source file.  */
        !           952: 
        !           953: #define BLOCK_PROFILER(FILE, BLOCKNO) \
        !           954: {                                                              \
        !           955:   int blockn = (BLOCKNO);                                      \
        !           956:   fprintf (FILE, "\tsethi %%hi(LPBX2+%d),%%g1\n\tld [%%lo(LPBX2+%d)+%%g1],%%g2\n\
        !           957: \tadd %%g2,1,%%g2\n\tst %%g2,[%%lo(LPBX2+%d)+%%g1]\n",         \
        !           958:           4 * blockn, 4 * blockn, 4 * blockn);                 \
        !           959: }
        !           960: 
        !           961: /* EXIT_IGNORE_STACK should be nonzero if, when returning from a function,
        !           962:    the stack pointer does not matter.  The value is tested only in
        !           963:    functions that have frame pointers.
        !           964:    No definition is equivalent to always zero.  */
        !           965: 
        !           966: extern int current_function_calls_alloca;
        !           967: extern int current_function_outgoing_args_size;
        !           968: 
        !           969: #define EXIT_IGNORE_STACK      \
        !           970:  (get_frame_size () != 0       \
        !           971:   || current_function_calls_alloca || current_function_outgoing_args_size)
        !           972: 
        !           973: /* This macro generates the assembly code for function exit,
        !           974:    on machines that need it.  If FUNCTION_EPILOGUE is not defined
        !           975:    then individual return instructions are generated for each
        !           976:    return statement.  Args are same as for FUNCTION_PROLOGUE.
        !           977: 
        !           978:    The function epilogue should not depend on the current stack pointer!
        !           979:    It should use the frame pointer only.  This is mandatory because
        !           980:    of alloca; we also take advantage of it to omit stack adjustments
        !           981:    before returning.  */
        !           982: 
        !           983: /* This declaration is needed due to traditional/ANSI
        !           984:    incompatibilities which cannot be #ifdefed away
        !           985:    because they occur inside of macros.  Sigh.  */
        !           986: extern union tree_node *current_function_decl;
        !           987: 
        !           988: #define FUNCTION_EPILOGUE(FILE, SIZE)                          \
        !           989:   (TARGET_FRW ? sparc_frw_output_function_epilogue (FILE, SIZE, leaf_function)\
        !           990:    : output_function_epilogue (FILE, SIZE, leaf_function))
        !           991: 
        !           992: #define DELAY_SLOTS_FOR_EPILOGUE       \
        !           993:   (TARGET_FRW ? sparc_frw_epilogue_delay_slots () : 1)
        !           994: #define ELIGIBLE_FOR_EPILOGUE_DELAY(trial, slots_filled)       \
        !           995:   (TARGET_FRW ? sparc_frw_eligible_for_epilogue_delay (trial, slots_filled) \
        !           996:    : eligible_for_epilogue_delay (trial, slots_filled))
        !           997: 
        !           998: /* Output assembler code for a block containing the constant parts
        !           999:    of a trampoline, leaving space for the variable parts.  */
        !          1000: 
        !          1001: /* On the sparc, the trampoline contains five instructions:
        !          1002:      sethi #TOP_OF_FUNCTION,%g1
        !          1003:      or #BOTTOM_OF_FUNCTION,%g1,%g1
        !          1004:      sethi #TOP_OF_STATIC,%g2
        !          1005:      jmp g1
        !          1006:      or #BOTTOM_OF_STATIC,%g2,%g2  */
        !          1007: #define TRAMPOLINE_TEMPLATE(FILE)                                      \
        !          1008: {                                                                      \
        !          1009:   ASM_OUTPUT_INT (FILE, gen_rtx (CONST_INT, VOIDmode, 0x00000000));    \
        !          1010:   ASM_OUTPUT_INT (FILE, gen_rtx (CONST_INT, VOIDmode, 0x00000000));    \
        !          1011:   ASM_OUTPUT_INT (FILE, gen_rtx (CONST_INT, VOIDmode, 0x00000000));    \
        !          1012:   ASM_OUTPUT_INT (FILE, gen_rtx (CONST_INT, VOIDmode, 0x81C04000));    \
        !          1013:   ASM_OUTPUT_INT (FILE, gen_rtx (CONST_INT, VOIDmode, 0x00000000));    \
        !          1014: }
        !          1015: 
        !          1016: /* Length in units of the trampoline for entering a nested function.  */
        !          1017: 
        !          1018: #define TRAMPOLINE_SIZE 20
        !          1019: 
        !          1020: /* Emit RTL insns to initialize the variable parts of a trampoline.
        !          1021:    FNADDR is an RTX for the address of the function's pure code.
        !          1022:    CXT is an RTX for the static chain value for the function.
        !          1023: 
        !          1024:    This takes 16 insns: 2 shifts & 2 ands (to split up addresses), 4 sethi
        !          1025:    (to load in opcodes), 4 iors (to merge address and opcodes), and 4 writes
        !          1026:    (to store insns).  This is a bit excessive.  Perhaps a different
        !          1027:    mechanism would be better here.
        !          1028: 
        !          1029:    Emit 3 FLUSH instructions (UNSPEC_VOLATILE 2) to synchonize the data
        !          1030:    and instruction caches.  */
        !          1031: 
        !          1032: #define INITIALIZE_TRAMPOLINE(TRAMP, FNADDR, CXT)                      \
        !          1033: {                                                                      \
        !          1034:   rtx high_cxt = expand_shift (RSHIFT_EXPR, SImode, CXT,               \
        !          1035:                              size_int (10), 0, 1);                     \
        !          1036:   rtx high_fn = expand_shift (RSHIFT_EXPR, SImode, FNADDR,             \
        !          1037:                             size_int (10), 0, 1);                      \
        !          1038:   rtx low_cxt = expand_and (CXT, gen_rtx (CONST_INT, VOIDmode, 0x3ff), 0); \
        !          1039:   rtx low_fn = expand_and (FNADDR, gen_rtx (CONST_INT, VOIDmode, 0x3ff), 0); \
        !          1040:   rtx g1_sethi = gen_rtx (HIGH, SImode,                                        \
        !          1041:                          gen_rtx (CONST_INT, VOIDmode, 0x03000000));   \
        !          1042:   rtx g2_sethi = gen_rtx (HIGH, SImode,                                        \
        !          1043:                          gen_rtx (CONST_INT, VOIDmode, 0x05000000));   \
        !          1044:   rtx g1_ori = gen_rtx (HIGH, SImode,                                  \
        !          1045:                        gen_rtx (CONST_INT, VOIDmode, 0x82106000));     \
        !          1046:   rtx g2_ori = gen_rtx (HIGH, SImode,                                  \
        !          1047:                        gen_rtx (CONST_INT, VOIDmode, 0x8410A000));     \
        !          1048:   rtx tem = gen_reg_rtx (SImode);                                      \
        !          1049:   emit_move_insn (tem, g1_sethi);                                      \
        !          1050:   emit_insn (gen_iorsi3 (high_fn, high_fn, tem));                      \
        !          1051:   emit_move_insn (gen_rtx (MEM, SImode, plus_constant (TRAMP, 0)), high_fn);\
        !          1052:   emit_move_insn (tem, g1_ori);                                                \
        !          1053:   emit_insn (gen_iorsi3 (low_fn, low_fn, tem));                                \
        !          1054:   emit_move_insn (gen_rtx (MEM, SImode, plus_constant (TRAMP, 4)), low_fn);\
        !          1055:   emit_move_insn (tem, g2_sethi);                                      \
        !          1056:   emit_insn (gen_iorsi3 (high_cxt, high_cxt, tem));                    \
        !          1057:   emit_move_insn (gen_rtx (MEM, SImode, plus_constant (TRAMP, 8)), high_cxt);\
        !          1058:   emit_move_insn (tem, g2_ori);                                                \
        !          1059:   emit_insn (gen_iorsi3 (low_cxt, low_cxt, tem));                      \
        !          1060:   emit_move_insn (gen_rtx (MEM, SImode, plus_constant (TRAMP, 16)), low_cxt);\
        !          1061:   emit_insn (gen_rtx (UNSPEC_VOLATILE, VOIDmode,                       \
        !          1062:                      gen_rtvec (1, plus_constant (TRAMP, 0)),          \
        !          1063:                      2));                                              \
        !          1064:   emit_insn (gen_rtx (UNSPEC_VOLATILE, VOIDmode,                       \
        !          1065:                      gen_rtvec (1, plus_constant (TRAMP, 8)),          \
        !          1066:                      2));                                              \
        !          1067:   emit_insn (gen_rtx (UNSPEC_VOLATILE, VOIDmode,                       \
        !          1068:                      gen_rtvec (1, plus_constant (TRAMP, 16)),         \
        !          1069:                      2));                                              \
        !          1070: }
        !          1071: 
        !          1072: /* Generate necessary RTL for __builtin_saveregs().
        !          1073:    ARGLIST is the argument list; see expr.c.  */
        !          1074: extern struct rtx_def *sparc_builtin_saveregs ();
        !          1075: #define EXPAND_BUILTIN_SAVEREGS(ARGLIST) sparc_builtin_saveregs (ARGLIST)
        !          1076: 
        !          1077: /* Generate RTL to flush the register windows so as to make arbitrary frames
        !          1078:    available.  */
        !          1079: #define SETUP_FRAME_ADDRESSES()                \
        !          1080:   emit_insn (gen_flush_register_windows ())
        !          1081: 
        !          1082: /* Given an rtx for the address of a frame,
        !          1083:    return an rtx for the address of the word in the frame
        !          1084:    that holds the dynamic chain--the previous frame's address.  */
        !          1085: #define DYNAMIC_CHAIN_ADDRESS(frame) \
        !          1086:   gen_rtx (PLUS, Pmode, frame, gen_rtx (CONST_INT, VOIDmode, 56))
        !          1087: 
        !          1088: /* The return address isn't on the stack, it is in a register, so we can't
        !          1089:    access it from the current frame pointer.  We can access it from the
        !          1090:    previous frame pointer though by reading a value from the register window
        !          1091:    save area.  */
        !          1092: #define RETURN_ADDR_IN_PREVIOUS_FRAME
        !          1093: 
        !          1094: /* The current return address is in %i7.  The return address of anything
        !          1095:    farther back is in the register window save area at [%fp+60].  */
        !          1096: /* ??? This ignores the fact that the actual return address is +8 for normal
        !          1097:    returns, and +12 for structure returns.  */
        !          1098: #define RETURN_ADDR_RTX(count, frame)          \
        !          1099:   ((count == -1)                               \
        !          1100:    ? gen_rtx (REG, Pmode, 31)                  \
        !          1101:    : copy_to_reg (gen_rtx (MEM, Pmode,         \
        !          1102:                           memory_address (Pmode, plus_constant (frame, 60)))))
        !          1103: 
        !          1104: /* Addressing modes, and classification of registers for them.  */
        !          1105: 
        !          1106: /* #define HAVE_POST_INCREMENT */
        !          1107: /* #define HAVE_POST_DECREMENT */
        !          1108: 
        !          1109: /* #define HAVE_PRE_DECREMENT */
        !          1110: /* #define HAVE_PRE_INCREMENT */
        !          1111: 
        !          1112: /* Macros to check register numbers against specific register classes.  */
        !          1113: 
        !          1114: /* These assume that REGNO is a hard or pseudo reg number.
        !          1115:    They give nonzero only if REGNO is a hard reg of the suitable class
        !          1116:    or a pseudo reg currently allocated to a suitable hard reg.
        !          1117:    Since they use reg_renumber, they are safe only once reg_renumber
        !          1118:    has been allocated, which happens in local-alloc.c.  */
        !          1119: 
        !          1120: #define REGNO_OK_FOR_INDEX_P(REGNO) \
        !          1121: (((REGNO) < 32 || (unsigned) reg_renumber[REGNO] < 32) && (REGNO) != 0)
        !          1122: #define REGNO_OK_FOR_BASE_P(REGNO) \
        !          1123: (((REGNO) < 32 || (unsigned) reg_renumber[REGNO] < 32) && (REGNO) != 0)
        !          1124: #define REGNO_OK_FOR_FP_P(REGNO) \
        !          1125: (((REGNO) ^ 0x20) < 32 \
        !          1126:  || (((REGNO) != 0) && (unsigned) (reg_renumber[REGNO] ^ 0x20) < 32))
        !          1127: 
        !          1128: /* Now macros that check whether X is a register and also,
        !          1129:    strictly, whether it is in a specified class.
        !          1130: 
        !          1131:    These macros are specific to the SPARC, and may be used only
        !          1132:    in code for printing assembler insns and in conditions for
        !          1133:    define_optimization.  */
        !          1134: 
        !          1135: /* 1 if X is an fp register.  */
        !          1136: 
        !          1137: #define FP_REG_P(X) (REG_P (X) && REGNO_OK_FOR_FP_P (REGNO (X)))
        !          1138: 
        !          1139: /* Maximum number of registers that can appear in a valid memory address.  */
        !          1140: 
        !          1141: #define MAX_REGS_PER_ADDRESS 2
        !          1142: 
        !          1143: /* Recognize any constant value that is a valid address.
        !          1144:    When PIC, we do not accept an address that would require a scratch reg
        !          1145:    to load into a register.  */
        !          1146: 
        !          1147: #define CONSTANT_ADDRESS_P(X)   \
        !          1148:   (GET_CODE (X) == LABEL_REF || GET_CODE (X) == SYMBOL_REF             \
        !          1149:    || GET_CODE (X) == CONST_INT || GET_CODE (X) == HIGH                        \
        !          1150:    || (GET_CODE (X) == CONST                                           \
        !          1151:        && ! (flag_pic && pic_address_needs_scratch (X))))
        !          1152: 
        !          1153: /* Define this, so that when PIC, reload won't try to reload invalid
        !          1154:    addresses which require two reload registers.  */
        !          1155: 
        !          1156: #define LEGITIMATE_PIC_OPERAND_P(X)  (! pic_address_needs_scratch (X))
        !          1157: 
        !          1158: /* Nonzero if the constant value X is a legitimate general operand.
        !          1159:    Anything can be made to work except floating point constants.  */
        !          1160: 
        !          1161: #define LEGITIMATE_CONSTANT_P(X) \
        !          1162:   (GET_CODE (X) != CONST_DOUBLE || GET_MODE (X) == VOIDmode)
        !          1163: 
        !          1164: /* The macros REG_OK_FOR..._P assume that the arg is a REG rtx
        !          1165:    and check its validity for a certain class.
        !          1166:    We have two alternate definitions for each of them.
        !          1167:    The usual definition accepts all pseudo regs; the other rejects
        !          1168:    them unless they have been allocated suitable hard regs.
        !          1169:    The symbol REG_OK_STRICT causes the latter definition to be used.
        !          1170: 
        !          1171:    Most source files want to accept pseudo regs in the hope that
        !          1172:    they will get allocated to the class that the insn wants them to be in.
        !          1173:    Source files for reload pass need to be strict.
        !          1174:    After reload, it makes no difference, since pseudo regs have
        !          1175:    been eliminated by then.  */
        !          1176: 
        !          1177: /* Optional extra constraints for this machine.  Borrowed from romp.h.
        !          1178: 
        !          1179:    For the SPARC, `Q' means that this is a memory operand but not a
        !          1180:    symbolic memory operand.  Note that an unassigned pseudo register
        !          1181:    is such a memory operand.  Needed because reload will generate
        !          1182:    these things in insns and then not re-recognize the insns, causing
        !          1183:    constrain_operands to fail.
        !          1184: 
        !          1185:    `S' handles constraints for calls.  */
        !          1186: 
        !          1187: #ifndef REG_OK_STRICT
        !          1188: 
        !          1189: /* Nonzero if X is a hard reg that can be used as an index
        !          1190:    or if it is a pseudo reg.  */
        !          1191: #define REG_OK_FOR_INDEX_P(X) (((unsigned) REGNO (X)) - 32 >= 32 && REGNO (X) != 0)
        !          1192: /* Nonzero if X is a hard reg that can be used as a base reg
        !          1193:    or if it is a pseudo reg.  */
        !          1194: #define REG_OK_FOR_BASE_P(X) (((unsigned) REGNO (X)) - 32 >= 32 && REGNO (X) != 0)
        !          1195: 
        !          1196: #define EXTRA_CONSTRAINT(OP, C)                                \
        !          1197:   ((C) == 'Q'                                          \
        !          1198:    ? ((GET_CODE (OP) == MEM                            \
        !          1199:        && memory_address_p (GET_MODE (OP), XEXP (OP, 0))       \
        !          1200:        && ! symbolic_memory_operand (OP, VOIDmode))    \
        !          1201:       || (reload_in_progress && GET_CODE (OP) == REG   \
        !          1202:          && REGNO (OP) >= FIRST_PSEUDO_REGISTER))      \
        !          1203:    : (C) == 'T'                                                \
        !          1204:    ? (mem_aligned_8 (OP))                              \
        !          1205:    : (C) == 'U'                                                \
        !          1206:    ? (register_ok_for_ldd (OP))                                \
        !          1207:    : 0)
        !          1208:  
        !          1209: #else
        !          1210: 
        !          1211: /* Nonzero if X is a hard reg that can be used as an index.  */
        !          1212: #define REG_OK_FOR_INDEX_P(X) REGNO_OK_FOR_INDEX_P (REGNO (X))
        !          1213: /* Nonzero if X is a hard reg that can be used as a base reg.  */
        !          1214: #define REG_OK_FOR_BASE_P(X) REGNO_OK_FOR_BASE_P (REGNO (X))
        !          1215: 
        !          1216: #define EXTRA_CONSTRAINT(OP, C)                                \
        !          1217:   ((C) == 'Q'                                          \
        !          1218:    ? (GET_CODE (OP) == REG                             \
        !          1219:       ? (REGNO (OP) >= FIRST_PSEUDO_REGISTER           \
        !          1220:         && reg_renumber[REGNO (OP)] < 0)               \
        !          1221:       : GET_CODE (OP) == MEM)                          \
        !          1222:    : (C) == 'T'                                                \
        !          1223:    ? mem_aligned_8 (OP) && strict_memory_address_p (Pmode, XEXP (OP, 0)) \
        !          1224:    : (C) == 'U'                                                \
        !          1225:    ? (GET_CODE (OP) == REG                             \
        !          1226:       && (REGNO (OP) < FIRST_PSEUDO_REGISTER           \
        !          1227:          || reg_renumber[REGNO (OP)] > 0)              \
        !          1228:       && register_ok_for_ldd (OP)) : 0)
        !          1229: #endif
        !          1230: 
        !          1231: /* GO_IF_LEGITIMATE_ADDRESS recognizes an RTL expression
        !          1232:    that is a valid memory address for an instruction.
        !          1233:    The MODE argument is the machine mode for the MEM expression
        !          1234:    that wants to use this address.
        !          1235: 
        !          1236:    On SPARC, the actual legitimate addresses must be REG+REG or REG+SMALLINT
        !          1237:    ordinarily.  This changes a bit when generating PIC.
        !          1238: 
        !          1239:    If you change this, execute "rm explow.o recog.o reload.o".  */
        !          1240: 
        !          1241: #define RTX_OK_FOR_BASE_P(X)                                           \
        !          1242:   ((GET_CODE (X) == REG && REG_OK_FOR_BASE_P (X))                      \
        !          1243:   || (GET_CODE (X) == SUBREG                                           \
        !          1244:       && GET_CODE (SUBREG_REG (X)) == REG                              \
        !          1245:       && REG_OK_FOR_BASE_P (SUBREG_REG (X))))
        !          1246: 
        !          1247: #define RTX_OK_FOR_INDEX_P(X)                                          \
        !          1248:   ((GET_CODE (X) == REG && REG_OK_FOR_INDEX_P (X))                     \
        !          1249:   || (GET_CODE (X) == SUBREG                                           \
        !          1250:       && GET_CODE (SUBREG_REG (X)) == REG                              \
        !          1251:       && REG_OK_FOR_INDEX_P (SUBREG_REG (X))))
        !          1252: 
        !          1253: #define RTX_OK_FOR_OFFSET_P(X)                                         \
        !          1254:   (GET_CODE (X) == CONST_INT && INTVAL (X) >= -0x1000 && INTVAL (X) < 0x1000)
        !          1255: 
        !          1256: #define GO_IF_LEGITIMATE_ADDRESS(MODE, X, ADDR)                \
        !          1257: { if (RTX_OK_FOR_BASE_P (X))                           \
        !          1258:     goto ADDR;                                         \
        !          1259:   else if (GET_CODE (X) == PLUS)                       \
        !          1260:     {                                                  \
        !          1261:       register rtx op0 = XEXP (X, 0);                  \
        !          1262:       register rtx op1 = XEXP (X, 1);                  \
        !          1263:       if (flag_pic && op0 == pic_offset_table_rtx)     \
        !          1264:        {                                               \
        !          1265:          if (RTX_OK_FOR_BASE_P (op1))                  \
        !          1266:            goto ADDR;                                  \
        !          1267:          else if (flag_pic == 1                        \
        !          1268:                   && GET_CODE (op1) != REG             \
        !          1269:                   && GET_CODE (op1) != LO_SUM          \
        !          1270:                   && GET_CODE (op1) != MEM             \
        !          1271:                   && (GET_CODE (op1) != CONST_INT      \
        !          1272:                       || SMALL_INT (op1)))             \
        !          1273:            goto ADDR;                                  \
        !          1274:        }                                               \
        !          1275:       else if (RTX_OK_FOR_BASE_P (op0))                        \
        !          1276:        {                                               \
        !          1277:          if (RTX_OK_FOR_INDEX_P (op1)                  \
        !          1278:              || RTX_OK_FOR_OFFSET_P (op1))             \
        !          1279:            goto ADDR;                                  \
        !          1280:        }                                               \
        !          1281:       else if (RTX_OK_FOR_BASE_P (op1))                        \
        !          1282:        {                                               \
        !          1283:          if (RTX_OK_FOR_INDEX_P (op0)                  \
        !          1284:              || RTX_OK_FOR_OFFSET_P (op0))             \
        !          1285:            goto ADDR;                                  \
        !          1286:        }                                               \
        !          1287:     }                                                  \
        !          1288:   else if (GET_CODE (X) == LO_SUM)                     \
        !          1289:     {                                                  \
        !          1290:       register rtx op0 = XEXP (X, 0);                  \
        !          1291:       register rtx op1 = XEXP (X, 1);                  \
        !          1292:       if (RTX_OK_FOR_BASE_P (op0)                      \
        !          1293:          && CONSTANT_P (op1))                          \
        !          1294:        goto ADDR;                                      \
        !          1295:     }                                                  \
        !          1296:   else if (GET_CODE (X) == CONST_INT && SMALL_INT (X)) \
        !          1297:     goto ADDR;                                         \
        !          1298: }
        !          1299: 
        !          1300: /* Try machine-dependent ways of modifying an illegitimate address
        !          1301:    to be legitimate.  If we find one, return the new, valid address.
        !          1302:    This macro is used in only one place: `memory_address' in explow.c.
        !          1303: 
        !          1304:    OLDX is the address as it was before break_out_memory_refs was called.
        !          1305:    In some cases it is useful to look at this to decide what needs to be done.
        !          1306: 
        !          1307:    MODE and WIN are passed so that this macro can use
        !          1308:    GO_IF_LEGITIMATE_ADDRESS.
        !          1309: 
        !          1310:    It is always safe for this macro to do nothing.  It exists to recognize
        !          1311:    opportunities to optimize the output.  */
        !          1312: 
        !          1313: /* On SPARC, change REG+N into REG+REG, and REG+(X*Y) into REG+REG.  */
        !          1314: extern struct rtx_def *legitimize_pic_address ();
        !          1315: #define LEGITIMIZE_ADDRESS(X,OLDX,MODE,WIN)    \
        !          1316: { rtx sparc_x = (X);                                           \
        !          1317:   if (GET_CODE (X) == PLUS && GET_CODE (XEXP (X, 0)) == MULT)  \
        !          1318:     (X) = gen_rtx (PLUS, Pmode, XEXP (X, 1),                   \
        !          1319:                   force_operand (XEXP (X, 0), NULL_RTX));      \
        !          1320:   if (GET_CODE (X) == PLUS && GET_CODE (XEXP (X, 1)) == MULT)  \
        !          1321:     (X) = gen_rtx (PLUS, Pmode, XEXP (X, 0),                   \
        !          1322:                   force_operand (XEXP (X, 1), NULL_RTX));      \
        !          1323:   if (GET_CODE (X) == PLUS && GET_CODE (XEXP (X, 0)) == PLUS)  \
        !          1324:     (X) = gen_rtx (PLUS, Pmode, force_operand (XEXP (X, 0), NULL_RTX),\
        !          1325:                   XEXP (X, 1));                                \
        !          1326:   if (GET_CODE (X) == PLUS && GET_CODE (XEXP (X, 1)) == PLUS)  \
        !          1327:     (X) = gen_rtx (PLUS, Pmode, XEXP (X, 0),                   \
        !          1328:                   force_operand (XEXP (X, 1), NULL_RTX));      \
        !          1329:   if (sparc_x != (X) && memory_address_p (MODE, X))            \
        !          1330:     goto WIN;                                                  \
        !          1331:   if (flag_pic) (X) = legitimize_pic_address (X, MODE, 0);     \
        !          1332:   else if (GET_CODE (X) == PLUS && CONSTANT_ADDRESS_P (XEXP (X, 1)))   \
        !          1333:     (X) = gen_rtx (PLUS, Pmode, XEXP (X, 0),                   \
        !          1334:                   copy_to_mode_reg (Pmode, XEXP (X, 1)));      \
        !          1335:   else if (GET_CODE (X) == PLUS && CONSTANT_ADDRESS_P (XEXP (X, 0)))   \
        !          1336:     (X) = gen_rtx (PLUS, Pmode, XEXP (X, 1),                   \
        !          1337:                   copy_to_mode_reg (Pmode, XEXP (X, 0)));      \
        !          1338:   else if (GET_CODE (X) == SYMBOL_REF || GET_CODE (X) == CONST \
        !          1339:           || GET_CODE (X) == LABEL_REF)                        \
        !          1340:     (X) = gen_rtx (LO_SUM, Pmode,                              \
        !          1341:                   copy_to_mode_reg (Pmode, gen_rtx (HIGH, Pmode, X)), X); \
        !          1342:   if (memory_address_p (MODE, X))                              \
        !          1343:     goto WIN; }
        !          1344: 
        !          1345: /* Go to LABEL if ADDR (a legitimate address expression)
        !          1346:    has an effect that depends on the machine mode it is used for.
        !          1347:    On the SPARC this is never true.  */
        !          1348: 
        !          1349: #define GO_IF_MODE_DEPENDENT_ADDRESS(ADDR,LABEL)
        !          1350: 
        !          1351: /* Specify the machine mode that this machine uses
        !          1352:    for the index in the tablejump instruction.  */
        !          1353: #define CASE_VECTOR_MODE SImode
        !          1354: 
        !          1355: /* Define this if the tablejump instruction expects the table
        !          1356:    to contain offsets from the address of the table.
        !          1357:    Do not define this if the table should contain absolute addresses.  */
        !          1358: /* #define CASE_VECTOR_PC_RELATIVE */
        !          1359: 
        !          1360: /* Specify the tree operation to be used to convert reals to integers.  */
        !          1361: #define IMPLICIT_FIX_EXPR FIX_ROUND_EXPR
        !          1362: 
        !          1363: /* This is the kind of divide that is easiest to do in the general case.  */
        !          1364: #define EASY_DIV_EXPR TRUNC_DIV_EXPR
        !          1365: 
        !          1366: /* Define this as 1 if `char' should by default be signed; else as 0.  */
        !          1367: #define DEFAULT_SIGNED_CHAR 1
        !          1368: 
        !          1369: /* Max number of bytes we can move from memory to memory
        !          1370:    in one reasonably fast instruction.  */
        !          1371: #define MOVE_MAX 8
        !          1372: 
        !          1373: #if 0 /* Sun 4 has matherr, so this is no good.  */
        !          1374: /* This is the value of the error code EDOM for this machine,
        !          1375:    used by the sqrt instruction.  */
        !          1376: #define TARGET_EDOM 33
        !          1377: 
        !          1378: /* This is how to refer to the variable errno.  */
        !          1379: #define GEN_ERRNO_RTX \
        !          1380:   gen_rtx (MEM, SImode, gen_rtx (SYMBOL_REF, Pmode, "errno"))
        !          1381: #endif /* 0 */
        !          1382: 
        !          1383: /* Define if operations between registers always perform the operation
        !          1384:    on the full register even if a narrower mode is specified.  */
        !          1385: #define WORD_REGISTER_OPERATIONS
        !          1386: 
        !          1387: /* Define if loading in MODE, an integral mode narrower than BITS_PER_WORD
        !          1388:    will either zero-extend or sign-extend.  The value of this macro should
        !          1389:    be the code that says which one of the two operations is implicitly
        !          1390:    done, NIL if none.  */
        !          1391: #define LOAD_EXTEND_OP(MODE) ZERO_EXTEND
        !          1392: 
        !          1393: /* Nonzero if access to memory by bytes is slow and undesirable.
        !          1394:    For RISC chips, it means that access to memory by bytes is no
        !          1395:    better than access by words when possible, so grab a whole word
        !          1396:    and maybe make use of that.  */
        !          1397: #define SLOW_BYTE_ACCESS 1
        !          1398: 
        !          1399: /* We assume that the store-condition-codes instructions store 0 for false
        !          1400:    and some other value for true.  This is the value stored for true.  */
        !          1401: 
        !          1402: #define STORE_FLAG_VALUE 1
        !          1403: 
        !          1404: /* When a prototype says `char' or `short', really pass an `int'.  */
        !          1405: #define PROMOTE_PROTOTYPES
        !          1406: 
        !          1407: /* Define this to be nonzero if shift instructions ignore all but the low-order
        !          1408:    few bits. */
        !          1409: #define SHIFT_COUNT_TRUNCATED 1
        !          1410: 
        !          1411: /* Value is 1 if truncating an integer of INPREC bits to OUTPREC bits
        !          1412:    is done just by pretending it is already truncated.  */
        !          1413: #define TRULY_NOOP_TRUNCATION(OUTPREC, INPREC) 1
        !          1414: 
        !          1415: /* Specify the machine mode that pointers have.
        !          1416:    After generation of rtl, the compiler makes no further distinction
        !          1417:    between pointers and any other objects of this machine mode.  */
        !          1418: #define Pmode SImode
        !          1419: 
        !          1420: /* Generate calls to memcpy, memcmp and memset.  */
        !          1421: #define TARGET_MEM_FUNCTIONS
        !          1422: 
        !          1423: /* Add any extra modes needed to represent the condition code.
        !          1424: 
        !          1425:    On the Sparc, we have a "no-overflow" mode which is used when an add or
        !          1426:    subtract insn is used to set the condition code.  Different branches are
        !          1427:    used in this case for some operations.
        !          1428: 
        !          1429:    We also have two modes to indicate that the relevant condition code is
        !          1430:    in the floating-point condition code register.  One for comparisons which
        !          1431:    will generate an exception if the result is unordered (CCFPEmode) and
        !          1432:    one for comparisons which will never trap (CCFPmode).  This really should
        !          1433:    be a separate register, but we don't want to go to 65 registers.  */
        !          1434: #define EXTRA_CC_MODES CC_NOOVmode, CCFPmode, CCFPEmode
        !          1435: 
        !          1436: /* Define the names for the modes specified above.  */
        !          1437: #define EXTRA_CC_NAMES "CC_NOOV", "CCFP", "CCFPE"
        !          1438: 
        !          1439: /* Given a comparison code (EQ, NE, etc.) and the first operand of a COMPARE,
        !          1440:    return the mode to be used for the comparison.  For floating-point,
        !          1441:    CCFP[E]mode is used.  CC_NOOVmode should be used when the first operand is a
        !          1442:    PLUS, MINUS, NEG, or ASHIFT.  CCmode should be used when no special
        !          1443:    processing is needed.  */
        !          1444: #define SELECT_CC_MODE(OP,X,Y) \
        !          1445:   (GET_MODE_CLASS (GET_MODE (X)) == MODE_FLOAT                         \
        !          1446:    ? ((OP == EQ || OP == NE) ? CCFPmode : CCFPEmode)                   \
        !          1447:    : ((GET_CODE (X) == PLUS || GET_CODE (X) == MINUS                   \
        !          1448:        || GET_CODE (X) == NEG || GET_CODE (X) == ASHIFT)               \
        !          1449:       ? CC_NOOVmode : CCmode))
        !          1450: 
        !          1451: /* A function address in a call instruction
        !          1452:    is a byte address (for indexing purposes)
        !          1453:    so give the MEM rtx a byte's mode.  */
        !          1454: #define FUNCTION_MODE SImode
        !          1455: 
        !          1456: /* Define this if addresses of constant functions
        !          1457:    shouldn't be put through pseudo regs where they can be cse'd.
        !          1458:    Desirable on machines where ordinary constants are expensive
        !          1459:    but a CALL with constant address is cheap.  */
        !          1460: #define NO_FUNCTION_CSE
        !          1461: 
        !          1462: /* alloca should avoid clobbering the old register save area.  */
        !          1463: #define SETJMP_VIA_SAVE_AREA
        !          1464: 
        !          1465: /* Define subroutines to call to handle multiply and divide.
        !          1466:    Use the subroutines that Sun's library provides.
        !          1467:    The `*' prevents an underscore from being prepended by the compiler.  */
        !          1468: 
        !          1469: #define DIVSI3_LIBCALL "*.div"
        !          1470: #define UDIVSI3_LIBCALL "*.udiv"
        !          1471: #define MODSI3_LIBCALL "*.rem"
        !          1472: #define UMODSI3_LIBCALL "*.urem"
        !          1473: /* .umul is a little faster than .mul.  */
        !          1474: #define MULSI3_LIBCALL "*.umul"
        !          1475: 
        !          1476: /* Compute the cost of computing a constant rtl expression RTX
        !          1477:    whose rtx-code is CODE.  The body of this macro is a portion
        !          1478:    of a switch statement.  If the code is computed here,
        !          1479:    return it with a return statement.  Otherwise, break from the switch.  */
        !          1480: 
        !          1481: #define CONST_COSTS(RTX,CODE,OUTER_CODE) \
        !          1482:   case CONST_INT:                                              \
        !          1483:     if (INTVAL (RTX) < 0x1000 && INTVAL (RTX) >= -0x1000)      \
        !          1484:       return 0;                                                        \
        !          1485:   case HIGH:                                                   \
        !          1486:     return 2;                                                  \
        !          1487:   case CONST:                                                  \
        !          1488:   case LABEL_REF:                                              \
        !          1489:   case SYMBOL_REF:                                             \
        !          1490:     return 4;                                                  \
        !          1491:   case CONST_DOUBLE:                                           \
        !          1492:     if (GET_MODE (RTX) == DImode)                              \
        !          1493:       if ((XINT (RTX, 3) == 0                                  \
        !          1494:           && (unsigned) XINT (RTX, 2) < 0x1000)                \
        !          1495:          || (XINT (RTX, 3) == -1                               \
        !          1496:              && XINT (RTX, 2) < 0                              \
        !          1497:              && XINT (RTX, 2) >= -0x1000))                     \
        !          1498:        return 0;                                               \
        !          1499:     return 8;
        !          1500: 
        !          1501: /* SPARC offers addressing modes which are "as cheap as a register".
        !          1502:    See sparc.c (or gcc.texinfo) for details.  */
        !          1503: 
        !          1504: #define ADDRESS_COST(RTX) \
        !          1505:   (GET_CODE (RTX) == REG ? 1 : sparc_address_cost (RTX))
        !          1506: 
        !          1507: /* Compute extra cost of moving data between one register class
        !          1508:    and another.  */
        !          1509: #define REGISTER_MOVE_COST(CLASS1, CLASS2) \
        !          1510:   (((CLASS1 == FP_REGS && CLASS2 == GENERAL_REGS) \
        !          1511:     || (CLASS1 == GENERAL_REGS && CLASS2 == FP_REGS)) ? 6 : 2)
        !          1512: 
        !          1513: /* Provide the costs of a rtl expression.  This is in the body of a
        !          1514:    switch on CODE.  The purpose for the cost of MULT is to encourage
        !          1515:    `synth_mult' to find a synthetic multiply when reasonable.
        !          1516: 
        !          1517:    If we need more than 12 insns to do a multiply, then go out-of-line,
        !          1518:    since the call overhead will be < 10% of the cost of the multiply.  */
        !          1519: 
        !          1520: #define RTX_COSTS(X,CODE,OUTER_CODE)                   \
        !          1521:   case MULT:                                           \
        !          1522:     return TARGET_V8 ? COSTS_N_INSNS (5) : COSTS_N_INSNS (25); \
        !          1523:   case DIV:                                            \
        !          1524:   case UDIV:                                           \
        !          1525:   case MOD:                                            \
        !          1526:   case UMOD:                                           \
        !          1527:     return COSTS_N_INSNS (25);                         \
        !          1528:   /* Make FLOAT and FIX more expensive than CONST_DOUBLE,\
        !          1529:      so that cse will favor the latter.  */            \
        !          1530:   case FLOAT:                                          \
        !          1531:   case FIX:                                            \
        !          1532:     return 19;
        !          1533: 
        !          1534: /* Conditional branches with empty delay slots have a length of two.  */
        !          1535: #define ADJUST_INSN_LENGTH(INSN, LENGTH)       \
        !          1536:   if (GET_CODE (INSN) == CALL_INSN                                     \
        !          1537:       || (GET_CODE (INSN) == JUMP_INSN && ! simplejump_p (insn)))      \
        !          1538:     LENGTH += 1;
        !          1539: 
        !          1540: /* Control the assembler format that we output.  */
        !          1541: 
        !          1542: /* Output at beginning of assembler file.  */
        !          1543: 
        !          1544: #define ASM_FILE_START(file)
        !          1545: 
        !          1546: /* Output to assembler file text saying following lines
        !          1547:    may contain character constants, extra white space, comments, etc.  */
        !          1548: 
        !          1549: #define ASM_APP_ON ""
        !          1550: 
        !          1551: /* Output to assembler file text saying following lines
        !          1552:    no longer contain unusual constructs.  */
        !          1553: 
        !          1554: #define ASM_APP_OFF ""
        !          1555: 
        !          1556: #define ASM_LONG       ".word"
        !          1557: #define ASM_SHORT      ".half"
        !          1558: #define ASM_BYTE_OP    ".byte"
        !          1559: 
        !          1560: /* Output before read-only data.  */
        !          1561: 
        !          1562: #define TEXT_SECTION_ASM_OP ".text"
        !          1563: 
        !          1564: /* Output before writable data.  */
        !          1565: 
        !          1566: #define DATA_SECTION_ASM_OP ".data"
        !          1567: 
        !          1568: /* How to refer to registers in assembler output.
        !          1569:    This sequence is indexed by compiler's hard-register-number (see above).  */
        !          1570: 
        !          1571: #define REGISTER_NAMES \
        !          1572: {"%g0", "%g1", "%g2", "%g3", "%g4", "%g5", "%g6", "%g7",               \
        !          1573:  "%o0", "%o1", "%o2", "%o3", "%o4", "%o5", "%sp", "%o7",               \
        !          1574:  "%l0", "%l1", "%l2", "%l3", "%l4", "%l5", "%l6", "%l7",               \
        !          1575:  "%i0", "%i1", "%i2", "%i3", "%i4", "%i5", "%fp", "%i7",               \
        !          1576:  "%f0", "%f1", "%f2", "%f3", "%f4", "%f5", "%f6", "%f7",               \
        !          1577:  "%f8", "%f9", "%f10", "%f11", "%f12", "%f13", "%f14", "%f15",         \
        !          1578:  "%f16", "%f17", "%f18", "%f19", "%f20", "%f21", "%f22", "%f23",       \
        !          1579:  "%f24", "%f25", "%f26", "%f27", "%f28", "%f29", "%f30", "%f31"}
        !          1580: 
        !          1581: /* Define additional names for use in asm clobbers and asm declarations.
        !          1582: 
        !          1583:    We define the fake Condition Code register as an alias for reg 0 (which
        !          1584:    is our `condition code' register), so that condition codes can easily
        !          1585:    be clobbered by an asm.  No such register actually exists.  Condition
        !          1586:    codes are partly stored in the PSR and partly in the FSR.  */
        !          1587: 
        !          1588: #define ADDITIONAL_REGISTER_NAMES      {"ccr", 0, "cc", 0}
        !          1589: 
        !          1590: /* How to renumber registers for dbx and gdb.  */
        !          1591: 
        !          1592: #define DBX_REGISTER_NUMBER(REGNO) (REGNO)
        !          1593: 
        !          1594: /* On Sun 4, this limit is 2048.  We use 1500 to be safe,
        !          1595:    since the length can run past this up to a continuation point.  */
        !          1596: #define DBX_CONTIN_LENGTH 1500
        !          1597: 
        !          1598: /* This is how to output a note to DBX telling it the line number
        !          1599:    to which the following sequence of instructions corresponds.
        !          1600: 
        !          1601:    This is needed for SunOS 4.0, and should not hurt for 3.2
        !          1602:    versions either.  */
        !          1603: #define ASM_OUTPUT_SOURCE_LINE(file, line)             \
        !          1604:   { static int sym_lineno = 1;                         \
        !          1605:     fprintf (file, ".stabn 68,0,%d,LM%d\nLM%d:\n",     \
        !          1606:             line, sym_lineno, sym_lineno);             \
        !          1607:     sym_lineno += 1; }
        !          1608: 
        !          1609: /* This is how to output the definition of a user-level label named NAME,
        !          1610:    such as the label on a static function or variable NAME.  */
        !          1611: 
        !          1612: #define ASM_OUTPUT_LABEL(FILE,NAME)    \
        !          1613:   do { assemble_name (FILE, NAME); fputs (":\n", FILE); } while (0)
        !          1614: 
        !          1615: /* This is how to output a command to make the user-level label named NAME
        !          1616:    defined for reference from other files.  */
        !          1617: 
        !          1618: #define ASM_GLOBALIZE_LABEL(FILE,NAME) \
        !          1619:   do { fputs ("\t.global ", FILE); assemble_name (FILE, NAME); fputs ("\n", FILE);} while (0)
        !          1620: 
        !          1621: /* This is how to output a reference to a user-level label named NAME.
        !          1622:    `assemble_name' uses this.  */
        !          1623: 
        !          1624: #define ASM_OUTPUT_LABELREF(FILE,NAME) \
        !          1625:   fprintf (FILE, "_%s", NAME)
        !          1626: 
        !          1627: /* This is how to output a definition of an internal numbered label where
        !          1628:    PREFIX is the class of label and NUM is the number within the class.  */
        !          1629: 
        !          1630: #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM)     \
        !          1631:   fprintf (FILE, "%s%d:\n", PREFIX, NUM)
        !          1632: 
        !          1633: /* This is how to output a reference to an internal numbered label where
        !          1634:    PREFIX is the class of label and NUM is the number within the class.  */
        !          1635: /* FIXME:  This should be used throughout gcc, and documented in the texinfo
        !          1636:    files.  There is no reason you should have to allocate a buffer and
        !          1637:    `sprintf' to reference an internal label (as opposed to defining it).  */
        !          1638: 
        !          1639: #define ASM_OUTPUT_INTERNAL_LABELREF(FILE,PREFIX,NUM)  \
        !          1640:   fprintf (FILE, "%s%d", PREFIX, NUM)
        !          1641: 
        !          1642: /* This is how to store into the string LABEL
        !          1643:    the symbol_ref name of an internal numbered label where
        !          1644:    PREFIX is the class of label and NUM is the number within the class.
        !          1645:    This is suitable for output with `assemble_name'.  */
        !          1646: 
        !          1647: #define ASM_GENERATE_INTERNAL_LABEL(LABEL,PREFIX,NUM)  \
        !          1648:   sprintf (LABEL, "*%s%d", PREFIX, NUM)
        !          1649: 
        !          1650: /* This is how to output an assembler line defining a `double' constant.  */
        !          1651: 
        !          1652: #define ASM_OUTPUT_DOUBLE(FILE,VALUE)                                  \
        !          1653:   {                                                                    \
        !          1654:     long t[2];                                                         \
        !          1655:     REAL_VALUE_TO_TARGET_DOUBLE ((VALUE), t);                          \
        !          1656:     fprintf (FILE, "\t%s\t0x%lx\n\t%s\t0x%lx\n",                       \
        !          1657:             ASM_LONG, t[0], ASM_LONG, t[1]);                           \
        !          1658:   }
        !          1659: 
        !          1660: /* This is how to output an assembler line defining a `float' constant.  */
        !          1661: 
        !          1662: #define ASM_OUTPUT_FLOAT(FILE,VALUE)                                   \
        !          1663:   {                                                                    \
        !          1664:     long t;                                                            \
        !          1665:     REAL_VALUE_TO_TARGET_SINGLE ((VALUE), t);                          \
        !          1666:     fprintf (FILE, "\t%s\t0x%lx\n", ASM_LONG, t);                      \
        !          1667:   }                                                                    \
        !          1668: 
        !          1669: /* This is how to output an assembler line defining a `long double'
        !          1670:    constant.  */
        !          1671: 
        !          1672: #define ASM_OUTPUT_LONG_DOUBLE(FILE,VALUE)                             \
        !          1673:   {                                                                    \
        !          1674:     long t[4];                                                         \
        !          1675:     REAL_VALUE_TO_TARGET_LONG_DOUBLE ((VALUE), t);                     \
        !          1676:     fprintf (FILE, "\t%s\t0x%lx\n\t%s\t0x%lx\n\t%s\t0x%lx\n\t%s\t0x%lx\n", \
        !          1677:       ASM_LONG, t[0], ASM_LONG, t[1], ASM_LONG, t[2], ASM_LONG, t[3]); \
        !          1678:   }
        !          1679: 
        !          1680: /* This is how to output an assembler line defining an `int' constant.  */
        !          1681: 
        !          1682: #define ASM_OUTPUT_INT(FILE,VALUE)  \
        !          1683: ( fprintf (FILE, "\t%s\t", ASM_LONG),          \
        !          1684:   output_addr_const (FILE, (VALUE)),           \
        !          1685:   fprintf (FILE, "\n"))
        !          1686: 
        !          1687: /* This is how to output an assembler line defining a DImode constant.  */
        !          1688: #define ASM_OUTPUT_DOUBLE_INT(FILE,VALUE)  \
        !          1689:   output_double_int (FILE, VALUE)
        !          1690: 
        !          1691: /* Likewise for `char' and `short' constants.  */
        !          1692: 
        !          1693: #define ASM_OUTPUT_SHORT(FILE,VALUE)  \
        !          1694: ( fprintf (FILE, "\t%s\t", ASM_SHORT),         \
        !          1695:   output_addr_const (FILE, (VALUE)),           \
        !          1696:   fprintf (FILE, "\n"))
        !          1697: 
        !          1698: #define ASM_OUTPUT_CHAR(FILE,VALUE)  \
        !          1699: ( fprintf (FILE, "\t%s\t", ASM_BYTE_OP),       \
        !          1700:   output_addr_const (FILE, (VALUE)),           \
        !          1701:   fprintf (FILE, "\n"))
        !          1702: 
        !          1703: /* This is how to output an assembler line for a numeric constant byte.  */
        !          1704: 
        !          1705: #define ASM_OUTPUT_BYTE(FILE,VALUE)  \
        !          1706:   fprintf (FILE, "\t%s\t0x%x\n", ASM_BYTE_OP, (VALUE))
        !          1707: 
        !          1708: /* This is how to output an element of a case-vector that is absolute.  */
        !          1709: 
        !          1710: #define ASM_OUTPUT_ADDR_VEC_ELT(FILE, VALUE)  \
        !          1711: do {                                                                   \
        !          1712:   char label[30];                                                      \
        !          1713:   ASM_GENERATE_INTERNAL_LABEL (label, "L", VALUE);                     \
        !          1714:   fprintf (FILE, "\t.word\t");                                         \
        !          1715:   assemble_name (FILE, label);                                         \
        !          1716:   fprintf (FILE, "\n");                                                        \
        !          1717: } while (0)
        !          1718: 
        !          1719: /* This is how to output an element of a case-vector that is relative.
        !          1720:    (SPARC uses such vectors only when generating PIC.)  */
        !          1721: 
        !          1722: #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL)                     \
        !          1723: do {                                                                   \
        !          1724:   char label[30];                                                      \
        !          1725:   ASM_GENERATE_INTERNAL_LABEL (label, "L", VALUE);                     \
        !          1726:   fprintf (FILE, "\t.word\t");                                         \
        !          1727:   assemble_name (FILE, label);                                         \
        !          1728:   fprintf (FILE, "-1b\n");                                             \
        !          1729: } while (0)
        !          1730: 
        !          1731: /* This is how to output an assembler line
        !          1732:    that says to advance the location counter
        !          1733:    to a multiple of 2**LOG bytes.  */
        !          1734: 
        !          1735: #define ASM_OUTPUT_ALIGN(FILE,LOG)     \
        !          1736:   if ((LOG) != 0)                      \
        !          1737:     fprintf (FILE, "\t.align %d\n", (1<<(LOG)))
        !          1738: 
        !          1739: #define ASM_OUTPUT_SKIP(FILE,SIZE)  \
        !          1740:   fprintf (FILE, "\t.skip %u\n", (SIZE))
        !          1741: 
        !          1742: /* This says how to output an assembler line
        !          1743:    to define a global common symbol.  */
        !          1744: 
        !          1745: #define ASM_OUTPUT_COMMON(FILE, NAME, SIZE, ROUNDED)  \
        !          1746: ( fputs ("\t.global ", (FILE)),                        \
        !          1747:   assemble_name ((FILE), (NAME)),              \
        !          1748:   fputs ("\n\t.common ", (FILE)),              \
        !          1749:   assemble_name ((FILE), (NAME)),              \
        !          1750:   fprintf ((FILE), ",%u,\"bss\"\n", (ROUNDED)))
        !          1751: 
        !          1752: /* This says how to output an assembler line
        !          1753:    to define a local common symbol.  */
        !          1754: 
        !          1755: #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE, ROUNDED)  \
        !          1756: ( fputs ("\n\t.reserve ", (FILE)),             \
        !          1757:   assemble_name ((FILE), (NAME)),              \
        !          1758:   fprintf ((FILE), ",%u,\"bss\"\n", (ROUNDED)))
        !          1759: 
        !          1760: /* Store in OUTPUT a string (made with alloca) containing
        !          1761:    an assembler-name for a local static variable named NAME.
        !          1762:    LABELNO is an integer which is different for each call.  */
        !          1763: 
        !          1764: #define ASM_FORMAT_PRIVATE_NAME(OUTPUT, NAME, LABELNO) \
        !          1765: ( (OUTPUT) = (char *) alloca (strlen ((NAME)) + 10),   \
        !          1766:   sprintf ((OUTPUT), "%s.%d", (NAME), (LABELNO)))
        !          1767: 
        !          1768: #define IDENT_ASM_OP ".ident"
        !          1769: 
        !          1770: /* Output #ident as a .ident.  */
        !          1771: 
        !          1772: #define ASM_OUTPUT_IDENT(FILE, NAME) \
        !          1773:   fprintf (FILE, "\t%s\t\"%s\"\n", IDENT_ASM_OP, NAME);
        !          1774: 
        !          1775: /* Define the parentheses used to group arithmetic operations
        !          1776:    in assembler code.  */
        !          1777: 
        !          1778: #define ASM_OPEN_PAREN "("
        !          1779: #define ASM_CLOSE_PAREN ")"
        !          1780: 
        !          1781: /* Define results of standard character escape sequences.  */
        !          1782: #define TARGET_BELL 007
        !          1783: #define TARGET_BS 010
        !          1784: #define TARGET_TAB 011
        !          1785: #define TARGET_NEWLINE 012
        !          1786: #define TARGET_VT 013
        !          1787: #define TARGET_FF 014
        !          1788: #define TARGET_CR 015
        !          1789: 
        !          1790: #define PRINT_OPERAND_PUNCT_VALID_P(CHAR) \
        !          1791:   ((CHAR) == '#' || (CHAR) == '*' || (CHAR) == '^' || (CHAR) == '(')
        !          1792: 
        !          1793: /* Print operand X (an rtx) in assembler syntax to file FILE.
        !          1794:    CODE is a letter or dot (`z' in `%z0') or 0 if no letter was specified.
        !          1795:    For `%' followed by punctuation, CODE is the punctuation and X is null.  */
        !          1796: 
        !          1797: #define PRINT_OPERAND(FILE, X, CODE) print_operand (FILE, X, CODE)
        !          1798: 
        !          1799: /* Print a memory address as an operand to reference that memory location.  */
        !          1800: 
        !          1801: #define PRINT_OPERAND_ADDRESS(FILE, ADDR)  \
        !          1802: { register rtx base, index = 0;                                        \
        !          1803:   int offset = 0;                                              \
        !          1804:   register rtx addr = ADDR;                                    \
        !          1805:   if (GET_CODE (addr) == REG)                                  \
        !          1806:     fputs (reg_names[REGNO (addr)], FILE);                     \
        !          1807:   else if (GET_CODE (addr) == PLUS)                            \
        !          1808:     {                                                          \
        !          1809:       if (GET_CODE (XEXP (addr, 0)) == CONST_INT)              \
        !          1810:        offset = INTVAL (XEXP (addr, 0)), base = XEXP (addr, 1);\
        !          1811:       else if (GET_CODE (XEXP (addr, 1)) == CONST_INT)         \
        !          1812:        offset = INTVAL (XEXP (addr, 1)), base = XEXP (addr, 0);\
        !          1813:       else                                                     \
        !          1814:        base = XEXP (addr, 0), index = XEXP (addr, 1);          \
        !          1815:       fputs (reg_names[REGNO (base)], FILE);                   \
        !          1816:       if (index == 0)                                          \
        !          1817:        fprintf (FILE, "%+d", offset);                          \
        !          1818:       else if (GET_CODE (index) == REG)                                \
        !          1819:        fprintf (FILE, "+%s", reg_names[REGNO (index)]);        \
        !          1820:       else if (GET_CODE (index) == SYMBOL_REF)                 \
        !          1821:        fputc ('+', FILE), output_addr_const (FILE, index);     \
        !          1822:       else abort ();                                           \
        !          1823:     }                                                          \
        !          1824:   else if (GET_CODE (addr) == MINUS                            \
        !          1825:           && GET_CODE (XEXP (addr, 1)) == LABEL_REF)           \
        !          1826:     {                                                          \
        !          1827:       output_addr_const (FILE, XEXP (addr, 0));                        \
        !          1828:       fputs ("-(", FILE);                                      \
        !          1829:       output_addr_const (FILE, XEXP (addr, 1));                        \
        !          1830:       fputs ("-.)", FILE);                                     \
        !          1831:     }                                                          \
        !          1832:   else if (GET_CODE (addr) == LO_SUM)                          \
        !          1833:     {                                                          \
        !          1834:       output_operand (XEXP (addr, 0), 0);                      \
        !          1835:       fputs ("+%lo(", FILE);                                   \
        !          1836:       output_address (XEXP (addr, 1));                         \
        !          1837:       fputc (')', FILE);                                       \
        !          1838:     }                                                          \
        !          1839:   else if (flag_pic && GET_CODE (addr) == CONST                        \
        !          1840:           && GET_CODE (XEXP (addr, 0)) == MINUS                \
        !          1841:           && GET_CODE (XEXP (XEXP (addr, 0), 1)) == CONST      \
        !          1842:           && GET_CODE (XEXP (XEXP (XEXP (addr, 0), 1), 0)) == MINUS    \
        !          1843:           && XEXP (XEXP (XEXP (XEXP (addr, 0), 1), 0), 1) == pc_rtx)   \
        !          1844:     {                                                          \
        !          1845:       addr = XEXP (addr, 0);                                   \
        !          1846:       output_addr_const (FILE, XEXP (addr, 0));                        \
        !          1847:       /* Group the args of the second CONST in parenthesis.  */        \
        !          1848:       fputs ("-(", FILE);                                      \
        !          1849:       /* Skip past the second CONST--it does nothing for us.  */\
        !          1850:       output_addr_const (FILE, XEXP (XEXP (addr, 1), 0));      \
        !          1851:       /* Close the parenthesis.  */                            \
        !          1852:       fputc (')', FILE);                                       \
        !          1853:     }                                                          \
        !          1854:   else                                                         \
        !          1855:     {                                                          \
        !          1856:       output_addr_const (FILE, addr);                          \
        !          1857:     }                                                          \
        !          1858: }
        !          1859: 
        !          1860: /* Declare functions defined in sparc.c and used in templates.  */
        !          1861: 
        !          1862: extern char *singlemove_string ();
        !          1863: extern char *output_move_double ();
        !          1864: extern char *output_move_quad ();
        !          1865: extern char *output_fp_move_double ();
        !          1866: extern char *output_fp_move_quad ();
        !          1867: extern char *output_block_move ();
        !          1868: extern char *output_scc_insn ();
        !          1869: extern char *output_cbranch ();
        !          1870: extern char *output_return ();
        !          1871: 
        !          1872: /* Defined in flags.h, but insn-emit.c does not include flags.h.  */
        !          1873: 
        !          1874: extern int flag_pic;

unix.superglobalmegacorp.com

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