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

1.1     ! root        1: /* Definitions of target machine for GNU compiler.  MIPS version.
        !             2:    Copyright (C) 1989, 1990, 1991, 1992, 1993 Free Software Foundation, Inc.
        !             3:    Contributed by   A. Lichnewsky,     [email protected]
        !             4:    Changed by Michael Meissner,                [email protected]
        !             5: 
        !             6: This file is part of GNU CC.
        !             7: 
        !             8: GNU CC is free software; you can redistribute it and/or modify
        !             9: it under the terms of the GNU General Public License as published by
        !            10: the Free Software Foundation; either version 2, or (at your option)
        !            11: any later version.
        !            12: 
        !            13: GNU CC is distributed in the hope that it will be useful,
        !            14: but WITHOUT ANY WARRANTY; without even the implied warranty of
        !            15: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
        !            16: GNU General Public License for more details.
        !            17: 
        !            18: You should have received a copy of the GNU General Public License
        !            19: along with GNU CC; see the file COPYING.  If not, write to
        !            20: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
        !            21: 
        !            22: 
        !            23: /* Make Saber happier on obstack.[ch].  */
        !            24: #if defined(__mips__) || defined(mips)
        !            25: #define __PTR_TO_INT(P) ((int)(P))
        !            26: #define __INT_TO_PTR(P) ((char *)(P))
        !            27: #endif
        !            28: 
        !            29: /* Standard GCC variables that we reference.  */
        !            30: 
        !            31: extern char    *asm_file_name;
        !            32: extern char    call_used_regs[];
        !            33: extern int     current_function_calls_alloca;
        !            34: extern int     flag_omit_frame_pointer;
        !            35: extern int     frame_pointer_needed;
        !            36: extern char    *language_string;
        !            37: extern int     may_call_alloca;
        !            38: extern int     optimize;
        !            39: extern char   **save_argv;
        !            40: extern int     target_flags;
        !            41: extern char    *version_string;
        !            42: 
        !            43: /* MIPS external variables defined in mips.c.  */
        !            44: 
        !            45: /* comparison type */
        !            46: enum cmp_type {
        !            47:   CMP_SI,                              /* compare integers */
        !            48:   CMP_SF,                              /* compare single precision floats */
        !            49:   CMP_DF,                              /* compare double precision floats */
        !            50:   CMP_MAX                              /* max comparison type */
        !            51: };
        !            52: 
        !            53: /* types of delay slot */
        !            54: enum delay_type {
        !            55:   DELAY_NONE,                          /* no delay slot */
        !            56:   DELAY_LOAD,                          /* load from memory delay */
        !            57:   DELAY_HILO,                          /* move from/to hi/lo registers */
        !            58:   DELAY_FCMP                           /* delay after doing c.<xx>.{d,s} */
        !            59: };
        !            60: 
        !            61: /* Which processor to schedule for.  Since there is no difference between
        !            62:    a R2000 and R3000 in terms of the scheduler, we collapse them into
        !            63:    just an R3000.  The elements of the enumeration must match exactly
        !            64:    the cpu attribute in the mips.md machine description.  */
        !            65: 
        !            66: enum processor_type {
        !            67:   PROCESSOR_DEFAULT,
        !            68:   PROCESSOR_R3000,
        !            69:   PROCESSOR_R6000,
        !            70:   PROCESSOR_R4000
        !            71: };
        !            72: 
        !            73: /* Recast the cpu class to be the cpu attribute.  */
        !            74: #define mips_cpu_attr ((enum attr_cpu)mips_cpu)
        !            75: 
        !            76: /* Whether to emit abicalls code sequences or not.  */
        !            77: 
        !            78: enum mips_abicalls_type {
        !            79:   MIPS_ABICALLS_NO,
        !            80:   MIPS_ABICALLS_YES
        !            81: };
        !            82: 
        !            83: /* Recast the abicalls class to be the abicalls attribute.  */
        !            84: #define mips_abicalls_attr ((enum attr_abicalls)mips_abicalls)
        !            85: 
        !            86: /* Which type of block move to do (whether or not the last store is
        !            87:    split out so it can fill a branch delay slot).  */
        !            88: 
        !            89: enum block_move_type {
        !            90:   BLOCK_MOVE_NORMAL,                   /* generate complete block move */
        !            91:   BLOCK_MOVE_NOT_LAST,                 /* generate all but last store */
        !            92:   BLOCK_MOVE_LAST                      /* generate just the last store */
        !            93: };
        !            94: 
        !            95: extern char mips_reg_names[][8];       /* register names (a0 vs. $4). */
        !            96: extern char mips_print_operand_punct[];        /* print_operand punctuation chars */
        !            97: extern char *current_function_name;    /* current function being compiled */
        !            98: extern char *current_function_file;    /* filename current function is in */
        !            99: extern int num_source_filenames;       /* current .file # */
        !           100: extern int inside_function;            /* != 0 if inside of a function */
        !           101: extern int ignore_line_number;         /* != 0 if we are to ignore next .loc */
        !           102: extern int file_in_function_warning;   /* warning given about .file in func */
        !           103: extern int sdb_label_count;            /* block start/end next label # */
        !           104: extern int mips_section_threshold;     /* # bytes of data/sdata cutoff */
        !           105: extern int g_switch_value;             /* value of the -G xx switch */
        !           106: extern int g_switch_set;               /* whether -G xx was passed.  */
        !           107: extern int sym_lineno;                 /* sgi next label # for each stmt */
        !           108: extern int set_noreorder;              /* # of nested .set noreorder's  */
        !           109: extern int set_nomacro;                        /* # of nested .set nomacro's  */
        !           110: extern int set_noat;                   /* # of nested .set noat's  */
        !           111: extern int set_volatile;               /* # of nested .set volatile's  */
        !           112: extern int mips_branch_likely;         /* emit 'l' after br (branch likely) */
        !           113: extern int mips_dbx_regno[];           /* Map register # to debug register # */
        !           114: extern char mips_rtx_classify[];       /* classify an RTX code */
        !           115: extern struct rtx_def *branch_cmp[2];  /* operands for compare */
        !           116: extern enum cmp_type branch_type;      /* what type of branch to use */
        !           117: extern enum processor_type mips_cpu;   /* which cpu are we scheduling for */
        !           118: extern enum mips_abicalls_type mips_abicalls;/* for svr4 abi pic calls */
        !           119: extern int mips_isa;                   /* architectural level */
        !           120: extern char *mips_cpu_string;          /* for -mcpu=<xxx> */
        !           121: extern char *mips_isa_string;          /* for -mips{1,2,3} */
        !           122: extern int dslots_load_total;          /* total # load related delay slots */
        !           123: extern int dslots_load_filled;         /* # filled load delay slots */
        !           124: extern int dslots_jump_total;          /* total # jump related delay slots */
        !           125: extern int dslots_jump_filled;         /* # filled jump delay slots */
        !           126: extern int dslots_number_nops;         /* # of nops needed by previous insn */
        !           127: extern int num_refs[3];                        /* # 1/2/3 word references */
        !           128: extern struct rtx_def *mips_load_reg;  /* register to check for load delay */
        !           129: extern struct rtx_def *mips_load_reg2; /* 2nd reg to check for load delay */
        !           130: extern struct rtx_def *mips_load_reg3; /* 3rd reg to check for load delay */
        !           131: extern struct rtx_def *mips_load_reg4; /* 4th reg to check for load delay */
        !           132: 
        !           133: /* Functions within mips.c that we reference.  */
        !           134: 
        !           135: extern void            abort_with_insn ();
        !           136: extern int             arith32_operand ();
        !           137: extern int             arith_operand ();
        !           138: extern int             cmp_op ();
        !           139: extern int             cmp2_op ();
        !           140: extern long            compute_frame_size ();
        !           141: extern int             epilogue_reg_mentioned_p ();
        !           142: extern void            expand_block_move ();
        !           143: extern int             equality_op ();
        !           144: extern int             fcmp_op ();
        !           145: extern void            final_prescan_insn ();
        !           146: extern int             fpsw_register_operand ();
        !           147: extern struct rtx_def *        function_arg ();
        !           148: extern void            function_arg_advance ();
        !           149: extern int             function_arg_partial_nregs ();
        !           150: extern void            function_epilogue ();
        !           151: extern void            function_prologue ();
        !           152: extern void            gen_conditional_branch ();
        !           153: extern struct rtx_def * gen_int_relational ();
        !           154: extern void            init_cumulative_args ();
        !           155: extern int             large_int ();
        !           156: extern int             md_register_operand ();
        !           157: extern int             mips_address_cost ();
        !           158: extern void            mips_asm_file_end ();
        !           159: extern void            mips_asm_file_start ();
        !           160: extern int             mips_const_double_ok ();
        !           161: extern void            mips_count_memory_refs ();
        !           162: extern int             mips_debugger_offset ();
        !           163: extern void            mips_declare_object ();
        !           164: extern int             mips_epilogue_delay_slots ();
        !           165: extern void            mips_expand_epilogue ();
        !           166: extern void            mips_expand_prologue ();
        !           167: extern char           *mips_fill_delay_slot ();
        !           168: extern char           *mips_move_1word ();
        !           169: extern char           *mips_move_2words ();
        !           170: extern void            mips_output_double ();
        !           171: extern int             mips_output_external ();
        !           172: extern void            mips_output_float ();
        !           173: extern void            mips_output_filename ();
        !           174: extern void            mips_output_lineno ();
        !           175: extern char           *output_block_move ();
        !           176: extern void            override_options ();
        !           177: extern int             pc_or_label_operand ();
        !           178: extern void            print_operand_address ();
        !           179: extern void            print_operand ();
        !           180: extern void            print_options ();
        !           181: extern int             reg_or_0_operand ();
        !           182: extern int             simple_epilogue_p ();
        !           183: extern int             simple_memory_operand ();
        !           184: extern int             small_int ();
        !           185: extern void            trace();
        !           186: extern int             uns_arith_operand ();
        !           187: extern int             uns_cmp_op ();
        !           188: 
        !           189: /* Recognition functions that return if a condition is true.  */
        !           190: extern int             address_operand ();
        !           191: extern int             const_double_operand ();
        !           192: extern int             const_int_operand ();
        !           193: extern int             general_operand ();
        !           194: extern int             immediate_operand ();
        !           195: extern int             memory_address_p ();
        !           196: extern int             memory_operand ();
        !           197: extern int             nonimmediate_operand ();
        !           198: extern int             nonmemory_operand ();
        !           199: extern int             register_operand ();
        !           200: extern int             scratch_operand ();
        !           201: 
        !           202: /* Functions to change what output section we are using.  */
        !           203: extern void            data_section ();
        !           204: extern void            rdata_section ();
        !           205: extern void            readonly_data_section ();
        !           206: extern void            sdata_section ();
        !           207: extern void            text_section ();
        !           208: 
        !           209: /* Functions in the rest of the compiler that we reference.  */
        !           210: extern void            abort_with_insn ();
        !           211: extern void            debug_rtx ();
        !           212: extern void            fatal_io_error ();
        !           213: extern int             get_frame_size ();
        !           214: extern int             offsettable_address_p ();
        !           215: extern void            output_address ();
        !           216: extern char           *permalloc ();
        !           217: extern int             reg_mentioned_p ();
        !           218: 
        !           219: /* Functions in the standard library that we reference.  */
        !           220: extern int             atoi ();
        !           221: extern char           *getenv ();
        !           222: extern char           *mktemp ();
        !           223: 
        !           224: 
        !           225: /* Stubs for half-pic support if not OSF/1 reference platform.  */
        !           226: 
        !           227: #ifndef HALF_PIC_P
        !           228: #define HALF_PIC_P() 0
        !           229: #define HALF_PIC_NUMBER_PTRS 0
        !           230: #define HALF_PIC_NUMBER_REFS 0
        !           231: #define HALF_PIC_ENCODE(DECL)
        !           232: #define HALF_PIC_DECLARE(NAME)
        !           233: #define HALF_PIC_INIT()        error ("half-pic init called on systems that don't support it.")
        !           234: #define HALF_PIC_ADDRESS_P(X) 0
        !           235: #define HALF_PIC_PTR(X) X
        !           236: #define HALF_PIC_FINISH(STREAM)
        !           237: #endif
        !           238: 
        !           239: 
        !           240: /* Run-time compilation parameters selecting different hardware subsets.  */
        !           241: 
        !           242: /* Macros used in the machine description to test the flags.  */
        !           243: 
        !           244:                                        /* Bits for real switches */
        !           245: #define MASK_INT64     0x00000001      /* ints are 64 bits */
        !           246: #define MASK_LONG64    0x00000002      /* longs are 64 bits */
        !           247: #define MASK_LLONG128  0x00000004      /* long longs are 128 bits */
        !           248: #define MASK_GPOPT     0x00000008      /* Optimize for global pointer */
        !           249: #define MASK_GAS       0x00000010      /* Gas used instead of MIPS as */
        !           250: #define MASK_NAME_REGS 0x00000020      /* Use MIPS s/w reg name convention */
        !           251: #define MASK_STATS     0x00000040      /* print statistics to stderr */
        !           252: #define MASK_MEMCPY    0x00000080      /* call memcpy instead of inline code*/
        !           253: #define MASK_SOFT_FLOAT        0x00000100      /* software floating point */
        !           254: #define MASK_FLOAT64   0x00000200      /* fp registers are 64 bits */
        !           255: #define MASK_ABICALLS  0x00000400      /* emit .abicalls/.cprestore/.cpload */
        !           256: #define MASK_HALF_PIC  0x00000800      /* Emit OSF-style pic refs to externs*/
        !           257: #define MASK_LONG_CALLS        0x00001000      /* Always call through a register */
        !           258: #define MASK_UNUSED1   0x00002000
        !           259: #define MASK_UNUSED2   0x00004000
        !           260: #define MASK_UNUSED3   0x00008000
        !           261: #define MASK_UNUSED4   0x00010000
        !           262: #define MASK_UNUSED5   0x00020000
        !           263: #define MASK_UNUSED6   0x00040000
        !           264: #define MASK_UNUSED7   0x00080000
        !           265: 
        !           266:                                        /* Dummy switches used only in spec's*/
        !           267: #define MASK_MIPS_TFILE        0x00000000      /* flag for mips-tfile usage */
        !           268: 
        !           269:                                        /* Debug switches, not documented */
        !           270: #define MASK_DEBUG     0x40000000      /* Eliminate version # in .s file */
        !           271: #define MASK_DEBUG_A   0x20000000      /* don't allow <label>($reg) addrs */
        !           272: #define MASK_DEBUG_B   0x10000000      /* GO_IF_LEGITIMATE_ADDRESS debug */
        !           273: #define MASK_DEBUG_C   0x08000000      /* don't expand seq, etc. */
        !           274: #define MASK_DEBUG_D   0x04000000      /* don't do define_split's */
        !           275: #define MASK_DEBUG_E   0x02000000      /* function_arg debug */
        !           276: #define MASK_DEBUG_F   0x01000000      /* don't try to suppress load nop's */
        !           277: #define MASK_DEBUG_G   0x00800000      /* don't support 64 bit arithmetic */
        !           278: #define MASK_DEBUG_H   0x00400000      /* allow ints in FP registers */
        !           279: #define MASK_DEBUG_I   0x00200000      /* unused */
        !           280: #define MASK_DEBUG_J   0x00100000      /* unused */
        !           281: 
        !           282:                                        /* r4000 64 bit sizes */
        !           283: #define TARGET_INT64           (target_flags & MASK_INT64)
        !           284: #define TARGET_LONG64          (target_flags & MASK_LONG64)
        !           285: #define TARGET_LLONG128                (target_flags & MASK_LLONG128)
        !           286: #define TARGET_FLOAT64         (target_flags & MASK_FLOAT64)
        !           287: 
        !           288:                                        /* Mips vs. GNU assembler */
        !           289: #define TARGET_GAS             (target_flags & MASK_GAS)
        !           290: #define TARGET_UNIX_ASM                (!TARGET_GAS)
        !           291: #define TARGET_MIPS_AS         TARGET_UNIX_ASM
        !           292: 
        !           293:                                        /* Debug Mode */
        !           294: #define TARGET_DEBUG_MODE      (target_flags & MASK_DEBUG)
        !           295: #define TARGET_DEBUG_A_MODE    (target_flags & MASK_DEBUG_A)
        !           296: #define TARGET_DEBUG_B_MODE    (target_flags & MASK_DEBUG_B)
        !           297: #define TARGET_DEBUG_C_MODE    (target_flags & MASK_DEBUG_C)
        !           298: #define TARGET_DEBUG_D_MODE    (target_flags & MASK_DEBUG_D)
        !           299: #define TARGET_DEBUG_E_MODE    (target_flags & MASK_DEBUG_E)
        !           300: #define TARGET_DEBUG_F_MODE    (target_flags & MASK_DEBUG_F)
        !           301: #define TARGET_DEBUG_G_MODE    (target_flags & MASK_DEBUG_G)
        !           302: #define TARGET_DEBUG_H_MODE    (target_flags & MASK_DEBUG_H)
        !           303: #define TARGET_DEBUG_I_MODE    (target_flags & MASK_DEBUG_I)
        !           304: #define TARGET_DEBUG_J_MODE    (target_flags & MASK_DEBUG_J)
        !           305: 
        !           306:                                        /* Reg. Naming in .s ($21 vs. $a0) */
        !           307: #define TARGET_NAME_REGS       (target_flags & MASK_NAME_REGS)
        !           308: 
        !           309:                                        /* Optimize for Sdata/Sbss */
        !           310: #define TARGET_GP_OPT          (target_flags & MASK_GPOPT)
        !           311: 
        !           312:                                        /* print program statistics */
        !           313: #define TARGET_STATS           (target_flags & MASK_STATS)
        !           314: 
        !           315:                                        /* call memcpy instead of inline code */
        !           316: #define TARGET_MEMCPY          (target_flags & MASK_MEMCPY)
        !           317: 
        !           318:                                        /* .abicalls, etc from Pyramid V.4 */
        !           319: #define TARGET_ABICALLS                (target_flags & MASK_ABICALLS)
        !           320: 
        !           321:                                        /* OSF pic references to externs */
        !           322: #define TARGET_HALF_PIC                (target_flags & MASK_HALF_PIC)
        !           323: 
        !           324:                                        /* software floating point */
        !           325: #define TARGET_SOFT_FLOAT      (target_flags & MASK_SOFT_FLOAT)
        !           326: #define TARGET_HARD_FLOAT      (! TARGET_SOFT_FLOAT)
        !           327: 
        !           328:                                        /* always call through a register */
        !           329: #define TARGET_LONG_CALLS      (target_flags & MASK_LONG_CALLS)
        !           330: 
        !           331: /* Macro to define tables used to set the flags.
        !           332:    This is a list in braces of pairs in braces,
        !           333:    each pair being { "NAME", VALUE }
        !           334:    where VALUE is the bits to set or minus the bits to clear.
        !           335:    An empty string NAME is used to identify the default VALUE.  */
        !           336: 
        !           337: #define TARGET_SWITCHES                                                        \
        !           338: {                                                                      \
        !           339:   {"int64",              MASK_INT64 | MASK_LONG64},                    \
        !           340:   {"long64",             MASK_LONG64},                                 \
        !           341:   {"longlong128",        MASK_INT64 | MASK_LONG64 | MASK_LLONG128},    \
        !           342:   {"mips-as",           -MASK_GAS},                                    \
        !           343:   {"gas",                MASK_GAS},                                    \
        !           344:   {"rnames",             MASK_NAME_REGS},                              \
        !           345:   {"no-rnames",                 -MASK_NAME_REGS},                              \
        !           346:   {"gpOPT",              MASK_GPOPT},                                  \
        !           347:   {"gpopt",              MASK_GPOPT},                                  \
        !           348:   {"no-gpOPT",          -MASK_GPOPT},                                  \
        !           349:   {"no-gpopt",          -MASK_GPOPT},                                  \
        !           350:   {"stats",              MASK_STATS},                                  \
        !           351:   {"no-stats",          -MASK_STATS},                                  \
        !           352:   {"memcpy",             MASK_MEMCPY},                                 \
        !           353:   {"no-memcpy",                 -MASK_MEMCPY},                                 \
        !           354:   {"mips-tfile",         MASK_MIPS_TFILE},                             \
        !           355:   {"no-mips-tfile",     -MASK_MIPS_TFILE},                             \
        !           356:   {"soft-float",         MASK_SOFT_FLOAT},                             \
        !           357:   {"hard-float",        -MASK_SOFT_FLOAT},                             \
        !           358:   {"fp64",               MASK_FLOAT64},                                \
        !           359:   {"fp32",              -MASK_FLOAT64},                                \
        !           360:   {"abicalls",           MASK_ABICALLS},                               \
        !           361:   {"no-abicalls",       -MASK_ABICALLS},                               \
        !           362:   {"half-pic",           MASK_HALF_PIC},                               \
        !           363:   {"no-half-pic",       -MASK_HALF_PIC},                               \
        !           364:   {"long-calls",         MASK_LONG_CALLS},                             \
        !           365:   {"no-long-calls",     -MASK_LONG_CALLS},                             \
        !           366:   {"debug",              MASK_DEBUG},                                  \
        !           367:   {"debuga",             MASK_DEBUG_A},                                \
        !           368:   {"debugb",             MASK_DEBUG_B},                                \
        !           369:   {"debugc",             MASK_DEBUG_C},                                \
        !           370:   {"debugd",             MASK_DEBUG_D},                                \
        !           371:   {"debuge",             MASK_DEBUG_E},                                \
        !           372:   {"debugf",             MASK_DEBUG_F},                                \
        !           373:   {"debugg",             MASK_DEBUG_G},                                \
        !           374:   {"debugh",             MASK_DEBUG_H},                                \
        !           375:   {"debugi",             MASK_DEBUG_I},                                \
        !           376:   {"debugj",             MASK_DEBUG_J},                                \
        !           377:   {"",                   TARGET_DEFAULT | TARGET_CPU_DEFAULT}          \
        !           378: }
        !           379: 
        !           380: /* Default target_flags if no switches are specified  */
        !           381: 
        !           382: #ifndef TARGET_DEFAULT
        !           383: #define TARGET_DEFAULT 0
        !           384: #endif
        !           385: 
        !           386: #ifndef TARGET_CPU_DEFAULT
        !           387: #define TARGET_CPU_DEFAULT 0
        !           388: #endif
        !           389: 
        !           390: /* This macro is similar to `TARGET_SWITCHES' but defines names of
        !           391:    command options that have values.  Its definition is an
        !           392:    initializer with a subgrouping for each command option.
        !           393: 
        !           394:    Each subgrouping contains a string constant, that defines the
        !           395:    fixed part of the option name, and the address of a variable. 
        !           396:    The variable, type `char *', is set to the variable part of the
        !           397:    given option if the fixed part matches.  The actual option name
        !           398:    is made by appending `-m' to the specified name.
        !           399: 
        !           400:    Here is an example which defines `-mshort-data-NUMBER'.  If the
        !           401:    given option is `-mshort-data-512', the variable `m88k_short_data'
        !           402:    will be set to the string `"512"'.
        !           403: 
        !           404:        extern char *m88k_short_data;
        !           405:        #define TARGET_OPTIONS { { "short-data-", &m88k_short_data } }  */
        !           406: 
        !           407: #define TARGET_OPTIONS                                                 \
        !           408: {                                                                      \
        !           409:   { "cpu=",    &mips_cpu_string        },                              \
        !           410:   { "ips",     &mips_isa_string        }                               \
        !           411: }
        !           412: 
        !           413: /* Macros to decide whether certain features are available or not,
        !           414:    depending on the instruction set architecture level.  */
        !           415: 
        !           416: #define BRANCH_LIKELY_P()      (mips_isa >= 2)
        !           417: #define HAVE_64BIT_P()         (mips_isa >= 3)
        !           418: #define HAVE_SQRT_P()          (mips_isa >= 2)
        !           419: 
        !           420: 
        !           421: /* Switch  Recognition by gcc.c.  Add -G xx support */
        !           422: 
        !           423: #ifdef SWITCH_TAKES_ARG
        !           424: #undef SWITCH_TAKES_ARG
        !           425: #endif
        !           426: 
        !           427: #define SWITCH_TAKES_ARG(CHAR)                                         \
        !           428:   ((CHAR) == 'D' || (CHAR) == 'U' || (CHAR) == 'o'                     \
        !           429:    || (CHAR) == 'e' || (CHAR) == 'T' || (CHAR) == 'u'                  \
        !           430:    || (CHAR) == 'I' || (CHAR) == 'm'                                   \
        !           431:    || (CHAR) == 'L' || (CHAR) == 'A' || (CHAR) == 'G')
        !           432: 
        !           433: /* Sometimes certain combinations of command options do not make sense
        !           434:    on a particular target machine.  You can define a macro
        !           435:    `OVERRIDE_OPTIONS' to take account of this.  This macro, if
        !           436:    defined, is executed once just after all the command options have
        !           437:    been parsed.
        !           438: 
        !           439:    On the MIPS, it is used to handle -G.  We also use it to set up all
        !           440:    of the tables referenced in the other macros.  */
        !           441: 
        !           442: #define OVERRIDE_OPTIONS override_options ()
        !           443: 
        !           444: /* Zero or more C statements that may conditionally modify two
        !           445:    variables `fixed_regs' and `call_used_regs' (both of type `char
        !           446:    []') after they have been initialized from the two preceding
        !           447:    macros.
        !           448: 
        !           449:    This is necessary in case the fixed or call-clobbered registers
        !           450:    depend on target flags.
        !           451: 
        !           452:    You need not define this macro if it has no work to do.
        !           453: 
        !           454:    If the usage of an entire class of registers depends on the target
        !           455:    flags, you may indicate this to GCC by using this macro to modify
        !           456:    `fixed_regs' and `call_used_regs' to 1 for each of the registers in
        !           457:    the classes which should not be used by GCC.  Also define the macro
        !           458:    `REG_CLASS_FROM_LETTER' to return `NO_REGS' if it is called with a
        !           459:    letter for a class that shouldn't be used.
        !           460: 
        !           461:    (However, if this class is not included in `GENERAL_REGS' and all
        !           462:    of the insn patterns whose constraints permit this class are
        !           463:    controlled by target switches, then GCC will automatically avoid
        !           464:    using these registers when the target switches are opposed to
        !           465:    them.)  */
        !           466: 
        !           467: #define CONDITIONAL_REGISTER_USAGE                                     \
        !           468: do                                                                     \
        !           469:   {                                                                    \
        !           470:     if (!TARGET_HARD_FLOAT)                                            \
        !           471:       {                                                                        \
        !           472:        int regno;                                                      \
        !           473:                                                                        \
        !           474:        for (regno = FP_REG_FIRST; regno <= FP_REG_LAST; regno++)       \
        !           475:          fixed_regs[regno] = call_used_regs[regno] = 1;                \
        !           476:       }                                                                        \
        !           477:   }                                                                    \
        !           478: while (0)
        !           479: 
        !           480: 
        !           481: /* Some machines may desire to change what optimizations are
        !           482:    performed for various optimization levels.   This macro, if
        !           483:    defined, is executed once just after the optimization level is
        !           484:    determined and before the remainder of the command options have
        !           485:    been parsed.  Values set in this macro are used as the default
        !           486:    values for the other command line options.
        !           487: 
        !           488:    LEVEL is the optimization level specified; 2 if -O2 is
        !           489:    specified, 1 if -O is specified, and 0 if neither is specified.  */
        !           490: 
        !           491: #define OPTIMIZATION_OPTIONS(LEVEL)                                    \
        !           492: {                                                                      \
        !           493:   if (LEVEL)                                                           \
        !           494:     {                                                                  \
        !           495:       flag_omit_frame_pointer         = TRUE;                          \
        !           496:       flag_schedule_insns_after_reload = TRUE;                         \
        !           497:       target_flags |= MASK_GPOPT;                                      \
        !           498:     }                                                                  \
        !           499: }
        !           500: 
        !           501: 
        !           502: /* Complain about missing specs and predefines that should be defined in each
        !           503:    of the target tm files to override the defaults.  This is mostly a place-
        !           504:    holder until I can get each of the files updated [mm].  */
        !           505: 
        !           506: #if defined(OSF_OS) \
        !           507:     || defined(DECSTATION) \
        !           508:     || defined(SGI_TARGET) \
        !           509:     || defined(MIPS_NEWS) \
        !           510:     || defined(MIPS_SYSV) \
        !           511:     || defined(MIPS_SVR4) \
        !           512:     || defined(MIPS_BSD43)
        !           513: 
        !           514: #ifndef CPP_PREDEFINES
        !           515:        #error "Define CPP_PREDEFINES in the appropriate tm.h file"
        !           516: #endif
        !           517: 
        !           518: #ifndef CPP_SPEC
        !           519:        #error "Define CPP_SPEC in the appropriate tm.h file"
        !           520: #endif
        !           521: 
        !           522: #ifndef LINK_SPEC
        !           523:        #error "Define LINK_SPEC in the appropriate tm.h file"
        !           524: #endif
        !           525: 
        !           526: #ifndef LIB_SPEC
        !           527:        #error "Define LIB_SPEC in the appropriate tm.h file"
        !           528: #endif
        !           529: 
        !           530: #ifndef STARTFILE_SPEC
        !           531:        #error "Define STARTFILE_SPEC in the appropriate tm.h file"
        !           532: #endif
        !           533: 
        !           534: #ifndef MACHINE_TYPE
        !           535:        #error "Define MACHINE_TYPE in the appropriate tm.h file"
        !           536: #endif
        !           537: #endif
        !           538: 
        !           539: /* Tell collect what flags to pass to nm.  */
        !           540: #ifndef NM_FLAGS
        !           541: #define NM_FLAGS "-Bp"
        !           542: #endif
        !           543: 
        !           544: 
        !           545: /* Names to predefine in the preprocessor for this target machine.  */
        !           546: 
        !           547: #ifndef CPP_PREDEFINES
        !           548: #define CPP_PREDEFINES "-Dmips -Dunix -Dhost_mips -DMIPSEB -DR3000 -DSYSTYPE_BSD43 \
        !           549: -D_mips -D_unix -D_host_mips -D_MIPSEB -D_R3000 -D_SYSTYPE_BSD43 \
        !           550: -Asystem(unix) -Asystem(bsd) -Acpu(mips) -Amachine(mips)"
        !           551: #endif
        !           552: 
        !           553: /* Extra switches sometimes passed to the assembler.  */
        !           554: 
        !           555: #ifndef ASM_SPEC
        !           556: #define ASM_SPEC "\
        !           557: %{!mgas: \
        !           558:        %{!mrnames: %{!.s:-nocpp} %{.s: %{cpp} %{nocpp}}} \
        !           559:        %{pipe: %e-pipe is not supported.} \
        !           560:        %{EB} %{!EB:-EB} \
        !           561:        %{EL: %e-EL not supported} \
        !           562:        %{mips1} %{mips2} %{mips3} \
        !           563:        %{noasmopt:-O0} \
        !           564:        %{!noasmopt:%{O:-O2} %{O1:-O2} %{O2:-O2} %{O3:-O3}} \
        !           565:        %{g} %{g0} %{g1} %{g2} %{g3} %{v} %{K} \
        !           566:        %{ggdb:-g} %{ggdb0:-g0} %{ggdb1:-g1} %{ggdb2:-g2} %{ggdb3:-g3} \
        !           567:        %{gstabs:-g} %{gstabs0:-g0} %{gstabs1:-g1} %{gstabs2:-g2} %{gstabs3:-g3} \
        !           568:        %{gstabs+:-g} %{gstabs+0:-g0} %{gstabs+1:-g1} %{gstabs+2:-g2} %{gstabs+3:-g3} \
        !           569:        %{gcoff:-g} %{gstabs0:-g0} %{gcoff1:-g1} %{gcoff2:-g2} %{gcoff3:-g3}} \
        !           570: %{G*}"
        !           571: 
        !           572: #endif                         /* ASM_SPEC */
        !           573: 
        !           574: /* Specify to run a post-processor, mips-tfile after the assembler
        !           575:    has run to stuff the mips debug information into the object file.
        !           576:    This is needed because the $#!%^ MIPS assembler provides no way
        !           577:    of specifying such information in the assembly file.  If we are
        !           578:    cross compiling, disable mips-tfile unless the user specifies
        !           579:    -mmips-tfile.  */
        !           580: 
        !           581: #ifndef ASM_FINAL_SPEC
        !           582: #if ((TARGET_CPU_DEFAULT | TARGET_DEFAULT) & MASK_GAS) != 0 || defined (CROSS_COMPILE)
        !           583:                                /* GAS */
        !           584: #define ASM_FINAL_SPEC "\
        !           585: %{mmips-as: %{!mno-mips-tfile: \
        !           586:        \n mips-tfile %{v*: -v} \
        !           587:                %{K: -I %b.o~} \
        !           588:                %{!K: %{save-temps: -I %b.o~}} \
        !           589:                %{c:%W{o*}%{!o*:-o %b.o}}%{!c:-o %U.o} \
        !           590:                %{.s:%i} %{!.s:%g.s}}}"
        !           591: 
        !           592: #else                          /* not GAS, clean up after MIPS assembler */
        !           593: #define ASM_FINAL_SPEC "\
        !           594: %{!mgas: %{!mno-mips-tfile: \
        !           595:        \n mips-tfile %{v*: -v} \
        !           596:                %{K: -I %b.o~} \
        !           597:                %{!K: %{save-temps: -I %b.o~}} \
        !           598:                %{c:%W{o*}%{!o*:-o %b.o}}%{!c:-o %U.o} \
        !           599:                %{.s:%i} %{!.s:%g.s}}}"
        !           600: 
        !           601: #endif /* GAS */
        !           602: #endif /* ASM_FINAL_SPEC */
        !           603: 
        !           604: /* Redefinition of libraries used.  Mips doesn't support normal
        !           605:    UNIX style profiling via calling _mcount.  It does offer
        !           606:    profiling that samples the PC, so do what we can... */
        !           607: 
        !           608: #ifndef LIB_SPEC
        !           609: #define LIB_SPEC "%{pg:-lprof1} %{p:-lprof1} -lc"
        !           610: #endif
        !           611: 
        !           612: /* Extra switches sometimes passed to the linker.  */
        !           613: 
        !           614: #ifndef LINK_SPEC
        !           615: #define LINK_SPEC "\
        !           616: %{G*} \
        !           617: %{!mgas: \
        !           618:        %{pipe: %e-pipe is not supported.} \
        !           619:        %{EB} %{!EB:-EB} \
        !           620:        %{EL: %e-EL not supported} \
        !           621:        %{mips1} %{mips2} %{mips3} \
        !           622:        %{bestGnum} %{shared} %{non_shared}}"
        !           623: #endif                         /* LINK_SPEC defined */
        !           624: 
        !           625: /* Specs for the compiler proper */
        !           626: 
        !           627: #ifndef CC1_SPEC
        !           628: #define CC1_SPEC "\
        !           629: %{gline:%{!g:%{!g0:%{!g1:%{!g2: -g1}}}}} \
        !           630: %{G*} \
        !           631: %{pic-none:   -mno-half-pic} \
        !           632: %{pic-lib:    -mhalf-pic} \
        !           633: %{pic-extern: -mhalf-pic} \
        !           634: %{pic-calls:  -mhalf-pic} \
        !           635: %{save-temps: }"
        !           636: #endif
        !           637: 
        !           638: /* Preprocessor specs */
        !           639: 
        !           640: #ifndef CPP_SPEC
        !           641: #define CPP_SPEC "\
        !           642: %{.cc: -D__LANGUAGE_C_PLUS_PLUS -D_LANGUAGE_C_PLUS_PLUS} \
        !           643: %{.cxx:        -D__LANGUAGE_C_PLUS_PLUS -D_LANGUAGE_C_PLUS_PLUS} \
        !           644: %{.C:  -D__LANGUAGE_C_PLUS_PLUS -D_LANGUAGE_C_PLUS_PLUS} \
        !           645: %{.m:  -D__LANGUAGE_OBJECTIVE_C -D_LANGUAGE_OBJECTIVE_C} \
        !           646: %{.S:  -D__LANGUAGE_ASSEMBLY -D_LANGUAGE_ASSEMBLY %{!ansi:-DLANGUAGE_ASSEMBLY}} \
        !           647: %{.s:  -D__LANGUAGE_ASSEMBLY -D_LANGUAGE_ASSEMBLY %{!ansi:-DLANGUAGE_ASSEMBLY}} \
        !           648: %{!.S:%{!.s:   -D__LANGUAGE_C -D_LANGUAGE_C %{!ansi:-DLANGUAGE_C}}}"
        !           649: #endif
        !           650: 
        !           651: /* If defined, this macro is an additional prefix to try after
        !           652:    `STANDARD_EXEC_PREFIX'.  */
        !           653: 
        !           654: #ifndef MD_EXEC_PREFIX
        !           655: #define MD_EXEC_PREFIX "/usr/lib/cmplrs/cc/"
        !           656: #endif
        !           657: 
        !           658: #ifndef MD_STARTFILE_PREFIX
        !           659: #define MD_STARTFILE_PREFIX "/usr/lib/cmplrs/cc/"
        !           660: #endif
        !           661: 
        !           662: 
        !           663: /* Print subsidiary information on the compiler version in use.  */
        !           664: 
        !           665: #define MIPS_VERSION "[AL 1.1, MM 40]"
        !           666: 
        !           667: #ifndef MACHINE_TYPE
        !           668: #define MACHINE_TYPE "BSD Mips"
        !           669: #endif
        !           670: 
        !           671: #ifndef TARGET_VERSION_INTERNAL
        !           672: #define TARGET_VERSION_INTERNAL(STREAM)                                        \
        !           673:   fprintf (STREAM, " %s %s", MIPS_VERSION, MACHINE_TYPE)
        !           674: #endif
        !           675: 
        !           676: #ifndef TARGET_VERSION
        !           677: #define TARGET_VERSION TARGET_VERSION_INTERNAL (stderr)
        !           678: #endif
        !           679: 
        !           680: 
        !           681: #define SDB_DEBUGGING_INFO             /* generate info for mips-tfile */
        !           682: #define DBX_DEBUGGING_INFO             /* generate stabs (OSF/rose) */
        !           683: #define MIPS_DEBUGGING_INFO            /* MIPS specific debugging info */
        !           684: 
        !           685: #ifndef PREFERRED_DEBUGGING_TYPE       /* assume SDB_DEBUGGING_INFO */
        !           686: #define PREFERRED_DEBUGGING_TYPE ((len > 1 && !strncmp (str, "ggdb", len)) ? DBX_DEBUG : SDB_DEBUG)
        !           687: #endif
        !           688: 
        !           689: /* By default, turn on GDB extensions.  */
        !           690: #define DEFAULT_GDB_EXTENSIONS 1
        !           691: 
        !           692: /* If we are passing smuggling stabs through the MIPS ECOFF object
        !           693:    format, put a comment in front of the .stab<x> operation so
        !           694:    that the MIPS assembler does not choke.  The mips-tfile program
        !           695:    will correctly put the stab into the object file.  */
        !           696: 
        !           697: #define ASM_STABS_OP   ((TARGET_GAS) ? ".stabs" : " #.stabs")
        !           698: #define ASM_STABN_OP   ((TARGET_GAS) ? ".stabn" : " #.stabn")
        !           699: #define ASM_STABD_OP   ((TARGET_GAS) ? ".stabd" : " #.stabd")
        !           700: 
        !           701: /* Forward references to tags are allowed.  */
        !           702: #define SDB_ALLOW_FORWARD_REFERENCES
        !           703: 
        !           704: /* Unknown tags are also allowed.  */
        !           705: #define SDB_ALLOW_UNKNOWN_REFERENCES
        !           706: 
        !           707: /* On Sun 4, this limit is 2048.  We use 1500 to be safe,
        !           708:    since the length can run past this up to a continuation point.  */
        !           709: #define DBX_CONTIN_LENGTH 1500
        !           710: 
        !           711: 
        !           712: /* How to renumber registers for dbx and gdb. */
        !           713: #define DBX_REGISTER_NUMBER(REGNO) mips_dbx_regno[ (REGNO) ]
        !           714: 
        !           715: 
        !           716: /* Overrides for the COFF debug format.  */
        !           717: #define PUT_SDB_SCL(a)                                 \
        !           718: do {                                                   \
        !           719:   extern FILE *asm_out_text_file;                      \
        !           720:   fprintf (asm_out_text_file, "\t.scl\t%d;", (a));     \
        !           721: } while (0)
        !           722: 
        !           723: #define PUT_SDB_INT_VAL(a)                             \
        !           724: do {                                                   \
        !           725:   extern FILE *asm_out_text_file;                      \
        !           726:   fprintf (asm_out_text_file, "\t.val\t%d;", (a));     \
        !           727: } while (0)
        !           728: 
        !           729: #define PUT_SDB_VAL(a)                                 \
        !           730: do {                                                   \
        !           731:   extern FILE *asm_out_text_file;                      \
        !           732:   fputs ("\t.val\t", asm_out_text_file);               \
        !           733:   output_addr_const (asm_out_text_file, (a));          \
        !           734:   fputc (';', asm_out_text_file);                      \
        !           735: } while (0)
        !           736: 
        !           737: #define PUT_SDB_DEF(a)                                 \
        !           738: do {                                                   \
        !           739:   extern FILE *asm_out_text_file;                      \
        !           740:   fprintf (asm_out_text_file, "\t%s.def\t",            \
        !           741:           (TARGET_GAS) ? "" : "#");                    \
        !           742:   ASM_OUTPUT_LABELREF (asm_out_text_file, a);          \
        !           743:   fputc (';', asm_out_text_file);                      \
        !           744: } while (0)
        !           745: 
        !           746: #define PUT_SDB_PLAIN_DEF(a)                           \
        !           747: do {                                                   \
        !           748:   extern FILE *asm_out_text_file;                      \
        !           749:   fprintf (asm_out_text_file, "\t%s.def\t.%s;",                \
        !           750:           (TARGET_GAS) ? "" : "#", (a));               \
        !           751: } while (0)
        !           752: 
        !           753: #define PUT_SDB_ENDEF                                  \
        !           754: do {                                                   \
        !           755:   extern FILE *asm_out_text_file;                      \
        !           756:   fprintf (asm_out_text_file, "\t.endef\n");           \
        !           757: } while (0)
        !           758: 
        !           759: #define PUT_SDB_TYPE(a)                                        \
        !           760: do {                                                   \
        !           761:   extern FILE *asm_out_text_file;                      \
        !           762:   fprintf (asm_out_text_file, "\t.type\t0x%x;", (a));  \
        !           763: } while (0)
        !           764: 
        !           765: #define PUT_SDB_SIZE(a)                                        \
        !           766: do {                                                   \
        !           767:   extern FILE *asm_out_text_file;                      \
        !           768:   fprintf (asm_out_text_file, "\t.size\t%d;", (a));    \
        !           769: } while (0)
        !           770: 
        !           771: #define PUT_SDB_DIM(a)                                 \
        !           772: do {                                                   \
        !           773:   extern FILE *asm_out_text_file;                      \
        !           774:   fprintf (asm_out_text_file, "\t.dim\t%d;", (a));     \
        !           775: } while (0)
        !           776: 
        !           777: #ifndef PUT_SDB_START_DIM
        !           778: #define PUT_SDB_START_DIM                              \
        !           779: do {                                                   \
        !           780:   extern FILE *asm_out_text_file;                      \
        !           781:   fprintf (asm_out_text_file, "\t.dim\t");             \
        !           782: } while (0)
        !           783: #endif
        !           784: 
        !           785: #ifndef PUT_SDB_NEXT_DIM
        !           786: #define PUT_SDB_NEXT_DIM(a)                            \
        !           787: do {                                                   \
        !           788:   extern FILE *asm_out_text_file;                      \
        !           789:   fprintf (asm_out_text_file, "%d,", a);               \
        !           790: } while (0)
        !           791: #endif
        !           792: 
        !           793: #ifndef PUT_SDB_LAST_DIM
        !           794: #define PUT_SDB_LAST_DIM(a)                            \
        !           795: do {                                                   \
        !           796:   extern FILE *asm_out_text_file;                      \
        !           797:   fprintf (asm_out_text_file, "%d;", a);               \
        !           798: } while (0)
        !           799: #endif
        !           800: 
        !           801: #define PUT_SDB_TAG(a)                                 \
        !           802: do {                                                   \
        !           803:   extern FILE *asm_out_text_file;                      \
        !           804:   fprintf (asm_out_text_file, "\t.tag\t");             \
        !           805:   ASM_OUTPUT_LABELREF (asm_out_text_file, a);          \
        !           806:   fputc (';', asm_out_text_file);                      \
        !           807: } while (0)
        !           808: 
        !           809: /* For block start and end, we create labels, so that
        !           810:    later we can figure out where the correct offset is.
        !           811:    The normal .ent/.end serve well enough for functions,
        !           812:    so those are just commented out.  */
        !           813: 
        !           814: #define PUT_SDB_BLOCK_START(LINE)                      \
        !           815: do {                                                   \
        !           816:   extern FILE *asm_out_text_file;                      \
        !           817:   fprintf (asm_out_text_file,                          \
        !           818:           "$Lb%d:\n\t%s.begin\t$Lb%d\t%d\n",           \
        !           819:           sdb_label_count,                             \
        !           820:           (TARGET_GAS) ? "" : "#",                     \
        !           821:           sdb_label_count,                             \
        !           822:           (LINE));                                     \
        !           823:   sdb_label_count++;                                   \
        !           824: } while (0)
        !           825: 
        !           826: #define PUT_SDB_BLOCK_END(LINE)                                \
        !           827: do {                                                   \
        !           828:   extern FILE *asm_out_text_file;                      \
        !           829:   fprintf (asm_out_text_file,                          \
        !           830:           "$Le%d:\n\t%s.bend\t$Le%d\t%d\n",            \
        !           831:           sdb_label_count,                             \
        !           832:           (TARGET_GAS) ? "" : "#",                     \
        !           833:           sdb_label_count,                             \
        !           834:           (LINE));                                     \
        !           835:   sdb_label_count++;                                   \
        !           836: } while (0)
        !           837: 
        !           838: #define PUT_SDB_FUNCTION_START(LINE)
        !           839: 
        !           840: #define PUT_SDB_FUNCTION_END(LINE)
        !           841: 
        !           842: #define PUT_SDB_EPILOGUE_END(NAME)
        !           843: 
        !           844: #define SDB_GENERATE_FAKE(BUFFER, NUMBER) \
        !           845:   sprintf ((BUFFER), ".%dfake", (NUMBER));
        !           846: 
        !           847: /* Correct the offset of automatic variables and arguments.  Note that
        !           848:    the MIPS debug format wants all automatic variables and arguments
        !           849:    to be in terms of the virtual frame pointer (stack pointer before
        !           850:    any adjustment in the function), while the MIPS 3.0 linker wants
        !           851:    the frame pointer to be the stack pointer after the initial
        !           852:    adjustment.  */
        !           853: 
        !           854: #define DEBUGGER_AUTO_OFFSET(X)                mips_debugger_offset (X, 0)
        !           855: #define DEBUGGER_ARG_OFFSET(OFFSET, X) mips_debugger_offset (X, OFFSET)
        !           856: 
        !           857: 
        !           858: /* Tell collect that the object format is ECOFF */
        !           859: #ifndef OBJECT_FORMAT_ROSE
        !           860: #define OBJECT_FORMAT_COFF     /* Object file looks like COFF */
        !           861: #define EXTENDED_COFF          /* ECOFF, not normal coff */
        !           862: #endif
        !           863: 
        !           864: #if 0 /* These definitions normally have no effect because
        !           865:         MIPS systems define USE_COLLECT2, so
        !           866:         assemble_constructor does nothing anyway.  */
        !           867: 
        !           868: /* Don't use the default definitions, because we don't have gld.
        !           869:    Also, we don't want stabs when generating ECOFF output.
        !           870:    Instead we depend on collect to handle these.  */
        !           871: 
        !           872: #define ASM_OUTPUT_CONSTRUCTOR(file, name)
        !           873: #define ASM_OUTPUT_DESTRUCTOR(file, name)
        !           874: 
        !           875: #endif /* 0 */
        !           876: 
        !           877: /* Target machine storage layout */
        !           878: 
        !           879: /* Define this if most significant bit is lowest numbered
        !           880:    in instructions that operate on numbered bit-fields.
        !           881: */
        !           882: #define BITS_BIG_ENDIAN 0
        !           883: 
        !           884: /* Define this if most significant byte of a word is the lowest numbered. */
        !           885: #ifndef BYTES_BIG_ENDIAN
        !           886: #ifndef DECSTATION
        !           887: #define BYTES_BIG_ENDIAN 1
        !           888: #else
        !           889: #define BYTES_BIG_ENDIAN 0
        !           890: #endif
        !           891: #endif
        !           892: 
        !           893: /* Define this if most significant word of a multiword number is the lowest. */
        !           894: #ifndef WORDS_BIG_ENDIAN
        !           895: #ifndef DECSTATION
        !           896: #define WORDS_BIG_ENDIAN 1
        !           897: #else
        !           898: #define WORDS_BIG_ENDIAN 0
        !           899: #endif
        !           900: #endif
        !           901: 
        !           902: /* Define macros to easily access the most and least significant words
        !           903:    without a lot of #ifdef's.  */
        !           904: 
        !           905: #if WORDS_BIG_ENDIAN
        !           906: #define MOST_SIGNIFICANT_WORD  0
        !           907: #define LEAST_SIGNIFICANT_WORD 1
        !           908: 
        !           909: #else
        !           910: #define MOST_SIGNIFICANT_WORD  1
        !           911: #define LEAST_SIGNIFICANT_WORD 0
        !           912: #endif
        !           913: 
        !           914: /* Number of bits in an addressable storage unit */
        !           915: #define BITS_PER_UNIT 8
        !           916: 
        !           917: /* Width in bits of a "word", which is the contents of a machine register.
        !           918:    Note that this is not necessarily the width of data type `int';
        !           919:    if using 16-bit ints on a 68000, this would still be 32.
        !           920:    But on a machine with 16-bit registers, this would be 16.  */
        !           921: #define BITS_PER_WORD 32
        !           922: 
        !           923: /* Width of a word, in units (bytes).  */
        !           924: #define UNITS_PER_WORD 4
        !           925: 
        !           926: /* A C expression for the size in bits of the type `int' on the
        !           927:    target machine.  If you don't define this, the default is one
        !           928:    word.  */
        !           929: #define INT_TYPE_SIZE 32
        !           930: 
        !           931: /* A C expression for the size in bits of the type `short' on the
        !           932:    target machine.  If you don't define this, the default is half a
        !           933:    word.  (If this would be less than one storage unit, it is
        !           934:    rounded up to one unit.)  */
        !           935: #define SHORT_TYPE_SIZE 16
        !           936: 
        !           937: /* A C expression for the size in bits of the type `long' on the
        !           938:    target machine.  If you don't define this, the default is one
        !           939:    word.  */
        !           940: #define LONG_TYPE_SIZE 32
        !           941: 
        !           942: /* A C expression for the size in bits of the type `long long' on the
        !           943:    target machine.  If you don't define this, the default is two
        !           944:    words.  */
        !           945: #define LONG_LONG_TYPE_SIZE 64
        !           946: 
        !           947: /* A C expression for the size in bits of the type `char' on the
        !           948:    target machine.  If you don't define this, the default is one
        !           949:    quarter of a word.  (If this would be less than one storage unit,
        !           950:    it is rounded up to one unit.)  */
        !           951: #define CHAR_TYPE_SIZE BITS_PER_UNIT
        !           952: 
        !           953: /* A C expression for the size in bits of the type `float' on the
        !           954:    target machine.  If you don't define this, the default is one
        !           955:    word.  */
        !           956: #define FLOAT_TYPE_SIZE 32
        !           957: 
        !           958: /* A C expression for the size in bits of the type `double' on the
        !           959:    target machine.  If you don't define this, the default is two
        !           960:    words.  */
        !           961: #define DOUBLE_TYPE_SIZE 64
        !           962: 
        !           963: /* A C expression for the size in bits of the type `long double' on
        !           964:    the target machine.  If you don't define this, the default is two
        !           965:    words.  */
        !           966: #define LONG_DOUBLE_TYPE_SIZE 64
        !           967: 
        !           968: /* Width in bits of a pointer.
        !           969:    See also the macro `Pmode' defined below.  */
        !           970: #define POINTER_SIZE 32
        !           971: 
        !           972: /* Allocation boundary (in *bits*) for storing pointers in memory.  */
        !           973: #define POINTER_BOUNDARY 32
        !           974: 
        !           975: /* Allocation boundary (in *bits*) for storing arguments in argument list.  */
        !           976: #define PARM_BOUNDARY 32
        !           977: 
        !           978: /* Allocation boundary (in *bits*) for the code of a function.  */
        !           979: #define FUNCTION_BOUNDARY 32
        !           980: 
        !           981: /* Alignment of field after `int : 0' in a structure.  */
        !           982: #define EMPTY_FIELD_BOUNDARY 32
        !           983: 
        !           984: /* Every structure's size must be a multiple of this.  */
        !           985: /* 8 is observed right on a DECstation and on riscos 4.02.  */
        !           986: #define STRUCTURE_SIZE_BOUNDARY 8
        !           987: 
        !           988: /* There is no point aligning anything to a rounder boundary than this.  */
        !           989: #define BIGGEST_ALIGNMENT 64
        !           990: 
        !           991: /* Biggest alignment any structure field can require in bits.  */
        !           992: #define BIGGEST_FIELD_ALIGNMENT 64
        !           993: 
        !           994: /* Set this nonzero if move instructions will actually fail to work
        !           995:    when given unaligned data.  */
        !           996: #define STRICT_ALIGNMENT 1
        !           997: 
        !           998: /* Define this if you wish to imitate the way many other C compilers
        !           999:    handle alignment of bitfields and the structures that contain
        !          1000:    them.
        !          1001: 
        !          1002:    The behavior is that the type written for a bitfield (`int',
        !          1003:    `short', or other integer type) imposes an alignment for the
        !          1004:    entire structure, as if the structure really did contain an
        !          1005:    ordinary field of that type.  In addition, the bitfield is placed
        !          1006:    within the structure so that it would fit within such a field,
        !          1007:    not crossing a boundary for it.
        !          1008: 
        !          1009:    Thus, on most machines, a bitfield whose type is written as `int'
        !          1010:    would not cross a four-byte boundary, and would force four-byte
        !          1011:    alignment for the whole structure.  (The alignment used may not
        !          1012:    be four bytes; it is controlled by the other alignment
        !          1013:    parameters.)
        !          1014: 
        !          1015:    If the macro is defined, its definition should be a C expression;
        !          1016:    a nonzero value for the expression enables this behavior.  */
        !          1017: 
        !          1018: #define PCC_BITFIELD_TYPE_MATTERS 1
        !          1019: 
        !          1020: /* If defined, a C expression to compute the alignment given to a
        !          1021:    constant that is being placed in memory.  CONSTANT is the constant
        !          1022:    and ALIGN is the alignment that the object would ordinarily have.
        !          1023:    The value of this macro is used instead of that alignment to align
        !          1024:    the object.
        !          1025: 
        !          1026:    If this macro is not defined, then ALIGN is used.
        !          1027: 
        !          1028:    The typical use of this macro is to increase alignment for string
        !          1029:    constants to be word aligned so that `strcpy' calls that copy
        !          1030:    constants can be done inline.  */
        !          1031: 
        !          1032: #define CONSTANT_ALIGNMENT(EXP, ALIGN)                                 \
        !          1033:   ((TREE_CODE (EXP) == STRING_CST  || TREE_CODE (EXP) == CONSTRUCTOR)  \
        !          1034:    && (ALIGN) < BITS_PER_WORD                                          \
        !          1035:        ? BITS_PER_WORD                                                 \
        !          1036:        : (ALIGN))
        !          1037: 
        !          1038: /* If defined, a C expression to compute the alignment for a static
        !          1039:    variable.  TYPE is the data type, and ALIGN is the alignment that
        !          1040:    the object would ordinarily have.  The value of this macro is used
        !          1041:    instead of that alignment to align the object.
        !          1042: 
        !          1043:    If this macro is not defined, then ALIGN is used.
        !          1044: 
        !          1045:    One use of this macro is to increase alignment of medium-size
        !          1046:    data to make it all fit in fewer cache lines.  Another is to
        !          1047:    cause character arrays to be word-aligned so that `strcpy' calls
        !          1048:    that copy constants to character arrays can be done inline.  */
        !          1049: 
        !          1050: #undef DATA_ALIGNMENT
        !          1051: #define DATA_ALIGNMENT(TYPE, ALIGN)                                    \
        !          1052:   ((((ALIGN) < BITS_PER_WORD)                                          \
        !          1053:     && (TREE_CODE (TYPE) == ARRAY_TYPE                                 \
        !          1054:        || TREE_CODE (TYPE) == UNION_TYPE                               \
        !          1055:        || TREE_CODE (TYPE) == RECORD_TYPE)) ? BITS_PER_WORD : (ALIGN))
        !          1056: 
        !          1057: /* Define this macro if an argument declared as `char' or `short' in a
        !          1058:    prototype should actually be passed as an `int'.  In addition to
        !          1059:    avoiding errors in certain cases of mismatch, it also makes for
        !          1060:    better code on certain machines. */
        !          1061: 
        !          1062: #define PROMOTE_PROTOTYPES
        !          1063: 
        !          1064: /* Define if operations between registers always perform the operation
        !          1065:    on the full register even if a narrower mode is specified.  */
        !          1066: #define WORD_REGISTER_OPERATIONS
        !          1067: 
        !          1068: /* Define if loading in MODE, an integral mode narrower than BITS_PER_WORD
        !          1069:    will either zero-extend or sign-extend.  The value of this macro should
        !          1070:    be the code that says which one of the two operations is implicitly
        !          1071:    done, NIL if none.  */
        !          1072: #define LOAD_EXTEND_OP(MODE) ZERO_EXTEND
        !          1073: 
        !          1074: /* Standard register usage.  */
        !          1075: 
        !          1076: /* Number of actual hardware registers.
        !          1077:    The hardware registers are assigned numbers for the compiler
        !          1078:    from 0 to just below FIRST_PSEUDO_REGISTER.
        !          1079:    All registers that the compiler knows about must be given numbers,
        !          1080:    even those that are not normally considered general registers.
        !          1081: 
        !          1082:    On the Mips, we have 32 integer registers, 32 floating point registers
        !          1083:    and the special registers hi, lo, and fp status.  */
        !          1084: 
        !          1085: #define FIRST_PSEUDO_REGISTER 67
        !          1086: 
        !          1087: /* 1 for registers that have pervasive standard uses
        !          1088:    and are not available for the register allocator.
        !          1089: 
        !          1090:    On the MIPS, see conventions, page D-2  */
        !          1091: 
        !          1092: #define FIXED_REGISTERS                                                        \
        !          1093: {                                                                      \
        !          1094:   1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,                      \
        !          1095:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 1,                      \
        !          1096:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,                      \
        !          1097:   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,                      \
        !          1098:   1, 1, 1                                                              \
        !          1099: }
        !          1100: 
        !          1101: 
        !          1102: /* 1 for registers not available across function calls.
        !          1103:    These must include the FIXED_REGISTERS and also any
        !          1104:    registers that can be used without being saved.
        !          1105:    The latter must include the registers where values are returned
        !          1106:    and the register where structure-value addresses are passed.
        !          1107:    Aside from that, you can include as many other registers as you like.  */
        !          1108: 
        !          1109: #define CALL_USED_REGISTERS                                            \
        !          1110: {                                                                      \
        !          1111:   1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,                      \
        !          1112:   0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1,                      \
        !          1113:   1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,                      \
        !          1114:   1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,                      \
        !          1115:   1, 1, 1                                                              \
        !          1116: }
        !          1117: 
        !          1118: 
        !          1119: /* Internal macros to classify a register number as to whether it's a
        !          1120:    general purpose register, a floating point register, a
        !          1121:    multiply/divide register, or a status register.
        !          1122: 
        !          1123:    The macro FP_CALL_REG_P also allows registers $4 and $6 as floating
        !          1124:    point registers to pass floating point as per MIPS spec. */
        !          1125: 
        !          1126: #define GP_REG_FIRST 0
        !          1127: #define GP_REG_LAST  31
        !          1128: #define GP_REG_NUM   (GP_REG_LAST - GP_REG_FIRST + 1)
        !          1129: #define GP_DBX_FIRST 0
        !          1130: 
        !          1131: #define FP_REG_FIRST 32
        !          1132: #define FP_REG_LAST  63
        !          1133: #define FP_REG_NUM   (FP_REG_LAST - FP_REG_FIRST + 1)
        !          1134: #define FP_DBX_FIRST ((write_symbols == DBX_DEBUG) ? 38 : 32)
        !          1135: 
        !          1136: #define MD_REG_FIRST 64
        !          1137: #define MD_REG_LAST  65
        !          1138: #define MD_REG_NUM   (MD_REG_LAST - MD_REG_FIRST + 1)
        !          1139: 
        !          1140: #define ST_REG_FIRST 66
        !          1141: #define ST_REG_LAST  66
        !          1142: #define ST_REG_NUM   (ST_REG_LAST - ST_REG_FIRST + 1)
        !          1143: 
        !          1144: #define AT_REGNUM      (GP_REG_FIRST + 1)
        !          1145: #define HI_REGNUM      (MD_REG_FIRST + 0)
        !          1146: #define LO_REGNUM      (MD_REG_FIRST + 1)
        !          1147: #define FPSW_REGNUM    ST_REG_FIRST
        !          1148: 
        !          1149: #define GP_REG_P(REGNO) ((unsigned) ((REGNO) - GP_REG_FIRST) < GP_REG_NUM)
        !          1150: #define FP_REG_P(REGNO) ((unsigned) ((REGNO) - FP_REG_FIRST) < FP_REG_NUM)
        !          1151: #define MD_REG_P(REGNO) ((unsigned) ((REGNO) - MD_REG_FIRST) < MD_REG_NUM)
        !          1152: #define ST_REG_P(REGNO) ((REGNO) == ST_REG_FIRST)
        !          1153: 
        !          1154: #define FP_CALL_REG_P(REGNO)                                   \
        !          1155:   (FP_REG_P (REGNO)                                            \
        !          1156:    || (REGNO) == (4 + GP_REG_FIRST)                            \
        !          1157:    || (REGNO) == (6 + GP_REG_FIRST))
        !          1158: 
        !          1159: /* Return number of consecutive hard regs needed starting at reg REGNO
        !          1160:    to hold something of mode MODE.
        !          1161:    This is ordinarily the length in words of a value of mode MODE
        !          1162:    but can be less for certain modes in special long registers.
        !          1163: 
        !          1164:    On the MIPS, all general registers are one word long.  Except on
        !          1165:    the R4000 with the FR bit set, the floating point uses register
        !          1166:    pairs, with the second register not being allocatable.  */
        !          1167: 
        !          1168: #define HARD_REGNO_NREGS(REGNO, MODE)                                  \
        !          1169:   (! FP_REG_P (REGNO)                                                  \
        !          1170:        ? ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD) \
        !          1171:        : (((GET_MODE_SIZE (MODE) + (2*UNITS_PER_WORD) - 1) / (2*UNITS_PER_WORD)) \
        !          1172:                << (TARGET_FLOAT64 == 0)))
        !          1173: 
        !          1174: /* Value is 1 if hard register REGNO can hold a value of machine-mode
        !          1175:    MODE.  Require that DImode and DFmode be in even registers.  For
        !          1176:    DImode, this makes some of the insns easier to write, since you
        !          1177:    don't have to worry about a DImode value in registers 3 & 4,
        !          1178:    producing a result in 4 & 5.
        !          1179: 
        !          1180:    To make the code simpler HARD_REGNO_MODE_OK now just references an
        !          1181:    array built in override_options.  Because machmodes.h is not yet
        !          1182:    included before this file is processed, the MODE bound can't be
        !          1183:    expressed here.  */
        !          1184: 
        !          1185: extern char mips_hard_regno_mode_ok[][FIRST_PSEUDO_REGISTER];
        !          1186: 
        !          1187: #define HARD_REGNO_MODE_OK(REGNO, MODE)                                        \
        !          1188:   mips_hard_regno_mode_ok[ (int)(MODE) ][ (REGNO) ]
        !          1189: 
        !          1190: /* Value is 1 if it is a good idea to tie two pseudo registers
        !          1191:    when one has mode MODE1 and one has mode MODE2.
        !          1192:    If HARD_REGNO_MODE_OK could produce different values for MODE1 and MODE2,
        !          1193:    for any hard reg, then this must be 0 for correct output.  */
        !          1194: #define MODES_TIEABLE_P(MODE1, MODE2)                                  \
        !          1195:   ((GET_MODE_CLASS (MODE1) == MODE_FLOAT ||                            \
        !          1196:     GET_MODE_CLASS (MODE1) == MODE_COMPLEX_FLOAT)                      \
        !          1197:    == (GET_MODE_CLASS (MODE2) == MODE_FLOAT ||                         \
        !          1198:        GET_MODE_CLASS (MODE2) == MODE_COMPLEX_FLOAT))
        !          1199: 
        !          1200: /* MIPS pc is not overloaded on a register.    */
        !          1201: /* #define PC_REGNUM xx                                */
        !          1202: 
        !          1203: /* Register to use for pushing function arguments.  */
        !          1204: #define STACK_POINTER_REGNUM (GP_REG_FIRST + 29)
        !          1205: 
        !          1206: /* Offset from the stack pointer to the first available location.  */
        !          1207: #define STACK_POINTER_OFFSET 0
        !          1208: 
        !          1209: /* Base register for access to local variables of the function.  */
        !          1210: #define FRAME_POINTER_REGNUM (GP_REG_FIRST + 30)
        !          1211: 
        !          1212: /* Value should be nonzero if functions must have frame pointers.
        !          1213:    Zero means the frame pointer need not be set up (and parms
        !          1214:    may be accessed via the stack pointer) in functions that seem suitable.
        !          1215:    This is computed in `reload', in reload1.c.  */
        !          1216: #define FRAME_POINTER_REQUIRED (current_function_calls_alloca)
        !          1217: 
        !          1218: /* Base register for access to arguments of the function.  */
        !          1219: #define ARG_POINTER_REGNUM GP_REG_FIRST
        !          1220: 
        !          1221: /* Register in which static-chain is passed to a function.  */
        !          1222: #define STATIC_CHAIN_REGNUM (GP_REG_FIRST + 2)
        !          1223: 
        !          1224: /* If the structure value address is passed in a register, then
        !          1225:    `STRUCT_VALUE_REGNUM' should be the number of that register.  */
        !          1226: /* #define STRUCT_VALUE_REGNUM (GP_REG_FIRST + 4) */
        !          1227: 
        !          1228: /* If the structure value address is not passed in a register, define
        !          1229:    `STRUCT_VALUE' as an expression returning an RTX for the place
        !          1230:    where the address is passed.  If it returns 0, the address is
        !          1231:    passed as an "invisible" first argument.  */
        !          1232: #define STRUCT_VALUE ((rtx)0)
        !          1233: 
        !          1234: /* Mips registers used in prologue/epilogue code when the stack frame
        !          1235:    is larger than 32K bytes.  These registers must come from the
        !          1236:    scratch register set, and not used for passing and returning
        !          1237:    arguments and any other information used in the calling sequence
        !          1238:    (such as pic).  */
        !          1239: 
        !          1240: #define MIPS_TEMP1_REGNUM (GP_REG_FIRST + 8)
        !          1241: #define MIPS_TEMP2_REGNUM (GP_REG_FIRST + 9)
        !          1242: 
        !          1243: /* Define this macro if it is as good or better to call a constant
        !          1244:    function address than to call an address kept in a register.  */
        !          1245: #define NO_FUNCTION_CSE 1
        !          1246: 
        !          1247: /* Define this macro if it is as good or better for a function to
        !          1248:    call itself with an explicit address than to call an address
        !          1249:    kept in a register.  */
        !          1250: #define NO_RECURSIVE_FUNCTION_CSE 1
        !          1251: 
        !          1252: /* The register number of the register used to address a table of
        !          1253:    static data addresses in memory.  In some cases this register is
        !          1254:    defined by a processor's "application binary interface" (ABI). 
        !          1255:    When this macro is defined, RTL is generated for this register
        !          1256:    once, as with the stack pointer and frame pointer registers.  If
        !          1257:    this macro is not defined, it is up to the machine-dependent
        !          1258:    files to allocate such a register (if necessary).  */
        !          1259: #define PIC_OFFSET_TABLE_REGNUM (GP_REG_FIRST + 28)
        !          1260: 
        !          1261: #define PIC_FUNCTION_ADDR_REGNUM (GP_REG_FIRST + 25)
        !          1262: 
        !          1263: 
        !          1264: /* Define the classes of registers for register constraints in the
        !          1265:    machine description.  Also define ranges of constants.
        !          1266: 
        !          1267:    One of the classes must always be named ALL_REGS and include all hard regs.
        !          1268:    If there is more than one class, another class must be named NO_REGS
        !          1269:    and contain no registers.
        !          1270: 
        !          1271:    The name GENERAL_REGS must be the name of a class (or an alias for
        !          1272:    another name such as ALL_REGS).  This is the class of registers
        !          1273:    that is allowed by "g" or "r" in a register constraint.
        !          1274:    Also, registers outside this class are allocated only when
        !          1275:    instructions express preferences for them.
        !          1276: 
        !          1277:    The classes must be numbered in nondecreasing order; that is,
        !          1278:    a larger-numbered class must never be contained completely
        !          1279:    in a smaller-numbered class.
        !          1280: 
        !          1281:    For any two classes, it is very desirable that there be another
        !          1282:    class that represents their union.  */
        !          1283: 
        !          1284: enum reg_class
        !          1285: {
        !          1286:   NO_REGS,                     /* no registers in set */
        !          1287:   GR_REGS,                     /* integer registers */
        !          1288:   FP_REGS,                     /* floating point registers */
        !          1289:   HI_REG,                      /* hi register */
        !          1290:   LO_REG,                      /* lo register */
        !          1291:   MD_REGS,                     /* multiply/divide registers (hi/lo) */
        !          1292:   ST_REGS,                     /* status registers (fp status) */
        !          1293:   ALL_REGS,                    /* all registers */
        !          1294:   LIM_REG_CLASSES              /* max value + 1 */
        !          1295: };
        !          1296: 
        !          1297: #define N_REG_CLASSES (int) LIM_REG_CLASSES
        !          1298: 
        !          1299: #define GENERAL_REGS GR_REGS
        !          1300: 
        !          1301: /* An initializer containing the names of the register classes as C
        !          1302:    string constants.  These names are used in writing some of the
        !          1303:    debugging dumps.  */
        !          1304: 
        !          1305: #define REG_CLASS_NAMES                                                        \
        !          1306: {                                                                      \
        !          1307:   "NO_REGS",                                                           \
        !          1308:   "GR_REGS",                                                           \
        !          1309:   "FP_REGS",                                                           \
        !          1310:   "HI_REG",                                                            \
        !          1311:   "LO_REG",                                                            \
        !          1312:   "MD_REGS",                                                           \
        !          1313:   "ST_REGS",                                                           \
        !          1314:   "ALL_REGS"                                                           \
        !          1315: }
        !          1316: 
        !          1317: /* An initializer containing the contents of the register classes,
        !          1318:    as integers which are bit masks.  The Nth integer specifies the
        !          1319:    contents of class N.  The way the integer MASK is interpreted is
        !          1320:    that register R is in the class if `MASK & (1 << R)' is 1.
        !          1321: 
        !          1322:    When the machine has more than 32 registers, an integer does not
        !          1323:    suffice.  Then the integers are replaced by sub-initializers,
        !          1324:    braced groupings containing several integers.  Each
        !          1325:    sub-initializer must be suitable as an initializer for the type
        !          1326:    `HARD_REG_SET' which is defined in `hard-reg-set.h'.  */
        !          1327: 
        !          1328: #define REG_CLASS_CONTENTS                                             \
        !          1329: {                                                                      \
        !          1330:   { 0x00000000, 0x00000000, 0x00000000 },      /* no registers */      \
        !          1331:   { 0xffffffff, 0x00000000, 0x00000000 },      /* integer registers */ \
        !          1332:   { 0x00000000, 0xffffffff, 0x00000000 },      /* floating registers*/ \
        !          1333:   { 0x00000000, 0x00000000, 0x00000001 },      /* hi register */       \
        !          1334:   { 0x00000000, 0x00000000, 0x00000002 },      /* lo register */       \
        !          1335:   { 0x00000000, 0x00000000, 0x00000003 },      /* mul/div registers */ \
        !          1336:   { 0x00000000, 0x00000000, 0x00000004 },      /* status registers */  \
        !          1337:   { 0xffffffff, 0xffffffff, 0x00000007 }       /* all registers */     \
        !          1338: }
        !          1339: 
        !          1340: 
        !          1341: /* A C expression whose value is a register class containing hard
        !          1342:    register REGNO.  In general there is more that one such class;
        !          1343:    choose a class which is "minimal", meaning that no smaller class
        !          1344:    also contains the register.  */
        !          1345: 
        !          1346: extern enum reg_class mips_regno_to_class[];
        !          1347: 
        !          1348: #define REGNO_REG_CLASS(REGNO) mips_regno_to_class[ (REGNO) ]
        !          1349: 
        !          1350: /* A macro whose definition is the name of the class to which a
        !          1351:    valid base register must belong.  A base register is one used in
        !          1352:    an address which is the register value plus a displacement.  */
        !          1353: 
        !          1354: #define BASE_REG_CLASS  GR_REGS
        !          1355: 
        !          1356: /* A macro whose definition is the name of the class to which a
        !          1357:    valid index register must belong.  An index register is one used
        !          1358:    in an address where its value is either multiplied by a scale
        !          1359:    factor or added to another register (as well as added to a
        !          1360:    displacement).  */
        !          1361: 
        !          1362: #define INDEX_REG_CLASS GR_REGS
        !          1363: 
        !          1364: 
        !          1365: /* REGISTER AND CONSTANT CLASSES */
        !          1366: 
        !          1367: /* Get reg_class from a letter such as appears in the machine
        !          1368:    description.
        !          1369: 
        !          1370:    DEFINED REGISTER CLASSES:
        !          1371: 
        !          1372:    'd'  General (aka integer) registers
        !          1373:    'f' Floating point registers
        !          1374:    'h' Hi register
        !          1375:    'l' Lo register
        !          1376:    'x' Multiply/divide registers
        !          1377:    'z' FP Status register */
        !          1378: 
        !          1379: extern enum reg_class mips_char_to_class[];
        !          1380: 
        !          1381: #define REG_CLASS_FROM_LETTER(C) mips_char_to_class[ (C) ]
        !          1382: 
        !          1383: /* The letters I, J, K, L, M, N, O, and P in a register constraint
        !          1384:    string can be used to stand for particular ranges of immediate
        !          1385:    operands.  This macro defines what the ranges are.  C is the
        !          1386:    letter, and VALUE is a constant value.  Return 1 if VALUE is
        !          1387:    in the range specified by C.  */
        !          1388: 
        !          1389: /* For MIPS:
        !          1390: 
        !          1391:    `I' is used for the range of constants an arithmetic insn can
        !          1392:        actually contain (16 bits signed integers).
        !          1393: 
        !          1394:    `J' is used for the range which is just zero (ie, $r0).
        !          1395: 
        !          1396:    `K' is used for the range of constants a logical insn can actually
        !          1397:        contain (16 bit zero-extended integers).
        !          1398: 
        !          1399:    `L' is used for the range of constants that be loaded with lui
        !          1400:        (ie, the bottom 16 bits are zero).
        !          1401: 
        !          1402:    `M' is used for the range of constants that take two words to load
        !          1403:        (ie, not matched by `I', `K', and `L').
        !          1404: 
        !          1405:    `N' is used for negative 16 bit constants.
        !          1406: 
        !          1407:    `O' is an exact power of 2 (not yet used in the md file).
        !          1408: 
        !          1409:    `P' is used for positive 16 bit constants.  */
        !          1410: 
        !          1411: #define SMALL_INT(X) ((unsigned) (INTVAL (X) + 0x8000) < 0x10000)
        !          1412: #define SMALL_INT_UNSIGNED(X) ((unsigned) (INTVAL (X)) < 0x10000)
        !          1413: 
        !          1414: #define CONST_OK_FOR_LETTER_P(VALUE, C)                                        \
        !          1415:   ((C) == 'I' ? ((unsigned) ((VALUE) + 0x8000) < 0x10000)              \
        !          1416:    : (C) == 'J' ? ((VALUE) == 0)                                       \
        !          1417:    : (C) == 'K' ? ((unsigned) (VALUE) < 0x10000)                       \
        !          1418:    : (C) == 'L' ? (((VALUE) & 0xffff0000) == (VALUE))                  \
        !          1419:    : (C) == 'M' ? ((((VALUE) & ~0x0000ffff) != 0)                      \
        !          1420:                   && (((VALUE) & ~0x0000ffff) != ~0x0000ffff)          \
        !          1421:                   && ((VALUE) & 0x0000ffff) != 0)                      \
        !          1422:    : (C) == 'N' ? (((VALUE) & ~0x0000ffff) == ~0x0000ffff)             \
        !          1423:    : (C) == 'O' ? (exact_log2 (VALUE) >= 0)                            \
        !          1424:    : (C) == 'P' ? ((VALUE) != 0 && (((VALUE) & ~0x0000ffff) == 0))     \
        !          1425:    : 0)
        !          1426: 
        !          1427: /* Similar, but for floating constants, and defining letters G and H.
        !          1428:    Here VALUE is the CONST_DOUBLE rtx itself.  */
        !          1429: 
        !          1430: /* For Mips
        !          1431: 
        !          1432:   'G'  : Floating point 0 */
        !          1433: 
        !          1434: #define CONST_DOUBLE_OK_FOR_LETTER_P(VALUE, C)                         \
        !          1435:   ((C) == 'G'                                                          \
        !          1436:    && CONST_DOUBLE_HIGH (VALUE) == 0                                   \
        !          1437:    && CONST_DOUBLE_LOW (VALUE) == 0)
        !          1438: 
        !          1439: /* Letters in the range `Q' through `U' may be defined in a
        !          1440:    machine-dependent fashion to stand for arbitrary operand types. 
        !          1441:    The machine description macro `EXTRA_CONSTRAINT' is passed the
        !          1442:    operand as its first argument and the constraint letter as its
        !          1443:    second operand.
        !          1444: 
        !          1445:    `Q' is for memory references which take more than 1 instruction.
        !          1446:    `R' is for memory references which take 1 word for the instruction.
        !          1447:    `S' is for references to extern items which are PIC for OSF/rose.  */
        !          1448: 
        !          1449: #define EXTRA_CONSTRAINT(OP,CODE)                                      \
        !          1450:   ((GET_CODE (OP) != MEM) ? FALSE                                      \
        !          1451:    : ((CODE) == 'Q')     ? !simple_memory_operand (OP, GET_MODE (OP))  \
        !          1452:    : ((CODE) == 'R')     ? simple_memory_operand (OP, GET_MODE (OP))   \
        !          1453:    : ((CODE) == 'S')     ? (HALF_PIC_P () && CONSTANT_P (OP)           \
        !          1454:                             && HALF_PIC_ADDRESS_P (OP))                \
        !          1455:    : FALSE)
        !          1456: 
        !          1457: /* Given an rtx X being reloaded into a reg required to be
        !          1458:    in class CLASS, return the class of reg to actually use.
        !          1459:    In general this is just CLASS; but on some machines
        !          1460:    in some cases it is preferable to use a more restrictive class.  */
        !          1461: 
        !          1462: #define PREFERRED_RELOAD_CLASS(X,CLASS)                                        \
        !          1463:   ((GET_MODE_CLASS (GET_MODE (X)) == MODE_FLOAT                                \
        !          1464:      || GET_MODE_CLASS (GET_MODE (X)) == MODE_COMPLEX_FLOAT)           \
        !          1465:            ? (TARGET_SOFT_FLOAT ? GR_REGS : FP_REGS)                   \
        !          1466:            : ((GET_MODE (X) == VOIDmode)                               \
        !          1467:                ? GR_REGS                                               \
        !          1468:                : CLASS))
        !          1469: 
        !          1470: /* Certain machines have the property that some registers cannot be
        !          1471:    copied to some other registers without using memory.  Define this
        !          1472:    macro on those machines to be a C expression that is non-zero if
        !          1473:    objects of mode MODE in registers of CLASS1 can only be copied to
        !          1474:    registers of class CLASS2 by storing a register of CLASS1 into
        !          1475:    memory and loading that memory location into a register of CLASS2.
        !          1476: 
        !          1477:    Do not define this macro if its value would always be zero.  */
        !          1478: 
        !          1479: #define SECONDARY_MEMORY_NEEDED(CLASS1, CLASS2, MODE)                  \
        !          1480:   (!TARGET_DEBUG_H_MODE                                                        \
        !          1481:    && GET_MODE_CLASS (MODE) == MODE_INT                                        \
        !          1482:    && ((CLASS1 == FP_REGS && CLASS2 == GR_REGS)                                \
        !          1483:        || (CLASS1 == GR_REGS && CLASS2 == FP_REGS)))
        !          1484: 
        !          1485: /* Return the maximum number of consecutive registers
        !          1486:    needed to represent mode MODE in a register of class CLASS.  */
        !          1487: 
        !          1488: #define CLASS_UNITS(mode, size)                                                \
        !          1489:   ((GET_MODE_SIZE (mode) + (size) - 1) / (size))
        !          1490: 
        !          1491: #define CLASS_MAX_NREGS(CLASS, MODE)                                   \
        !          1492:   ((CLASS) == FP_REGS                                                  \
        !          1493:    ? (TARGET_FLOAT64                                                   \
        !          1494:       ? CLASS_UNITS (MODE, 8)                                          \
        !          1495:       : 2 * CLASS_UNITS (MODE, 8))                                     \
        !          1496:    : CLASS_UNITS (MODE, UNITS_PER_WORD))
        !          1497: 
        !          1498: /* If defined, this is a C expression whose value should be
        !          1499:    nonzero if the insn INSN has the effect of mysteriously
        !          1500:    clobbering the contents of hard register number REGNO.  By
        !          1501:    "mysterious" we mean that the insn's RTL expression doesn't
        !          1502:    describe such an effect.
        !          1503: 
        !          1504:    If this macro is not defined, it means that no insn clobbers
        !          1505:    registers mysteriously.  This is the usual situation; all else
        !          1506:    being equal, it is best for the RTL expression to show all the
        !          1507:    activity.  */
        !          1508: 
        !          1509: /* #define INSN_CLOBBERS_REGNO_P(INSN, REGNO) */
        !          1510: 
        !          1511: 
        !          1512: /* Stack layout; function entry, exit and calling.  */
        !          1513: 
        !          1514: /* Define this if pushing a word on the stack
        !          1515:    makes the stack pointer a smaller address.  */
        !          1516: #define STACK_GROWS_DOWNWARD
        !          1517: 
        !          1518: /* Define this if the nominal address of the stack frame
        !          1519:    is at the high-address end of the local variables;
        !          1520:    that is, each additional local variable allocated
        !          1521:    goes at a more negative offset in the frame.  */
        !          1522: /* #define FRAME_GROWS_DOWNWARD */
        !          1523: 
        !          1524: /* Offset within stack frame to start allocating local variables at.
        !          1525:    If FRAME_GROWS_DOWNWARD, this is the offset to the END of the
        !          1526:    first local allocated.  Otherwise, it is the offset to the BEGINNING
        !          1527:    of the first local allocated.  */
        !          1528: #define STARTING_FRAME_OFFSET                                          \
        !          1529:   (current_function_outgoing_args_size                                 \
        !          1530:    + (TARGET_ABICALLS ? MIPS_STACK_ALIGN (UNITS_PER_WORD) : 0))
        !          1531: 
        !          1532: /* Offset from the stack pointer register to an item dynamically
        !          1533:    allocated on the stack, e.g., by `alloca'.
        !          1534: 
        !          1535:    The default value for this macro is `STACK_POINTER_OFFSET' plus the
        !          1536:    length of the outgoing arguments.  The default is correct for most
        !          1537:    machines.  See `function.c' for details.
        !          1538: 
        !          1539:    The MIPS ABI states that functions which dynamically allocate the
        !          1540:    stack must not have 0 for STACK_DYNAMIC_OFFSET, since it looks like
        !          1541:    we are trying to create a second frame pointer to the function, so
        !          1542:    allocate some stack space to make it happy.
        !          1543: 
        !          1544:    However, the linker currently complains about linking any code that
        !          1545:    dynamically allocates stack space, and there seems to be a bug in
        !          1546:    STACK_DYNAMIC_OFFSET, so don't define this right now.  */
        !          1547: 
        !          1548: #if 0
        !          1549: #define STACK_DYNAMIC_OFFSET(FUNDECL)                                  \
        !          1550:   ((current_function_outgoing_args_size == 0 && current_function_calls_alloca) \
        !          1551:        ? 4*UNITS_PER_WORD                                              \
        !          1552:        : current_function_outgoing_args_size)
        !          1553: #endif
        !          1554: 
        !          1555: /* Structure to be filled in by compute_frame_size with register
        !          1556:    save masks, and offsets for the current function.  */
        !          1557: 
        !          1558: struct mips_frame_info
        !          1559: {
        !          1560:   long total_size;             /* # bytes that the entire frame takes up */
        !          1561:   long var_size;               /* # bytes that variables take up */
        !          1562:   long args_size;              /* # bytes that outgoing arguments take up */
        !          1563:   long extra_size;             /* # bytes of extra gunk */
        !          1564:   int  gp_reg_size;            /* # bytes needed to store gp regs */
        !          1565:   int  fp_reg_size;            /* # bytes needed to store fp regs */
        !          1566:   long mask;                   /* mask of saved gp registers */
        !          1567:   long fmask;                  /* mask of saved fp registers */
        !          1568:   long gp_save_offset;         /* offset from vfp to store gp registers */
        !          1569:   long fp_save_offset;         /* offset from vfp to store fp registers */
        !          1570:   long gp_sp_offset;           /* offset from new sp to store gp registers */
        !          1571:   long fp_sp_offset;           /* offset from new sp to store fp registers */
        !          1572:   int  initialized;            /* != 0 if frame size already calculated */
        !          1573:   int  num_gp;                 /* number of gp registers saved */
        !          1574:   int  num_fp;                 /* number of fp registers saved */
        !          1575: };
        !          1576: 
        !          1577: extern struct mips_frame_info current_frame_info;
        !          1578: 
        !          1579: /* Store in the variable DEPTH the initial difference between the
        !          1580:    frame pointer reg contents and the stack pointer reg contents,
        !          1581:    as of the start of the function body.  This depends on the layout
        !          1582:    of the fixed parts of the stack frame and on how registers are saved.  */
        !          1583: 
        !          1584: /* #define INITIAL_FRAME_POINTER_OFFSET(VAR)                           \
        !          1585:     ((VAR) = compute_frame_size (get_frame_size ())) */
        !          1586: 
        !          1587: /* If defined, this macro specifies a table of register pairs used to
        !          1588:    eliminate unneeded registers that point into the stack frame.  If
        !          1589:    it is not defined, the only elimination attempted by the compiler
        !          1590:    is to replace references to the frame pointer with references to
        !          1591:    the stack pointer.
        !          1592: 
        !          1593:    The definition of this macro is a list of structure
        !          1594:    initializations, each of which specifies an original and
        !          1595:    replacement register.
        !          1596: 
        !          1597:    On some machines, the position of the argument pointer is not
        !          1598:    known until the compilation is completed.  In such a case, a
        !          1599:    separate hard register must be used for the argument pointer. 
        !          1600:    This register can be eliminated by replacing it with either the
        !          1601:    frame pointer or the argument pointer, depending on whether or not
        !          1602:    the frame pointer has been eliminated.
        !          1603: 
        !          1604:    In this case, you might specify:
        !          1605:         #define ELIMINABLE_REGS  \
        !          1606:         {{ARG_POINTER_REGNUM, STACK_POINTER_REGNUM}, \
        !          1607:          {ARG_POINTER_REGNUM, FRAME_POINTER_REGNUM}, \
        !          1608:          {FRAME_POINTER_REGNUM, STACK_POINTER_REGNUM}}
        !          1609: 
        !          1610:    Note that the elimination of the argument pointer with the stack
        !          1611:    pointer is specified first since that is the preferred elimination.  */
        !          1612: 
        !          1613: #define ELIMINABLE_REGS                                                        \
        !          1614: {{ ARG_POINTER_REGNUM,   STACK_POINTER_REGNUM},                                \
        !          1615:  { ARG_POINTER_REGNUM,   FRAME_POINTER_REGNUM},                                \
        !          1616:  { FRAME_POINTER_REGNUM, STACK_POINTER_REGNUM}}
        !          1617: 
        !          1618: 
        !          1619: /* A C expression that returns non-zero if the compiler is allowed to
        !          1620:    try to replace register number FROM-REG with register number
        !          1621:    TO-REG.  This macro need only be defined if `ELIMINABLE_REGS' is
        !          1622:    defined, and will usually be the constant 1, since most of the
        !          1623:    cases preventing register elimination are things that the compiler
        !          1624:    already knows about.  */
        !          1625: 
        !          1626: #define CAN_ELIMINATE(FROM, TO)                                                \
        !          1627:   (!frame_pointer_needed                                               \
        !          1628:    || ((FROM) == ARG_POINTER_REGNUM && (TO) == FRAME_POINTER_REGNUM))
        !          1629: 
        !          1630: /* This macro is similar to `INITIAL_FRAME_POINTER_OFFSET'.  It
        !          1631:    specifies the initial difference between the specified pair of
        !          1632:    registers.  This macro must be defined if `ELIMINABLE_REGS' is
        !          1633:    defined.  */
        !          1634: 
        !          1635: #define INITIAL_ELIMINATION_OFFSET(FROM, TO, OFFSET)                    \
        !          1636: {  compute_frame_size (get_frame_size ());                              \
        !          1637:   if ((FROM) == FRAME_POINTER_REGNUM && (TO) == STACK_POINTER_REGNUM)   \
        !          1638:     (OFFSET) = 0;                                                       \
        !          1639:   else if ((FROM) == ARG_POINTER_REGNUM && (TO) == FRAME_POINTER_REGNUM) \
        !          1640:     (OFFSET) = current_frame_info.total_size;                           \
        !          1641:   else if ((FROM) == ARG_POINTER_REGNUM && (TO) == STACK_POINTER_REGNUM) \
        !          1642:     (OFFSET) = current_frame_info.total_size;                           \
        !          1643:   else                                                                  \
        !          1644:     abort ();                                                           \
        !          1645: }
        !          1646: 
        !          1647: 
        !          1648: /* If we generate an insn to push BYTES bytes,
        !          1649:    this says how many the stack pointer really advances by.
        !          1650:    On the vax, sp@- in a byte insn really pushes a word.  */
        !          1651: 
        !          1652: /* #define PUSH_ROUNDING(BYTES) 0 */
        !          1653: 
        !          1654: /* If defined, the maximum amount of space required for outgoing
        !          1655:    arguments will be computed and placed into the variable
        !          1656:    `current_function_outgoing_args_size'.  No space will be pushed
        !          1657:    onto the stack for each call; instead, the function prologue
        !          1658:    should increase the stack frame size by this amount.
        !          1659: 
        !          1660:    It is not proper to define both `PUSH_ROUNDING' and
        !          1661:    `ACCUMULATE_OUTGOING_ARGS'.  */
        !          1662: #define ACCUMULATE_OUTGOING_ARGS
        !          1663: 
        !          1664: /* Offset from the argument pointer register to the first argument's
        !          1665:    address.  On some machines it may depend on the data type of the
        !          1666:    function.
        !          1667: 
        !          1668:    If `ARGS_GROW_DOWNWARD', this is the offset to the location above
        !          1669:    the first argument's address.
        !          1670: 
        !          1671:    On the MIPS, we must skip the first argument position if we are
        !          1672:    returning a structure or a union, to account for it's address being
        !          1673:    passed in $4.  However, at the current time, this produces a compiler
        !          1674:    that can't bootstrap, so comment it out for now.  */
        !          1675: 
        !          1676: #if 0
        !          1677: #define FIRST_PARM_OFFSET(FNDECL)                                      \
        !          1678:   (FNDECL != 0                                                         \
        !          1679:    && TREE_TYPE (FNDECL) != 0                                          \
        !          1680:    && TREE_TYPE (TREE_TYPE (FNDECL)) != 0                              \
        !          1681:    && (TREE_CODE (TREE_TYPE (TREE_TYPE (FNDECL))) == RECORD_TYPE       \
        !          1682:        || TREE_CODE (TREE_TYPE (TREE_TYPE (FNDECL))) == UNION_TYPE)    \
        !          1683:                ? UNITS_PER_WORD                                        \
        !          1684:                : 0)
        !          1685: #else
        !          1686: #define FIRST_PARM_OFFSET(FNDECL) 0
        !          1687: #endif
        !          1688: 
        !          1689: /* When a parameter is passed in a register, stack space is still
        !          1690:    allocated for it.  For the MIPS, stack space must be allocated, cf
        !          1691:    Asm Lang Prog Guide page 7-8.
        !          1692: 
        !          1693:    BEWARE that some space is also allocated for non existing arguments
        !          1694:    in register. In case an argument list is of form GF used registers
        !          1695:    are a0 (a2,a3), but we should push over a1...  */
        !          1696: 
        !          1697: #define REG_PARM_STACK_SPACE(FNDECL) ((4*UNITS_PER_WORD) - FIRST_PARM_OFFSET (FNDECL))
        !          1698: 
        !          1699: /* Define this if it is the responsibility of the caller to
        !          1700:    allocate the area reserved for arguments passed in registers. 
        !          1701:    If `ACCUMULATE_OUTGOING_ARGS' is also defined, the only effect
        !          1702:    of this macro is to determine whether the space is included in 
        !          1703:    `current_function_outgoing_args_size'.  */
        !          1704: #define OUTGOING_REG_PARM_STACK_SPACE
        !          1705: 
        !          1706: /* Align stack frames on 64 bits (Double Word ).  */
        !          1707: #define STACK_BOUNDARY 64
        !          1708: 
        !          1709: /* Make sure 16 bytes are always allocated on the stack.  */
        !          1710: 
        !          1711: #ifndef STACK_ARGS_ADJUST
        !          1712: #define STACK_ARGS_ADJUST(SIZE)                                                \
        !          1713: {                                                                      \
        !          1714:   if (SIZE.constant < 16)                                              \
        !          1715:     SIZE.constant = 16;                                                        \
        !          1716: }
        !          1717: #endif
        !          1718: 
        !          1719: 
        !          1720: /* A C expression that should indicate the number of bytes of its
        !          1721:    own arguments that a function function pops on returning, or 0
        !          1722:    if the function pops no arguments and the caller must therefore
        !          1723:    pop them all after the function returns.
        !          1724: 
        !          1725:    FUNTYPE is a C variable whose value is a tree node that
        !          1726:    describes the function in question.  Normally it is a node of
        !          1727:    type `FUNCTION_TYPE' that describes the data type of the function.
        !          1728:    From this it is possible to obtain the data types of the value
        !          1729:    and arguments (if known).
        !          1730: 
        !          1731:    When a call to a library function is being considered, FUNTYPE
        !          1732:    will contain an identifier node for the library function.  Thus,
        !          1733:    if you need to distinguish among various library functions, you
        !          1734:    can do so by their names.  Note that "library function" in this
        !          1735:    context means a function used to perform arithmetic, whose name
        !          1736:    is known specially in the compiler and was not mentioned in the
        !          1737:    C code being compiled.
        !          1738: 
        !          1739:    STACK-SIZE is the number of bytes of arguments passed on the
        !          1740:    stack.  If a variable number of bytes is passed, it is zero, and
        !          1741:    argument popping will always be the responsibility of the
        !          1742:    calling function.  */
        !          1743: 
        !          1744: #define RETURN_POPS_ARGS(FUNTYPE, SIZE) 0
        !          1745: 
        !          1746: 
        !          1747: /* Symbolic macros for the registers used to return integer and floating
        !          1748:    point values.  */
        !          1749: 
        !          1750: #define GP_RETURN (GP_REG_FIRST + 2)
        !          1751: #define FP_RETURN ((TARGET_SOFT_FLOAT) ? GP_RETURN : (FP_REG_FIRST + 0))
        !          1752: 
        !          1753: /* Symbolic macros for the first/last argument registers.  */
        !          1754: 
        !          1755: #define GP_ARG_FIRST (GP_REG_FIRST + 4)
        !          1756: #define GP_ARG_LAST  (GP_REG_FIRST + 7)
        !          1757: #define FP_ARG_FIRST (FP_REG_FIRST + 12)
        !          1758: #define FP_ARG_LAST  (FP_REG_FIRST + 15)
        !          1759: 
        !          1760: #define MAX_ARGS_IN_REGISTERS  4
        !          1761: 
        !          1762: /* Define how to find the value returned by a library function
        !          1763:    assuming the value has mode MODE.  */
        !          1764: 
        !          1765: #define LIBCALL_VALUE(MODE)                                            \
        !          1766:   gen_rtx (REG, MODE,                                                  \
        !          1767:           (GET_MODE_CLASS (MODE) == MODE_FLOAT)                        \
        !          1768:                ? FP_RETURN                                             \
        !          1769:                : GP_RETURN)
        !          1770: 
        !          1771: /* Define how to find the value returned by a function.
        !          1772:    VALTYPE is the data type of the value (as a tree).
        !          1773:    If the precise function being called is known, FUNC is its FUNCTION_DECL;
        !          1774:    otherwise, FUNC is 0.  */
        !          1775: 
        !          1776: #define FUNCTION_VALUE(VALTYPE, FUNC) LIBCALL_VALUE (TYPE_MODE (VALTYPE))
        !          1777: 
        !          1778: 
        !          1779: /* 1 if N is a possible register number for a function value.
        !          1780:    On the MIPS, R2 R3 and F0 F2 are the only register thus used.
        !          1781:    Currently, R2 and F0 are only implemented  here (C has no complex type)  */
        !          1782: 
        !          1783: #define FUNCTION_VALUE_REGNO_P(N) ((N) == GP_RETURN || (N) == FP_RETURN)
        !          1784: 
        !          1785: /* 1 if N is a possible register number for function argument passing.  */
        !          1786: 
        !          1787: #define FUNCTION_ARG_REGNO_P(N) (((N) >= GP_ARG_FIRST && (N) <= GP_ARG_LAST)   \
        !          1788:                                 || ((N) >= FP_ARG_FIRST && (N) <= FP_ARG_LAST \
        !          1789:                                     && (0 == (N) % 2)))
        !          1790: 
        !          1791: /* A C expression which can inhibit the returning of certain function
        !          1792:    values in registers, based on the type of value.  A nonzero value says
        !          1793:    to return the function value in memory, just as large structures are
        !          1794:    always returned.  Here TYPE will be a C expression of type
        !          1795:    `tree', representing the data type of the value.
        !          1796: 
        !          1797:    Note that values of mode `BLKmode' must be explicitly
        !          1798:    handled by this macro.  Also, the option `-fpcc-struct-return'
        !          1799:    takes effect regardless of this macro.  On most systems, it is
        !          1800:    possible to leave the macro undefined; this causes a default
        !          1801:    definition to be used, whose value is the constant 1 for BLKmode
        !          1802:    values, and 0 otherwise.
        !          1803: 
        !          1804:    GCC normally converts 1 byte structures into chars, 2 byte
        !          1805:    structs into shorts, and 4 byte structs into ints, and returns
        !          1806:    them this way.  Defining the following macro overrides this,
        !          1807:    to give us MIPS cc compatibility.  */
        !          1808: 
        !          1809: #define RETURN_IN_MEMORY(TYPE) \
        !          1810:   (TYPE_MODE (TYPE) == BLKmode)
        !          1811: 
        !          1812: /* A code distinguishing the floating point format of the target
        !          1813:    machine.  There are three defined values: IEEE_FLOAT_FORMAT,
        !          1814:    VAX_FLOAT_FORMAT, and UNKNOWN_FLOAT_FORMAT.  */
        !          1815: 
        !          1816: #define TARGET_FLOAT_FORMAT IEEE_FLOAT_FORMAT
        !          1817: 
        !          1818: 
        !          1819: /* Define a data type for recording info about an argument list
        !          1820:    during the scan of that argument list.  This data type should
        !          1821:    hold all necessary information about the function itself
        !          1822:    and about the args processed so far, enough to enable macros
        !          1823:    such as FUNCTION_ARG to determine where the next arg should go.
        !          1824: */
        !          1825: 
        !          1826: typedef struct mips_args {
        !          1827:   int gp_reg_found;            /* whether a gp register was found yet */
        !          1828:   int arg_number;              /* argument number */
        !          1829:   int arg_words;               /* # total words the arguments take */
        !          1830:   int num_adjusts;             /* number of adjustments made */
        !          1831:                                /* Adjustments made to args pass in regs.  */
        !          1832:                                /* ??? The size is doubled to work around a 
        !          1833:                                   bug in the code that sets the adjustments
        !          1834:                                   in function_arg.  */
        !          1835:   struct rtx_def *adjust[MAX_ARGS_IN_REGISTERS*2];
        !          1836: } CUMULATIVE_ARGS;
        !          1837: 
        !          1838: /* Initialize a variable CUM of type CUMULATIVE_ARGS
        !          1839:    for a call to a function whose data type is FNTYPE.
        !          1840:    For a library call, FNTYPE is 0.
        !          1841: 
        !          1842: */
        !          1843: 
        !          1844: #define INIT_CUMULATIVE_ARGS(CUM,FNTYPE,LIBNAME)                       \
        !          1845:   init_cumulative_args (&CUM, FNTYPE, LIBNAME)                         \
        !          1846: 
        !          1847: /* Update the data in CUM to advance over an argument
        !          1848:    of mode MODE and data type TYPE.
        !          1849:    (TYPE is null for libcalls where that information may not be available.)  */
        !          1850: 
        !          1851: #define FUNCTION_ARG_ADVANCE(CUM, MODE, TYPE, NAMED)                   \
        !          1852:   function_arg_advance (&CUM, MODE, TYPE, NAMED)
        !          1853: 
        !          1854: /* Determine where to put an argument to a function.
        !          1855:    Value is zero to push the argument on the stack,
        !          1856:    or a hard register in which to store the argument.
        !          1857: 
        !          1858:    MODE is the argument's machine mode.
        !          1859:    TYPE is the data type of the argument (as a tree).
        !          1860:     This is null for libcalls where that information may
        !          1861:     not be available.
        !          1862:    CUM is a variable of type CUMULATIVE_ARGS which gives info about
        !          1863:     the preceding args and about the function being called.
        !          1864:    NAMED is nonzero if this argument is a named parameter
        !          1865:     (otherwise it is an extra parameter matching an ellipsis).  */
        !          1866: 
        !          1867: #define FUNCTION_ARG(CUM, MODE, TYPE, NAMED) \
        !          1868:   function_arg( &CUM, MODE, TYPE, NAMED)
        !          1869: 
        !          1870: /* For an arg passed partly in registers and partly in memory,
        !          1871:    this is the number of registers used.
        !          1872:    For args passed entirely in registers or entirely in memory, zero. */
        !          1873: 
        !          1874: #define FUNCTION_ARG_PARTIAL_NREGS(CUM, MODE, TYPE, NAMED) \
        !          1875:   function_arg_partial_nregs (&CUM, MODE, TYPE, NAMED)
        !          1876: 
        !          1877: /* If defined, a C expression that gives the alignment boundary, in
        !          1878:    bits, of an argument with the specified mode and type.  If it is
        !          1879:    not defined,  `PARM_BOUNDARY' is used for all arguments.  */
        !          1880: 
        !          1881: #define FUNCTION_ARG_BOUNDARY(MODE, TYPE)                              \
        !          1882:   (((TYPE) != 0)                                                       \
        !          1883:        ? ((TYPE_ALIGN(TYPE) <= PARM_BOUNDARY)                          \
        !          1884:                ? PARM_BOUNDARY                                         \
        !          1885:                : TYPE_ALIGN(TYPE))                                     \
        !          1886:        : ((GET_MODE_ALIGNMENT(MODE) <= PARM_BOUNDARY)                  \
        !          1887:                ? PARM_BOUNDARY                                         \
        !          1888:                : GET_MODE_ALIGNMENT(MODE)))
        !          1889: 
        !          1890: 
        !          1891: /* This macro generates the assembly code for function entry.
        !          1892:    FILE is a stdio stream to output the code to.
        !          1893:    SIZE is an int: how many units of temporary storage to allocate.
        !          1894:    Refer to the array `regs_ever_live' to determine which registers
        !          1895:    to save; `regs_ever_live[I]' is nonzero if register number I
        !          1896:    is ever used in the function.  This macro is responsible for
        !          1897:    knowing which registers should not be saved even if used.  */
        !          1898: 
        !          1899: #define FUNCTION_PROLOGUE(FILE, SIZE) function_prologue(FILE, SIZE)
        !          1900: 
        !          1901: /* This macro generates the assembly code for function exit,
        !          1902:    on machines that need it.  If FUNCTION_EPILOGUE is not defined
        !          1903:    then individual return instructions are generated for each
        !          1904:    return statement.  Args are same as for FUNCTION_PROLOGUE.  */
        !          1905: 
        !          1906: #define FUNCTION_EPILOGUE(FILE, SIZE) function_epilogue(FILE, SIZE)
        !          1907: 
        !          1908: /* Define the number of delay slots needed for the function epilogue.
        !          1909: 
        !          1910:    On the mips, we need a slot if either no stack has been allocated,
        !          1911:    or the only register saved is the return register.  */
        !          1912: 
        !          1913: #define DELAY_SLOTS_FOR_EPILOGUE mips_epilogue_delay_slots ()
        !          1914: 
        !          1915: /* Define whether INSN can be placed in delay slot N for the epilogue.
        !          1916:    No references to the stack must be made, since on the MIPS, the
        !          1917:    delay slot is done after the stack has been cleaned up.  */
        !          1918: 
        !          1919: #define ELIGIBLE_FOR_EPILOGUE_DELAY(INSN,N)                            \
        !          1920:   (get_attr_dslot (INSN) == DSLOT_NO                                   \
        !          1921:    && get_attr_length (INSN) == 1                                      \
        !          1922:    && ! epilogue_reg_mentioned_p (PATTERN (INSN)))
        !          1923: 
        !          1924: /* Tell prologue and epilogue if register REGNO should be saved / restored.  */
        !          1925: 
        !          1926: #define MUST_SAVE_REGISTER(regno) \
        !          1927:  ((regs_ever_live[regno] && !call_used_regs[regno])            \
        !          1928:   || (regno == FRAME_POINTER_REGNUM && frame_pointer_needed)   \
        !          1929:   || (regno == (GP_REG_FIRST + 31) && regs_ever_live[GP_REG_FIRST + 31]))
        !          1930: 
        !          1931: /* ALIGN FRAMES on double word boundaries */
        !          1932: 
        !          1933: #define MIPS_STACK_ALIGN(LOC) (((LOC)+7) & ~7)
        !          1934: 
        !          1935: 
        !          1936: /* Output assembler code to FILE to increment profiler label # LABELNO
        !          1937:    for profiling a function entry.  */
        !          1938: 
        !          1939: #define FUNCTION_PROFILER(FILE, LABELNO)                               \
        !          1940: {                                                                      \
        !          1941:   fprintf (FILE, "\t.set\tnoreorder\n");                               \
        !          1942:   fprintf (FILE, "\t.set\tnoat\n");                                    \
        !          1943:   fprintf (FILE, "\tmove\t%s,%s\t\t# save current return address\n",   \
        !          1944:           reg_names[GP_REG_FIRST + 1], reg_names[GP_REG_FIRST + 31]);  \
        !          1945:   fprintf (FILE, "\tjal\t_mcount\n");                                  \
        !          1946:   fprintf (FILE, "\tsubu\t%s,%s,8\t\t# _mcount pops 2 words from  stack\n", \
        !          1947:           reg_names[STACK_POINTER_REGNUM],                             \
        !          1948:           reg_names[STACK_POINTER_REGNUM]);                            \
        !          1949:   fprintf (FILE, "\t.set\treorder\n");                                 \
        !          1950:   fprintf (FILE, "\t.set\tat\n");                                      \
        !          1951: }
        !          1952: 
        !          1953: /* Define this macro if the code for function profiling should come
        !          1954:    before the function prologue.  Normally, the profiling code comes
        !          1955:    after.  */
        !          1956: 
        !          1957: /* #define PROFILE_BEFORE_PROLOGUE */
        !          1958: 
        !          1959: /* EXIT_IGNORE_STACK should be nonzero if, when returning from a function,
        !          1960:    the stack pointer does not matter.  The value is tested only in
        !          1961:    functions that have frame pointers.
        !          1962:    No definition is equivalent to always zero.  */
        !          1963: 
        !          1964: #define EXIT_IGNORE_STACK 1
        !          1965: 
        !          1966: 
        !          1967: /* A C statement to output, on the stream FILE, assembler code for a
        !          1968:    block of data that contains the constant parts of a trampoline. 
        !          1969:    This code should not include a label--the label is taken care of
        !          1970:    automatically.  */
        !          1971: 
        !          1972: #define TRAMPOLINE_TEMPLATE(STREAM)                                     \
        !          1973: {                                                                       \
        !          1974:   fprintf (STREAM, "\t.word\t0x03e00821\t\t# move   $1,$31\n");                \
        !          1975:   fprintf (STREAM, "\t.word\t0x04110001\t\t# bgezal $0,.+8\n");                \
        !          1976:   fprintf (STREAM, "\t.word\t0x00000000\t\t# nop\n");                  \
        !          1977:   fprintf (STREAM, "\t.word\t0x8fe30010\t\t# lw     $3,16($31)\n");    \
        !          1978:   fprintf (STREAM, "\t.word\t0x8fe20014\t\t# lw     $2,20($31)\n");    \
        !          1979:   fprintf (STREAM, "\t.word\t0x00600008\t\t# jr     $3\n");            \
        !          1980:   fprintf (STREAM, "\t.word\t0x0020f821\t\t# move   $31,$1\n");                \
        !          1981:   fprintf (STREAM, "\t.word\t0x00000000\t\t# <function address>\n");   \
        !          1982:   fprintf (STREAM, "\t.word\t0x00000000\t\t# <static chain value>\n"); \
        !          1983: }
        !          1984: 
        !          1985: /* A C expression for the size in bytes of the trampoline, as an
        !          1986:    integer.  */
        !          1987: 
        !          1988: #define TRAMPOLINE_SIZE (9*4)
        !          1989: 
        !          1990: /* Alignment required for trampolines, in bits.
        !          1991: 
        !          1992:    If you don't define this macro, the value of `BIGGEST_ALIGNMENT'
        !          1993:    is used for aligning trampolines.  */
        !          1994: 
        !          1995: /* #define TRAMPOLINE_ALIGNMENT 32 */
        !          1996: 
        !          1997: /* A C statement to initialize the variable parts of a trampoline. 
        !          1998:    ADDR is an RTX for the address of the trampoline; FNADDR is an
        !          1999:    RTX for the address of the nested function; STATIC_CHAIN is an
        !          2000:    RTX for the static chain value that should be passed to the
        !          2001:    function when it is called.  */
        !          2002: 
        !          2003: #define INITIALIZE_TRAMPOLINE(ADDR, FUNC, CHAIN)                           \
        !          2004: {                                                                          \
        !          2005:   rtx addr = ADDR;                                                         \
        !          2006:   emit_move_insn (gen_rtx (MEM, SImode, plus_constant (addr, 28)), FUNC);   \
        !          2007:   emit_move_insn (gen_rtx (MEM, SImode, plus_constant (addr, 32)), CHAIN);  \
        !          2008:                                                                            \
        !          2009:   /* Flush the instruction cache.  */                                      \
        !          2010:   emit_library_call (gen_rtx (SYMBOL_REF, Pmode, "__gcc_flush_cache"), \
        !          2011:                     0, VOIDmode, 1, addr, Pmode);                          \
        !          2012: }
        !          2013: 
        !          2014: /* Flush the instruction cache.  */
        !          2015: 
        !          2016: #define TRANSFER_FROM_TRAMPOLINE                                       \
        !          2017:                                                                        \
        !          2018: void                                                                   \
        !          2019: __gcc_flush_cache (addr)                                               \
        !          2020:      char *addr;                                                       \
        !          2021: {                                                                      \
        !          2022:   if (cacheflush (addr, TRAMPOLINE_SIZE, 1) < 0)                       \
        !          2023:     perror ("cacheflush of trampoline code");                          \
        !          2024: }
        !          2025: 
        !          2026: /* Addressing modes, and classification of registers for them.  */
        !          2027: 
        !          2028: /* #define HAVE_POST_INCREMENT */
        !          2029: /* #define HAVE_POST_DECREMENT */
        !          2030: 
        !          2031: /* #define HAVE_PRE_DECREMENT */
        !          2032: /* #define HAVE_PRE_INCREMENT */
        !          2033: 
        !          2034: /* These assume that REGNO is a hard or pseudo reg number.
        !          2035:    They give nonzero only if REGNO is a hard reg of the suitable class
        !          2036:    or a pseudo reg currently allocated to a suitable hard reg.
        !          2037:    These definitions are NOT overridden anywhere.  */
        !          2038: 
        !          2039: #define GP_REG_OR_PSEUDO_STRICT_P(regno) \
        !          2040:   GP_REG_P((regno < FIRST_PSEUDO_REGISTER) ? regno : reg_renumber[regno])
        !          2041: 
        !          2042: #define GP_REG_OR_PSEUDO_NONSTRICT_P(regno) \
        !          2043:   (((regno) >= FIRST_PSEUDO_REGISTER) || (GP_REG_P (regno)))
        !          2044: 
        !          2045: #define REGNO_OK_FOR_INDEX_P(regno)    GP_REG_OR_PSEUDO_STRICT_P (regno)
        !          2046: #define REGNO_OK_FOR_BASE_P(regno)     GP_REG_OR_PSEUDO_STRICT_P (regno)
        !          2047: 
        !          2048: /* The macros REG_OK_FOR..._P assume that the arg is a REG rtx
        !          2049:    and check its validity for a certain class.
        !          2050:    We have two alternate definitions for each of them.
        !          2051:    The usual definition accepts all pseudo regs; the other rejects them all.
        !          2052:    The symbol REG_OK_STRICT causes the latter definition to be used.
        !          2053: 
        !          2054:    Most source files want to accept pseudo regs in the hope that
        !          2055:    they will get allocated to the class that the insn wants them to be in.
        !          2056:    Some source files that are used after register allocation
        !          2057:    need to be strict.  */
        !          2058: 
        !          2059: #ifndef REG_OK_STRICT
        !          2060: 
        !          2061: #define REG_OK_STRICT_P 0
        !          2062: #define REG_OK_FOR_INDEX_P(X) GP_REG_OR_PSEUDO_NONSTRICT_P (REGNO (X))
        !          2063: #define REG_OK_FOR_BASE_P(X)  GP_REG_OR_PSEUDO_NONSTRICT_P (REGNO (X))
        !          2064: 
        !          2065: #else
        !          2066: 
        !          2067: #define REG_OK_STRICT_P 1
        !          2068: #define REG_OK_FOR_INDEX_P(X) REGNO_OK_FOR_INDEX_P (REGNO (X))
        !          2069: #define REG_OK_FOR_BASE_P(X)  REGNO_OK_FOR_BASE_P  (REGNO (X))
        !          2070: 
        !          2071: #endif
        !          2072: 
        !          2073: 
        !          2074: /* Maximum number of registers that can appear in a valid memory address.  */
        !          2075: 
        !          2076: #define MAX_REGS_PER_ADDRESS 1
        !          2077: 
        !          2078: /* A C compound statement with a conditional `goto LABEL;' executed
        !          2079:    if X (an RTX) is a legitimate memory address on the target
        !          2080:    machine for a memory operand of mode MODE.
        !          2081: 
        !          2082:    It usually pays to define several simpler macros to serve as
        !          2083:    subroutines for this one.  Otherwise it may be too complicated
        !          2084:    to understand.
        !          2085: 
        !          2086:    This macro must exist in two variants: a strict variant and a
        !          2087:    non-strict one.  The strict variant is used in the reload pass. 
        !          2088:    It must be defined so that any pseudo-register that has not been
        !          2089:    allocated a hard register is considered a memory reference.  In
        !          2090:    contexts where some kind of register is required, a
        !          2091:    pseudo-register with no hard register must be rejected.
        !          2092: 
        !          2093:    The non-strict variant is used in other passes.  It must be
        !          2094:    defined to accept all pseudo-registers in every context where
        !          2095:    some kind of register is required.
        !          2096: 
        !          2097:    Compiler source files that want to use the strict variant of
        !          2098:    this macro define the macro `REG_OK_STRICT'.  You should use an
        !          2099:    `#ifdef REG_OK_STRICT' conditional to define the strict variant
        !          2100:    in that case and the non-strict variant otherwise.
        !          2101: 
        !          2102:    Typically among the subroutines used to define
        !          2103:    `GO_IF_LEGITIMATE_ADDRESS' are subroutines to check for
        !          2104:    acceptable registers for various purposes (one for base
        !          2105:    registers, one for index registers, and so on).  Then only these
        !          2106:    subroutine macros need have two variants; the higher levels of
        !          2107:    macros may be the same whether strict or not.
        !          2108: 
        !          2109:    Normally, constant addresses which are the sum of a `symbol_ref'
        !          2110:    and an integer are stored inside a `const' RTX to mark them as
        !          2111:    constant.  Therefore, there is no need to recognize such sums
        !          2112:    specifically as legitimate addresses.  Normally you would simply
        !          2113:    recognize any `const' as legitimate.
        !          2114: 
        !          2115:    Usually `PRINT_OPERAND_ADDRESS' is not prepared to handle
        !          2116:    constant sums that are not marked with  `const'.  It assumes
        !          2117:    that a naked `plus' indicates indexing.  If so, then you *must*
        !          2118:    reject such naked constant sums as illegitimate addresses, so
        !          2119:    that none of them will be given to `PRINT_OPERAND_ADDRESS'.
        !          2120: 
        !          2121:    On some machines, whether a symbolic address is legitimate
        !          2122:    depends on the section that the address refers to.  On these
        !          2123:    machines, define the macro `ENCODE_SECTION_INFO' to store the
        !          2124:    information into the `symbol_ref', and then check for it here. 
        !          2125:    When you see a `const', you will have to look inside it to find
        !          2126:    the `symbol_ref' in order to determine the section.  */
        !          2127: 
        !          2128: #if 1
        !          2129: #define GO_PRINTF(x)   trace(x)
        !          2130: #define GO_PRINTF2(x,y)        trace(x,y)
        !          2131: #define GO_DEBUG_RTX(x) debug_rtx(x)
        !          2132: 
        !          2133: #else
        !          2134: #define GO_PRINTF(x)
        !          2135: #define GO_PRINTF2(x,y)
        !          2136: #define GO_DEBUG_RTX(x)
        !          2137: #endif
        !          2138: 
        !          2139: #define GO_IF_LEGITIMATE_ADDRESS(MODE, X, ADDR)                                \
        !          2140: {                                                                      \
        !          2141:   register rtx xinsn = (X);                                            \
        !          2142:                                                                        \
        !          2143:   if (TARGET_DEBUG_B_MODE)                                             \
        !          2144:     {                                                                  \
        !          2145:       GO_PRINTF2 ("\n========== GO_IF_LEGITIMATE_ADDRESS, %sstrict\n", \
        !          2146:                  (REG_OK_STRICT_P) ? "" : "not ");                     \
        !          2147:       GO_DEBUG_RTX (xinsn);                                            \
        !          2148:     }                                                                  \
        !          2149:                                                                        \
        !          2150:   if (GET_CODE (xinsn) == REG && REG_OK_FOR_BASE_P (xinsn))            \
        !          2151:     goto ADDR;                                                         \
        !          2152:                                                                        \
        !          2153:   if (CONSTANT_ADDRESS_P (xinsn))                                      \
        !          2154:     goto ADDR;                                                         \
        !          2155:                                                                        \
        !          2156:   if (GET_CODE (xinsn) == PLUS)                                                \
        !          2157:     {                                                                  \
        !          2158:       register rtx xplus0 = XEXP (xinsn, 0);                           \
        !          2159:       register rtx xplus1 = XEXP (xinsn, 1);                           \
        !          2160:       register enum rtx_code code0 = GET_CODE (xplus0);                        \
        !          2161:       register enum rtx_code code1 = GET_CODE (xplus1);                        \
        !          2162:                                                                        \
        !          2163:       if (code0 != REG && code1 == REG)                                        \
        !          2164:        {                                                               \
        !          2165:          xplus0 = XEXP (xinsn, 1);                                     \
        !          2166:          xplus1 = XEXP (xinsn, 0);                                     \
        !          2167:          code0 = GET_CODE (xplus0);                                    \
        !          2168:          code1 = GET_CODE (xplus1);                                    \
        !          2169:        }                                                               \
        !          2170:                                                                        \
        !          2171:       if (code0 == REG && REG_OK_FOR_BASE_P (xplus0))                  \
        !          2172:        {                                                               \
        !          2173:          if (code1 == CONST_INT)                                       \
        !          2174:            {                                                           \
        !          2175:              register unsigned adj_offset = INTVAL (xplus1) + 0x8000;  \
        !          2176:                                                                        \
        !          2177:              if ((adj_offset <= 0xffff)                                \
        !          2178:                  && (adj_offset + GET_MODE_SIZE (MODE) - 1 <= 0xffff)) \
        !          2179:                goto ADDR;                                              \
        !          2180:            }                                                           \
        !          2181:                                                                        \
        !          2182:          /* For some code sequences, you actually get better code by   \
        !          2183:             pretending that the MIPS supports an address mode of a     \
        !          2184:             constant address + a register, even though the real        \
        !          2185:             machine doesn't support it.  This is because the           \
        !          2186:             assembler can use $r1 to load just the high 16 bits, add   \
        !          2187:             in the register, and fold the low 16 bits into the memory  \
        !          2188:             reference, whereas the compiler generates a 4 instruction  \
        !          2189:             sequence.  On the other hand, CSE is not as effective.     \
        !          2190:             It would be a win to generate the lui directly, but the    \
        !          2191:             MIPS assembler does not have syntax to generate the        \
        !          2192:             appropriate relocation.  */                                \
        !          2193:                                                                        \
        !          2194:          else if (!TARGET_DEBUG_A_MODE                                 \
        !          2195:                   && code0 == REG                                      \
        !          2196:                   && CONSTANT_ADDRESS_P (xplus1))                      \
        !          2197:            goto ADDR;                                                  \
        !          2198:        }                                                               \
        !          2199:     }                                                                  \
        !          2200:                                                                        \
        !          2201:   if (TARGET_DEBUG_B_MODE)                                             \
        !          2202:     GO_PRINTF ("Not a legitimate address\n");                          \
        !          2203: }
        !          2204: 
        !          2205: 
        !          2206: /* A C expression that is 1 if the RTX X is a constant which is a
        !          2207:    valid address.  This is defined to be the same as `CONSTANT_P (X)',
        !          2208:    but rejecting CONST_DOUBLE.  */
        !          2209: #define CONSTANT_ADDRESS_P(X)                                          \
        !          2210:   ((GET_CODE (X) == LABEL_REF || GET_CODE (X) == SYMBOL_REF            \
        !          2211:    || GET_CODE (X) == CONST_INT || GET_CODE (X) == CONST               \
        !          2212:    || GET_CODE (X) == HIGH) && (!HALF_PIC_P () || !HALF_PIC_ADDRESS_P (X)))
        !          2213: 
        !          2214: 
        !          2215: /* Nonzero if the constant value X is a legitimate general operand.
        !          2216:    It is given that X satisfies CONSTANT_P or is a CONST_DOUBLE.
        !          2217: 
        !          2218:    At present, GAS doesn't understand li.[sd], so don't allow it
        !          2219:    to be generated at present.  Also, the MIPS assembler does not
        !          2220:    grok li.d Infinity.  */
        !          2221: 
        !          2222: #define LEGITIMATE_CONSTANT_P(X)                                       \
        !          2223:   (GET_CODE (X) != CONST_DOUBLE || mips_const_double_ok (X, GET_MODE (X)))
        !          2224: 
        !          2225: 
        !          2226: /* A C compound statement that attempts to replace X with a valid
        !          2227:    memory address for an operand of mode MODE.  WIN will be a C
        !          2228:    statement label elsewhere in the code; the macro definition may
        !          2229:    use
        !          2230: 
        !          2231:           GO_IF_LEGITIMATE_ADDRESS (MODE, X, WIN);
        !          2232: 
        !          2233:    to avoid further processing if the address has become legitimate.
        !          2234: 
        !          2235:    X will always be the result of a call to `break_out_memory_refs',
        !          2236:    and OLDX will be the operand that was given to that function to
        !          2237:    produce X.
        !          2238: 
        !          2239:    The code generated by this macro should not alter the
        !          2240:    substructure of X.  If it transforms X into a more legitimate
        !          2241:    form, it should assign X (which will always be a C variable) a
        !          2242:    new value.
        !          2243: 
        !          2244:    It is not necessary for this macro to come up with a legitimate
        !          2245:    address.  The compiler has standard ways of doing so in all
        !          2246:    cases.  In fact, it is safe for this macro to do nothing.  But
        !          2247:    often a machine-dependent strategy can generate better code.
        !          2248: 
        !          2249:    For the MIPS, transform:
        !          2250: 
        !          2251:        memory(X + <large int>)
        !          2252: 
        !          2253:    into:
        !          2254: 
        !          2255:        Y = <large int> & ~0x7fff;
        !          2256:        Z = X + Y
        !          2257:        memory (Z + (<large int> & 0x7fff));
        !          2258: 
        !          2259:    This is for CSE to find several similar references, and only use one Z.  */
        !          2260: 
        !          2261: #define LEGITIMIZE_ADDRESS(X,OLDX,MODE,WIN)                            \
        !          2262: {                                                                      \
        !          2263:   register rtx xinsn = (X);                                            \
        !          2264:                                                                        \
        !          2265:   if (TARGET_DEBUG_B_MODE)                                             \
        !          2266:     {                                                                  \
        !          2267:       GO_PRINTF ("\n========== LEGITIMIZE_ADDRESS\n");                 \
        !          2268:       GO_DEBUG_RTX (xinsn);                                            \
        !          2269:     }                                                                  \
        !          2270:                                                                        \
        !          2271:   if (GET_CODE (xinsn) == PLUS)                                                \
        !          2272:     {                                                                  \
        !          2273:       register rtx xplus0 = XEXP (xinsn, 0);                           \
        !          2274:       register rtx xplus1 = XEXP (xinsn, 1);                           \
        !          2275:       register enum rtx_code code0 = GET_CODE (xplus0);                        \
        !          2276:       register enum rtx_code code1 = GET_CODE (xplus1);                        \
        !          2277:                                                                        \
        !          2278:       if (code0 != REG && code1 == REG)                                        \
        !          2279:        {                                                               \
        !          2280:          xplus0 = XEXP (xinsn, 1);                                     \
        !          2281:          xplus1 = XEXP (xinsn, 0);                                     \
        !          2282:          code0 = GET_CODE (xplus0);                                    \
        !          2283:          code1 = GET_CODE (xplus1);                                    \
        !          2284:        }                                                               \
        !          2285:                                                                        \
        !          2286:       if (code0 == REG && REG_OK_FOR_BASE_P (xplus0)                   \
        !          2287:          && code1 == CONST_INT && !SMALL_INT (xplus1))                 \
        !          2288:        {                                                               \
        !          2289:          rtx int_reg = gen_reg_rtx (Pmode);                            \
        !          2290:          rtx ptr_reg = gen_reg_rtx (Pmode);                            \
        !          2291:                                                                        \
        !          2292:          emit_move_insn (int_reg,                                      \
        !          2293:                          GEN_INT (INTVAL (xplus1) & ~ 0x7fff));        \
        !          2294:                                                                        \
        !          2295:          emit_insn (gen_rtx (SET, VOIDmode,                            \
        !          2296:                              ptr_reg,                                  \
        !          2297:                              gen_rtx (PLUS, Pmode, xplus0, int_reg))); \
        !          2298:                                                                        \
        !          2299:          X = gen_rtx (PLUS, Pmode, ptr_reg,                            \
        !          2300:                       GEN_INT (INTVAL (xplus1) & 0x7fff));             \
        !          2301:          goto WIN;                                                     \
        !          2302:        }                                                               \
        !          2303:     }                                                                  \
        !          2304:                                                                        \
        !          2305:   if (TARGET_DEBUG_B_MODE)                                             \
        !          2306:     GO_PRINTF ("LEGITIMIZE_ADDRESS could not fix.\n");                 \
        !          2307: }
        !          2308: 
        !          2309: 
        !          2310: /* A C statement or compound statement with a conditional `goto
        !          2311:    LABEL;' executed if memory address X (an RTX) can have different
        !          2312:    meanings depending on the machine mode of the memory reference it
        !          2313:    is used for.
        !          2314: 
        !          2315:    Autoincrement and autodecrement addresses typically have
        !          2316:    mode-dependent effects because the amount of the increment or
        !          2317:    decrement is the size of the operand being addressed.  Some
        !          2318:    machines have other mode-dependent addresses.  Many RISC machines
        !          2319:    have no mode-dependent addresses.
        !          2320: 
        !          2321:    You may assume that ADDR is a valid address for the machine.  */
        !          2322: 
        !          2323: #define GO_IF_MODE_DEPENDENT_ADDRESS(ADDR,LABEL) {}
        !          2324: 
        !          2325: 
        !          2326: /* Define this macro if references to a symbol must be treated
        !          2327:    differently depending on something about the variable or
        !          2328:    function named by the symbol (such as what section it is in).
        !          2329: 
        !          2330:    The macro definition, if any, is executed immediately after the
        !          2331:    rtl for DECL has been created and stored in `DECL_RTL (DECL)'. 
        !          2332:    The value of the rtl will be a `mem' whose address is a
        !          2333:    `symbol_ref'.
        !          2334: 
        !          2335:    The usual thing for this macro to do is to a flag in the
        !          2336:    `symbol_ref' (such as `SYMBOL_REF_FLAG') or to store a modified
        !          2337:    name string in the `symbol_ref' (if one bit is not enough
        !          2338:    information).
        !          2339: 
        !          2340:    The best way to modify the name string is by adding text to the
        !          2341:    beginning, with suitable punctuation to prevent any ambiguity. 
        !          2342:    Allocate the new name in `saveable_obstack'.  You will have to
        !          2343:    modify `ASM_OUTPUT_LABELREF' to remove and decode the added text
        !          2344:    and output the name accordingly.
        !          2345: 
        !          2346:    You can also check the information stored in the `symbol_ref' in
        !          2347:    the definition of `GO_IF_LEGITIMATE_ADDRESS' or
        !          2348:    `PRINT_OPERAND_ADDRESS'. */
        !          2349: 
        !          2350: #define ENCODE_SECTION_INFO(DECL)                                      \
        !          2351: do                                                                     \
        !          2352:   {                                                                    \
        !          2353:     if (optimize && mips_section_threshold > 0 && TARGET_GP_OPT                \
        !          2354:        && TREE_CODE (DECL) == VAR_DECL)                                \
        !          2355:       {                                                                        \
        !          2356:        int size = int_size_in_bytes (TREE_TYPE (DECL));                \
        !          2357:                                                                        \
        !          2358:        if (size > 0 && size <= mips_section_threshold)                 \
        !          2359:          SYMBOL_REF_FLAG (XEXP (DECL_RTL (DECL), 0)) = 1;              \
        !          2360:       }                                                                        \
        !          2361:                                                                        \
        !          2362:     else if (HALF_PIC_P ())                                            \
        !          2363:       HALF_PIC_ENCODE (DECL);                                          \
        !          2364:   }                                                                    \
        !          2365: while (0)
        !          2366: 
        !          2367: 
        !          2368: /* Specify the machine mode that this machine uses
        !          2369:    for the index in the tablejump instruction.  */
        !          2370: #define CASE_VECTOR_MODE SImode
        !          2371: 
        !          2372: /* Define this if the tablejump instruction expects the table
        !          2373:    to contain offsets from the address of the table.
        !          2374:    Do not define this if the table should contain absolute addresses.  */
        !          2375: /* #define CASE_VECTOR_PC_RELATIVE */
        !          2376: 
        !          2377: /* Specify the tree operation to be used to convert reals to integers.  */
        !          2378: #define IMPLICIT_FIX_EXPR FIX_ROUND_EXPR
        !          2379: 
        !          2380: /* This is the kind of divide that is easiest to do in the general case.  */
        !          2381: #define EASY_DIV_EXPR TRUNC_DIV_EXPR
        !          2382: 
        !          2383: /* Define this as 1 if `char' should by default be signed; else as 0.  */
        !          2384: #ifndef DEFAULT_SIGNED_CHAR
        !          2385: #define DEFAULT_SIGNED_CHAR 1
        !          2386: #endif
        !          2387: 
        !          2388: /* Max number of bytes we can move from memory to memory
        !          2389:    in one reasonably fast instruction.  */
        !          2390: #define MOVE_MAX 4
        !          2391: 
        !          2392: /* Define this macro as a C expression which is nonzero if
        !          2393:    accessing less than a word of memory (i.e. a `char' or a
        !          2394:    `short') is no faster than accessing a word of memory, i.e., if
        !          2395:    such access require more than one instruction or if there is no
        !          2396:    difference in cost between byte and (aligned) word loads.
        !          2397: 
        !          2398:    On RISC machines, it tends to generate better code to define
        !          2399:    this as 1, since it avoids making a QI or HI mode register.  */
        !          2400: #define SLOW_BYTE_ACCESS 1
        !          2401: 
        !          2402: /* We assume that the store-condition-codes instructions store 0 for false
        !          2403:    and some other value for true.  This is the value stored for true.  */
        !          2404: 
        !          2405: #define STORE_FLAG_VALUE 1
        !          2406: 
        !          2407: /* Define this if zero-extension is slow (more than one real instruction).  */
        !          2408: #define SLOW_ZERO_EXTEND
        !          2409: 
        !          2410: /* Define this to be nonzero if shift instructions ignore all but the low-order
        !          2411:    few bits. */
        !          2412: #define SHIFT_COUNT_TRUNCATED 1
        !          2413: 
        !          2414: /* Value is 1 if truncating an integer of INPREC bits to OUTPREC bits
        !          2415:    is done just by pretending it is already truncated.  */
        !          2416: #define TRULY_NOOP_TRUNCATION(OUTPREC, INPREC) 1
        !          2417: 
        !          2418: /* Define this macro to control use of the character `$' in
        !          2419:    identifier names.  The value should be 0, 1, or 2.  0 means `$'
        !          2420:    is not allowed by default; 1 means it is allowed by default if
        !          2421:    `-traditional' is used; 2 means it is allowed by default provided
        !          2422:    `-ansi' is not used.  1 is the default; there is no need to
        !          2423:    define this macro in that case. */
        !          2424: 
        !          2425: #ifndef DOLLARS_IN_IDENTIFIERS
        !          2426: #define DOLLARS_IN_IDENTIFIERS 1
        !          2427: #endif
        !          2428: 
        !          2429: /* Specify the machine mode that pointers have.
        !          2430:    After generation of rtl, the compiler makes no further distinction
        !          2431:    between pointers and any other objects of this machine mode.  */
        !          2432: #define Pmode SImode
        !          2433: 
        !          2434: /* A function address in a call instruction
        !          2435:    is a word address (for indexing purposes)
        !          2436:    so give the MEM rtx a words's mode.  */
        !          2437: 
        !          2438: #define FUNCTION_MODE SImode
        !          2439: 
        !          2440: /* Define TARGET_MEM_FUNCTIONS if we want to use calls to memcpy and
        !          2441:    memset, instead of the BSD functions bcopy and bzero.  */
        !          2442: 
        !          2443: #if defined(MIPS_SYSV) || defined(OSF_OS)
        !          2444: #define TARGET_MEM_FUNCTIONS
        !          2445: #endif
        !          2446: 
        !          2447: 
        !          2448: /* A part of a C `switch' statement that describes the relative
        !          2449:    costs of constant RTL expressions.  It must contain `case'
        !          2450:    labels for expression codes `const_int', `const', `symbol_ref',
        !          2451:    `label_ref' and `const_double'.  Each case must ultimately reach
        !          2452:    a `return' statement to return the relative cost of the use of
        !          2453:    that kind of constant value in an expression.  The cost may
        !          2454:    depend on the precise value of the constant, which is available
        !          2455:    for examination in X.
        !          2456: 
        !          2457:    CODE is the expression code--redundant, since it can be obtained
        !          2458:    with `GET_CODE (X)'.  */
        !          2459: 
        !          2460: #define CONST_COSTS(X,CODE,OUTER_CODE)                                 \
        !          2461:   case CONST_INT:                                                      \
        !          2462:     /* Always return 0, since we don't have different sized            \
        !          2463:        instructions, hence different costs according to Richard                \
        !          2464:        Kenner */                                                       \
        !          2465:     return COSTS_N_INSNS (0);                                          \
        !          2466:                                                                        \
        !          2467:   case LABEL_REF:                                                      \
        !          2468:     return COSTS_N_INSNS (2);                                          \
        !          2469:                                                                        \
        !          2470:   case CONST:                                                          \
        !          2471:     {                                                                  \
        !          2472:       rtx offset = const0_rtx;                                         \
        !          2473:       rtx symref = eliminate_constant_term (X, &offset);               \
        !          2474:                                                                        \
        !          2475:       if (GET_CODE (symref) == LABEL_REF)                              \
        !          2476:        return COSTS_N_INSNS (2);                                       \
        !          2477:                                                                        \
        !          2478:       if (GET_CODE (symref) != SYMBOL_REF)                             \
        !          2479:        return COSTS_N_INSNS (4);                                       \
        !          2480:                                                                        \
        !          2481:       /* let's be paranoid.... */                                      \
        !          2482:       if (INTVAL (offset) < -32768 || INTVAL (offset) > 32767)         \
        !          2483:        return COSTS_N_INSNS (2);                                       \
        !          2484:                                                                        \
        !          2485:       return COSTS_N_INSNS (SYMBOL_REF_FLAG (symref) ? 1 : 2);         \
        !          2486:     }                                                                  \
        !          2487:                                                                        \
        !          2488:   case SYMBOL_REF:                                                     \
        !          2489:     return COSTS_N_INSNS (SYMBOL_REF_FLAG (X) ? 1 : 2);                        \
        !          2490:                                                                        \
        !          2491:   case CONST_DOUBLE:                                                   \
        !          2492:     return COSTS_N_INSNS ((CONST_DOUBLE_HIGH (X) == 0                  \
        !          2493:                           && CONST_DOUBLE_LOW (X)) ? 2 : 4);
        !          2494: 
        !          2495: 
        !          2496: /* Like `CONST_COSTS' but applies to nonconstant RTL expressions.
        !          2497:    This can be used, for example, to indicate how costly a multiply
        !          2498:    instruction is.  In writing this macro, you can use the construct
        !          2499:    `COSTS_N_INSNS (N)' to specify a cost equal to N fast instructions.
        !          2500: 
        !          2501:    This macro is optional; do not define it if the default cost
        !          2502:    assumptions are adequate for the target machine.
        !          2503: 
        !          2504:    If -mdebugd is used, change the multiply cost to 2, so multiply by
        !          2505:    a constant isn't converted to a series of shifts.  This helps
        !          2506:    strength reduction, and also makes it easier to identify what the
        !          2507:    compiler is doing.  */
        !          2508: 
        !          2509: #define RTX_COSTS(X,CODE,OUTER_CODE)                                   \
        !          2510:   case MEM:                                                            \
        !          2511:     {                                                                  \
        !          2512:       int num_words = (GET_MODE_SIZE (GET_MODE (X)) > UNITS_PER_WORD) ? 2 : 1; \
        !          2513:       if (simple_memory_operand (X, GET_MODE (X)))                     \
        !          2514:        return COSTS_N_INSNS (num_words);                               \
        !          2515:                                                                        \
        !          2516:       return COSTS_N_INSNS (2*num_words);                              \
        !          2517:     }                                                                  \
        !          2518:                                                                        \
        !          2519:   case FFS:                                                            \
        !          2520:     return COSTS_N_INSNS (6);                                          \
        !          2521:                                                                        \
        !          2522:   case NOT:                                                            \
        !          2523:     return COSTS_N_INSNS ((GET_MODE (X) == DImode) ? 2 : 1);           \
        !          2524:                                                                        \
        !          2525:   case AND:                                                            \
        !          2526:   case IOR:                                                            \
        !          2527:   case XOR:                                                            \
        !          2528:     if (GET_MODE (X) == DImode)                                                \
        !          2529:       return COSTS_N_INSNS (2);                                                \
        !          2530:                                                                        \
        !          2531:     if (GET_CODE (XEXP (X, 1)) == CONST_INT)                           \
        !          2532:       {                                                                        \
        !          2533:        rtx number = XEXP (X, 1);                                       \
        !          2534:        if (SMALL_INT_UNSIGNED (number))                                \
        !          2535:          return COSTS_N_INSNS (1);                                     \
        !          2536:                                                                        \
        !          2537:        else if (SMALL_INT (number))                                    \
        !          2538:          return COSTS_N_INSNS (2);                                     \
        !          2539:                                                                        \
        !          2540:        return COSTS_N_INSNS (3);                                       \
        !          2541:       }                                                                        \
        !          2542:                                                                        \
        !          2543:     return COSTS_N_INSNS (1);                                          \
        !          2544:                                                                        \
        !          2545:   case ASHIFT:                                                         \
        !          2546:   case ASHIFTRT:                                                       \
        !          2547:   case LSHIFT:                                                         \
        !          2548:   case LSHIFTRT:                                                       \
        !          2549:     if (GET_MODE (X) == DImode)                                                \
        !          2550:       return COSTS_N_INSNS ((GET_CODE (XEXP (X, 1)) == CONST_INT) ? 12 : 4); \
        !          2551:                                                                        \
        !          2552:     return COSTS_N_INSNS (1);                                          \
        !          2553:                                                                        \
        !          2554:   case ABS:                                                            \
        !          2555:     {                                                                  \
        !          2556:       enum machine_mode xmode = GET_MODE (X);                          \
        !          2557:       if (xmode == SFmode || xmode == DFmode)                          \
        !          2558:        return COSTS_N_INSNS (1);                                       \
        !          2559:                                                                        \
        !          2560:       return COSTS_N_INSNS (4);                                                \
        !          2561:     }                                                                  \
        !          2562:                                                                        \
        !          2563:   case PLUS:                                                           \
        !          2564:   case MINUS:                                                          \
        !          2565:     {                                                                  \
        !          2566:       enum machine_mode xmode = GET_MODE (X);                          \
        !          2567:       if (xmode == SFmode || xmode == DFmode)                          \
        !          2568:        return COSTS_N_INSNS (2);                                       \
        !          2569:                                                                        \
        !          2570:       if (xmode == DImode)                                             \
        !          2571:        return COSTS_N_INSNS (4);                                       \
        !          2572:                                                                        \
        !          2573:       return COSTS_N_INSNS (1);                                                \
        !          2574:     }                                                                  \
        !          2575:                                                                        \
        !          2576:   case NEG:                                                            \
        !          2577:     return COSTS_N_INSNS ((GET_MODE (X) == DImode) ? 4 : 1);           \
        !          2578:                                                                        \
        !          2579:   case MULT:                                                           \
        !          2580:     {                                                                  \
        !          2581:       enum machine_mode xmode = GET_MODE (X);                          \
        !          2582:       if (xmode == SFmode)                                             \
        !          2583:        return COSTS_N_INSNS (4);                                       \
        !          2584:                                                                        \
        !          2585:       if (xmode == DFmode)                                             \
        !          2586:        return COSTS_N_INSNS (5);                                       \
        !          2587:                                                                        \
        !          2588:       return COSTS_N_INSNS (12);                                       \
        !          2589:     }                                                                  \
        !          2590:                                                                        \
        !          2591:   case DIV:                                                            \
        !          2592:   case MOD:                                                            \
        !          2593:     {                                                                  \
        !          2594:       enum machine_mode xmode = GET_MODE (X);                          \
        !          2595:       if (xmode == SFmode)                                             \
        !          2596:        return COSTS_N_INSNS (12);                                      \
        !          2597:                                                                        \
        !          2598:       if (xmode == DFmode)                                             \
        !          2599:        return COSTS_N_INSNS (19);                                      \
        !          2600:     }                                                                  \
        !          2601:     /* fall through */                                                 \
        !          2602:                                                                        \
        !          2603:   case UDIV:                                                           \
        !          2604:   case UMOD:                                                           \
        !          2605:     return COSTS_N_INSNS (35);
        !          2606: 
        !          2607: /* An expression giving the cost of an addressing mode that
        !          2608:    contains ADDRESS.  If not defined, the cost is computed from the
        !          2609:    form of the ADDRESS expression and the `CONST_COSTS' values.
        !          2610: 
        !          2611:    For most CISC machines, the default cost is a good approximation
        !          2612:    of the true cost of the addressing mode.  However, on RISC
        !          2613:    machines, all instructions normally have the same length and
        !          2614:    execution time.  Hence all addresses will have equal costs.
        !          2615: 
        !          2616:    In cases where more than one form of an address is known, the
        !          2617:    form with the lowest cost will be used.  If multiple forms have
        !          2618:    the same, lowest, cost, the one that is the most complex will be
        !          2619:    used.
        !          2620: 
        !          2621:    For example, suppose an address that is equal to the sum of a
        !          2622:    register and a constant is used twice in the same basic block. 
        !          2623:    When this macro is not defined, the address will be computed in
        !          2624:    a register and memory references will be indirect through that
        !          2625:    register.  On machines where the cost of the addressing mode
        !          2626:    containing the sum is no higher than that of a simple indirect
        !          2627:    reference, this will produce an additional instruction and
        !          2628:    possibly require an additional register.  Proper specification
        !          2629:    of this macro eliminates this overhead for such machines.
        !          2630: 
        !          2631:    Similar use of this macro is made in strength reduction of loops.
        !          2632: 
        !          2633:    ADDRESS need not be valid as an address.  In such a case, the
        !          2634:    cost is not relevant and can be any value; invalid addresses
        !          2635:    need not be assigned a different cost.
        !          2636: 
        !          2637:    On machines where an address involving more than one register is
        !          2638:    as cheap as an address computation involving only one register,
        !          2639:    defining `ADDRESS_COST' to reflect this can cause two registers
        !          2640:    to be live over a region of code where only one would have been
        !          2641:    if `ADDRESS_COST' were not defined in that manner.  This effect
        !          2642:    should be considered in the definition of this macro. 
        !          2643:    Equivalent costs should probably only be given to addresses with
        !          2644:    different numbers of registers on machines with lots of registers.
        !          2645: 
        !          2646:    This macro will normally either not be defined or be defined as
        !          2647:    a constant. */
        !          2648: 
        !          2649: #define ADDRESS_COST(ADDR) (REG_P (ADDR) ? 1 : mips_address_cost (ADDR))
        !          2650: 
        !          2651: /* A C expression for the cost of moving data from a register in
        !          2652:    class FROM to one in class TO.  The classes are expressed using
        !          2653:    the enumeration values such as `GENERAL_REGS'.  A value of 2 is
        !          2654:    the default; other values are interpreted relative to that.
        !          2655: 
        !          2656:    It is not required that the cost always equal 2 when FROM is the
        !          2657:    same as TO; on some machines it is expensive to move between
        !          2658:    registers if they are not general registers.
        !          2659: 
        !          2660:    If reload sees an insn consisting of a single `set' between two
        !          2661:    hard registers, and if `REGISTER_MOVE_COST' applied to their
        !          2662:    classes returns a value of 2, reload does not check to ensure
        !          2663:    that the constraints of the insn are met.  Setting a cost of
        !          2664:    other than 2 will allow reload to verify that the constraints are
        !          2665:    met.  You should do this if the `movM' pattern's constraints do
        !          2666:    not allow such copying.  */
        !          2667: 
        !          2668: #define REGISTER_MOVE_COST(FROM, TO) 4 /* force reload to use constraints */
        !          2669: 
        !          2670: /* A C expression for the cost of a branch instruction.  A value of
        !          2671:    1 is the default; other values are interpreted relative to that.  */
        !          2672: 
        !          2673: #define BRANCH_COST \
        !          2674:   ((mips_cpu == PROCESSOR_R4000 || mips_cpu == PROCESSOR_R6000) ? 2 : 1)
        !          2675: 
        !          2676: 
        !          2677: /* Used in by the peephole code.  */
        !          2678: #define classify_op(op,mode)   (mips_rtx_classify[ (int)GET_CODE (op) ])
        !          2679: #define additive_op(op,mode)   ((classify_op (op,mode) & CLASS_ADD_OP)      != 0)
        !          2680: #define divmod_op(op,mode)     ((classify_op (op,mode) & CLASS_DIVMOD_OP)   != 0)
        !          2681: #define unsigned_op(op,mode)   ((classify_op (op,mode) & CLASS_UNSIGNED_OP) != 0)
        !          2682: 
        !          2683: #define CLASS_ADD_OP           0x01    /* operator is PLUS/MINUS */
        !          2684: #define CLASS_DIVMOD_OP                0x02    /* operator is {,U}{DIV,MOD} */
        !          2685: #define CLASS_UNSIGNED_OP      0x04    /* operator is U{DIV,MOD} */
        !          2686: #define CLASS_CMP_OP           0x08    /* operator is comparison */
        !          2687: #define CLASS_EQUALITY_OP      0x10    /* operator is == or != */
        !          2688: #define CLASS_FCMP_OP          0x08    /* operator is fp. compare */
        !          2689: 
        !          2690: #define CLASS_UNS_CMP_OP       (CLASS_UNSIGNED_OP | CLASS_CMP_OP)
        !          2691: 
        !          2692: 
        !          2693: /* Optionally define this if you have added predicates to
        !          2694:    `MACHINE.c'.  This macro is called within an initializer of an
        !          2695:    array of structures.  The first field in the structure is the
        !          2696:    name of a predicate and the second field is an array of rtl
        !          2697:    codes.  For each predicate, list all rtl codes that can be in
        !          2698:    expressions matched by the predicate.  The list should have a
        !          2699:    trailing comma.  Here is an example of two entries in the list
        !          2700:    for a typical RISC machine:
        !          2701: 
        !          2702:    #define PREDICATE_CODES \
        !          2703:      {"gen_reg_rtx_operand", {SUBREG, REG}},  \
        !          2704:      {"reg_or_short_cint_operand", {SUBREG, REG, CONST_INT}},
        !          2705: 
        !          2706:    Defining this macro does not affect the generated code (however,
        !          2707:    incorrect definitions that omit an rtl code that may be matched
        !          2708:    by the predicate can cause the compiler to malfunction). 
        !          2709:    Instead, it allows the table built by `genrecog' to be more
        !          2710:    compact and efficient, thus speeding up the compiler.  The most
        !          2711:    important predicates to include in the list specified by this
        !          2712:    macro are thoses used in the most insn patterns.  */
        !          2713: 
        !          2714: #define PREDICATE_CODES                                                        \
        !          2715:   {"uns_arith_operand",                { REG, CONST_INT, SUBREG }},            \
        !          2716:   {"arith_operand",            { REG, CONST_INT, SUBREG }},            \
        !          2717:   {"arith32_operand",          { REG, CONST_INT, SUBREG }},            \
        !          2718:   {"reg_or_0_operand",         { REG, CONST_INT, SUBREG }},            \
        !          2719:   {"small_int",                        { CONST_INT }},                         \
        !          2720:   {"large_int",                        { CONST_INT }},                         \
        !          2721:   {"md_register_operand",      { REG }},                               \
        !          2722:   {"mips_const_double_ok",     { CONST_DOUBLE }},                      \
        !          2723:   {"simple_memory_operand",    { MEM, SUBREG }},                       \
        !          2724:   {"equality_op",              { EQ, NE }},                            \
        !          2725:   {"cmp_op",                   { EQ, NE, GT, GE, GTU, GEU, LT, LE,     \
        !          2726:                                  LTU, LEU }},                          \
        !          2727:   {"cmp2_op",                  { EQ, NE, GT, GE, GTU, GEU, LT, LE,     \
        !          2728:                                  LTU, LEU }},                          \
        !          2729:   {"fcmp_op",                  { EQ, NE, GT, GE, LT, LE }},            \
        !          2730:   {"pc_or_label_operand",      { PC, LABEL_REF }},                     \
        !          2731:   {"call_insn_operand",                { MEM }},                               \
        !          2732:   {"uns_cmp_op",               { GTU, GEU, LTU, LEU }},
        !          2733: 
        !          2734: 
        !          2735: /* If defined, a C statement to be executed just prior to the
        !          2736:    output of assembler code for INSN, to modify the extracted
        !          2737:    operands so they will be output differently.
        !          2738: 
        !          2739:    Here the argument OPVEC is the vector containing the operands
        !          2740:    extracted from INSN, and NOPERANDS is the number of elements of
        !          2741:    the vector which contain meaningful data for this insn.  The
        !          2742:    contents of this vector are what will be used to convert the
        !          2743:    insn template into assembler code, so you can change the
        !          2744:    assembler output by changing the contents of the vector.
        !          2745: 
        !          2746:    We use it to check if the current insn needs a nop in front of it
        !          2747:    because of load delays, and also to update the delay slot
        !          2748:    statistics.  */
        !          2749: 
        !          2750: #define FINAL_PRESCAN_INSN(INSN, OPVEC, NOPERANDS)                     \
        !          2751:   final_prescan_insn (INSN, OPVEC, NOPERANDS)
        !          2752: 
        !          2753: 
        !          2754: /* Tell final.c how to eliminate redundant test instructions.
        !          2755:    Here we define machine-dependent flags and fields in cc_status
        !          2756:    (see `conditions.h').  */
        !          2757: 
        !          2758: /* A C compound statement to set the components of `cc_status'
        !          2759:    appropriately for an insn INSN whose body is EXP.  It is this
        !          2760:    macro's responsibility to recognize insns that set the condition
        !          2761:    code as a byproduct of other activity as well as those that
        !          2762:    explicitly set `(cc0)'.
        !          2763: 
        !          2764:    This macro is not used on machines that do not use `cc0'.  */
        !          2765: 
        !          2766: #define NOTICE_UPDATE_CC(EXP, INSN)                                    \
        !          2767: do                                                                     \
        !          2768:   {                                                                    \
        !          2769:     enum attr_type type = get_attr_type (INSN);                                \
        !          2770:     if (type == TYPE_ICMP || type == TYPE_FCMP)                                \
        !          2771:       CC_STATUS_INIT;                                                  \
        !          2772:   }                                                                    \
        !          2773: while (0)
        !          2774: 
        !          2775: /* A list of names to be used for additional modes for condition code
        !          2776:    values in registers.  These names are added to `enum machine_mode'
        !          2777:    and all have class `MODE_CC'.  By convention, they should start
        !          2778:    with `CC' and end with `mode'.
        !          2779: 
        !          2780:    You should only define this macro if your machine does not use
        !          2781:    `cc0' and only if additional modes are required.
        !          2782: 
        !          2783:    On the MIPS, we use CC_FPmode for all floating point except for not
        !          2784:    equal, CC_REV_FPmode for not equal (to reverse the sense of the
        !          2785:    jump), CC_EQmode for integer equality/inequality comparisons,
        !          2786:    CC_0mode for comparisons against 0, and CCmode for other integer
        !          2787:    comparisons. */
        !          2788: 
        !          2789: #define EXTRA_CC_MODES CC_EQmode, CC_FPmode, CC_0mode, CC_REV_FPmode
        !          2790: 
        !          2791: /* A list of C strings giving the names for the modes listed in
        !          2792:    `EXTRA_CC_MODES'.  */
        !          2793: 
        !          2794: #define EXTRA_CC_NAMES "CC_EQ", "CC_FP", "CC_0", "CC_REV_FP"
        !          2795: 
        !          2796: /* Returns a mode from class `MODE_CC' to be used when comparison
        !          2797:    operation code OP is applied to rtx X.  */
        !          2798: 
        !          2799: #define SELECT_CC_MODE(OP, X, Y)                                       \
        !          2800:   (GET_MODE_CLASS (GET_MODE (X)) != MODE_FLOAT                         \
        !          2801:        ? SImode                                                        \
        !          2802:        : ((OP == NE) ? CC_REV_FPmode : CC_FPmode))
        !          2803: 
        !          2804: 
        !          2805: /* Control the assembler format that we output.  */
        !          2806: 
        !          2807: /* Output at beginning of assembler file.
        !          2808:    If we are optimizing to use the global pointer, create a temporary
        !          2809:    file to hold all of the text stuff, and write it out to the end.
        !          2810:    This is needed because the MIPS assembler is evidently one pass,
        !          2811:    and if it hasn't seen the relevant .comm/.lcomm/.extern/.sdata
        !          2812:    declaration when the code is processed, it generates a two
        !          2813:    instruction sequence.  */
        !          2814: 
        !          2815: #define ASM_FILE_START(STREAM) mips_asm_file_start (STREAM)
        !          2816: 
        !          2817: /* Output to assembler file text saying following lines
        !          2818:    may contain character constants, extra white space, comments, etc.  */
        !          2819: 
        !          2820: #define ASM_APP_ON " #APP\n"
        !          2821: 
        !          2822: /* Output to assembler file text saying following lines
        !          2823:    no longer contain unusual constructs.  */
        !          2824: 
        !          2825: #define ASM_APP_OFF " #NO_APP\n"
        !          2826: 
        !          2827: /* How to refer to registers in assembler output.
        !          2828:    This sequence is indexed by compiler's hard-register-number (see above).
        !          2829: 
        !          2830:    In order to support the two different conventions for register names,
        !          2831:    we use the name of a table set up in mips.c, which is overwritten
        !          2832:    if -mrnames is used.  */
        !          2833: 
        !          2834: #define REGISTER_NAMES                                                 \
        !          2835: {                                                                      \
        !          2836:   &mips_reg_names[ 0][0],                                              \
        !          2837:   &mips_reg_names[ 1][0],                                              \
        !          2838:   &mips_reg_names[ 2][0],                                              \
        !          2839:   &mips_reg_names[ 3][0],                                              \
        !          2840:   &mips_reg_names[ 4][0],                                              \
        !          2841:   &mips_reg_names[ 5][0],                                              \
        !          2842:   &mips_reg_names[ 6][0],                                              \
        !          2843:   &mips_reg_names[ 7][0],                                              \
        !          2844:   &mips_reg_names[ 8][0],                                              \
        !          2845:   &mips_reg_names[ 9][0],                                              \
        !          2846:   &mips_reg_names[10][0],                                              \
        !          2847:   &mips_reg_names[11][0],                                              \
        !          2848:   &mips_reg_names[12][0],                                              \
        !          2849:   &mips_reg_names[13][0],                                              \
        !          2850:   &mips_reg_names[14][0],                                              \
        !          2851:   &mips_reg_names[15][0],                                              \
        !          2852:   &mips_reg_names[16][0],                                              \
        !          2853:   &mips_reg_names[17][0],                                              \
        !          2854:   &mips_reg_names[18][0],                                              \
        !          2855:   &mips_reg_names[19][0],                                              \
        !          2856:   &mips_reg_names[20][0],                                              \
        !          2857:   &mips_reg_names[21][0],                                              \
        !          2858:   &mips_reg_names[22][0],                                              \
        !          2859:   &mips_reg_names[23][0],                                              \
        !          2860:   &mips_reg_names[24][0],                                              \
        !          2861:   &mips_reg_names[25][0],                                              \
        !          2862:   &mips_reg_names[26][0],                                              \
        !          2863:   &mips_reg_names[27][0],                                              \
        !          2864:   &mips_reg_names[28][0],                                              \
        !          2865:   &mips_reg_names[29][0],                                              \
        !          2866:   &mips_reg_names[30][0],                                              \
        !          2867:   &mips_reg_names[31][0],                                              \
        !          2868:   &mips_reg_names[32][0],                                              \
        !          2869:   &mips_reg_names[33][0],                                              \
        !          2870:   &mips_reg_names[34][0],                                              \
        !          2871:   &mips_reg_names[35][0],                                              \
        !          2872:   &mips_reg_names[36][0],                                              \
        !          2873:   &mips_reg_names[37][0],                                              \
        !          2874:   &mips_reg_names[38][0],                                              \
        !          2875:   &mips_reg_names[39][0],                                              \
        !          2876:   &mips_reg_names[40][0],                                              \
        !          2877:   &mips_reg_names[41][0],                                              \
        !          2878:   &mips_reg_names[42][0],                                              \
        !          2879:   &mips_reg_names[43][0],                                              \
        !          2880:   &mips_reg_names[44][0],                                              \
        !          2881:   &mips_reg_names[45][0],                                              \
        !          2882:   &mips_reg_names[46][0],                                              \
        !          2883:   &mips_reg_names[47][0],                                              \
        !          2884:   &mips_reg_names[48][0],                                              \
        !          2885:   &mips_reg_names[49][0],                                              \
        !          2886:   &mips_reg_names[50][0],                                              \
        !          2887:   &mips_reg_names[51][0],                                              \
        !          2888:   &mips_reg_names[52][0],                                              \
        !          2889:   &mips_reg_names[53][0],                                              \
        !          2890:   &mips_reg_names[54][0],                                              \
        !          2891:   &mips_reg_names[55][0],                                              \
        !          2892:   &mips_reg_names[56][0],                                              \
        !          2893:   &mips_reg_names[57][0],                                              \
        !          2894:   &mips_reg_names[58][0],                                              \
        !          2895:   &mips_reg_names[59][0],                                              \
        !          2896:   &mips_reg_names[60][0],                                              \
        !          2897:   &mips_reg_names[61][0],                                              \
        !          2898:   &mips_reg_names[62][0],                                              \
        !          2899:   &mips_reg_names[63][0],                                              \
        !          2900:   &mips_reg_names[64][0],                                              \
        !          2901:   &mips_reg_names[65][0],                                              \
        !          2902:   &mips_reg_names[66][0],                                              \
        !          2903: }
        !          2904: 
        !          2905: /* print-rtl.c can't use REGISTER_NAMES, since it depends on mips.c.
        !          2906:    So define this for it.  */
        !          2907: #define DEBUG_REGISTER_NAMES                                           \
        !          2908: {                                                                      \
        !          2909:   "$0",   "at",   "v0",   "v1",   "a0",   "a1",   "a2",   "a3",                \
        !          2910:   "t0",   "t1",   "t2",   "t3",   "t4",   "t5",   "t6",   "t7",                \
        !          2911:   "s0",   "s1",   "s2",   "s3",   "s4",   "s5",   "s6",   "s7",                \
        !          2912:   "t8",   "t9",   "k0",   "k1",   "gp",   "sp",   "$fp",   "ra",       \
        !          2913:   "$f0",  "$f1",  "$f2",  "$f3",  "$f4",  "$f5",  "$f6",  "$f7",       \
        !          2914:   "$f8",  "$f9",  "$f10", "$f11", "$f12", "$f13", "$f14", "$f15",      \
        !          2915:   "$f16", "$f17", "$f18", "$f19", "$f20", "$f21", "$f22", "$f23",      \
        !          2916:   "$f24", "$f25", "$f26", "$f27", "$f28", "$f29", "$f30", "$f31",      \
        !          2917:   "hi",   "lo",   "$fcr31"                                             \
        !          2918: }
        !          2919: 
        !          2920: /* If defined, a C initializer for an array of structures
        !          2921:    containing a name and a register number.  This macro defines
        !          2922:    additional names for hard registers, thus allowing the `asm'
        !          2923:    option in declarations to refer to registers using alternate
        !          2924:    names.
        !          2925: 
        !          2926:    We define both names for the integer registers here.  */
        !          2927: 
        !          2928: #define ADDITIONAL_REGISTER_NAMES                                      \
        !          2929: {                                                                      \
        !          2930:   { "$0",       0 + GP_REG_FIRST },                                    \
        !          2931:   { "$1",       1 + GP_REG_FIRST },                                    \
        !          2932:   { "$2",       2 + GP_REG_FIRST },                                    \
        !          2933:   { "$3",       3 + GP_REG_FIRST },                                    \
        !          2934:   { "$4",       4 + GP_REG_FIRST },                                    \
        !          2935:   { "$5",       5 + GP_REG_FIRST },                                    \
        !          2936:   { "$6",       6 + GP_REG_FIRST },                                    \
        !          2937:   { "$7",       7 + GP_REG_FIRST },                                    \
        !          2938:   { "$8",       8 + GP_REG_FIRST },                                    \
        !          2939:   { "$9",       9 + GP_REG_FIRST },                                    \
        !          2940:   { "$10",     10 + GP_REG_FIRST },                                    \
        !          2941:   { "$11",     11 + GP_REG_FIRST },                                    \
        !          2942:   { "$12",     12 + GP_REG_FIRST },                                    \
        !          2943:   { "$13",     13 + GP_REG_FIRST },                                    \
        !          2944:   { "$14",     14 + GP_REG_FIRST },                                    \
        !          2945:   { "$15",     15 + GP_REG_FIRST },                                    \
        !          2946:   { "$16",     16 + GP_REG_FIRST },                                    \
        !          2947:   { "$17",     17 + GP_REG_FIRST },                                    \
        !          2948:   { "$18",     18 + GP_REG_FIRST },                                    \
        !          2949:   { "$19",     19 + GP_REG_FIRST },                                    \
        !          2950:   { "$20",     20 + GP_REG_FIRST },                                    \
        !          2951:   { "$21",     21 + GP_REG_FIRST },                                    \
        !          2952:   { "$22",     22 + GP_REG_FIRST },                                    \
        !          2953:   { "$23",     23 + GP_REG_FIRST },                                    \
        !          2954:   { "$24",     24 + GP_REG_FIRST },                                    \
        !          2955:   { "$25",     25 + GP_REG_FIRST },                                    \
        !          2956:   { "$26",     26 + GP_REG_FIRST },                                    \
        !          2957:   { "$27",     27 + GP_REG_FIRST },                                    \
        !          2958:   { "$28",     28 + GP_REG_FIRST },                                    \
        !          2959:   { "$29",     29 + GP_REG_FIRST },                                    \
        !          2960:   { "$30",     30 + GP_REG_FIRST },                                    \
        !          2961:   { "$31",     31 + GP_REG_FIRST },                                    \
        !          2962:   { "$sp",     29 + GP_REG_FIRST },                                    \
        !          2963:   { "$fp",     30 + GP_REG_FIRST },                                    \
        !          2964:   { "at",       1 + GP_REG_FIRST },                                    \
        !          2965:   { "v0",       2 + GP_REG_FIRST },                                    \
        !          2966:   { "v1",       3 + GP_REG_FIRST },                                    \
        !          2967:   { "a0",       4 + GP_REG_FIRST },                                    \
        !          2968:   { "a1",       5 + GP_REG_FIRST },                                    \
        !          2969:   { "a2",       6 + GP_REG_FIRST },                                    \
        !          2970:   { "a3",       7 + GP_REG_FIRST },                                    \
        !          2971:   { "t0",       8 + GP_REG_FIRST },                                    \
        !          2972:   { "t1",       9 + GP_REG_FIRST },                                    \
        !          2973:   { "t2",      10 + GP_REG_FIRST },                                    \
        !          2974:   { "t3",      11 + GP_REG_FIRST },                                    \
        !          2975:   { "t4",      12 + GP_REG_FIRST },                                    \
        !          2976:   { "t5",      13 + GP_REG_FIRST },                                    \
        !          2977:   { "t6",      14 + GP_REG_FIRST },                                    \
        !          2978:   { "t7",      15 + GP_REG_FIRST },                                    \
        !          2979:   { "s0",      16 + GP_REG_FIRST },                                    \
        !          2980:   { "s1",      17 + GP_REG_FIRST },                                    \
        !          2981:   { "s2",      18 + GP_REG_FIRST },                                    \
        !          2982:   { "s3",      19 + GP_REG_FIRST },                                    \
        !          2983:   { "s4",      20 + GP_REG_FIRST },                                    \
        !          2984:   { "s5",      21 + GP_REG_FIRST },                                    \
        !          2985:   { "s6",      22 + GP_REG_FIRST },                                    \
        !          2986:   { "s7",      23 + GP_REG_FIRST },                                    \
        !          2987:   { "t8",      24 + GP_REG_FIRST },                                    \
        !          2988:   { "t9",      25 + GP_REG_FIRST },                                    \
        !          2989:   { "k0",      26 + GP_REG_FIRST },                                    \
        !          2990:   { "k1",      27 + GP_REG_FIRST },                                    \
        !          2991:   { "gp",      28 + GP_REG_FIRST },                                    \
        !          2992:   { "sp",      29 + GP_REG_FIRST },                                    \
        !          2993:   { "fp",      30 + GP_REG_FIRST },                                    \
        !          2994:   { "ra",      31 + GP_REG_FIRST },                                    \
        !          2995:   { "$sp",     29 + GP_REG_FIRST },                                    \
        !          2996:   { "$fp",     30 + GP_REG_FIRST },                                    \
        !          2997:   { "cc",      FPSW_REGNUM },                                          \
        !          2998: }
        !          2999: 
        !          3000: /* Define results of standard character escape sequences.  */
        !          3001: #define TARGET_BELL    007
        !          3002: #define TARGET_BS      010
        !          3003: #define TARGET_TAB     011
        !          3004: #define TARGET_NEWLINE 012
        !          3005: #define TARGET_VT      013
        !          3006: #define TARGET_FF      014
        !          3007: #define TARGET_CR      015
        !          3008: 
        !          3009: /* A C compound statement to output to stdio stream STREAM the
        !          3010:    assembler syntax for an instruction operand X.  X is an RTL
        !          3011:    expression.
        !          3012: 
        !          3013:    CODE is a value that can be used to specify one of several ways
        !          3014:    of printing the operand.  It is used when identical operands
        !          3015:    must be printed differently depending on the context.  CODE
        !          3016:    comes from the `%' specification that was used to request
        !          3017:    printing of the operand.  If the specification was just `%DIGIT'
        !          3018:    then CODE is 0; if the specification was `%LTR DIGIT' then CODE
        !          3019:    is the ASCII code for LTR.
        !          3020: 
        !          3021:    If X is a register, this macro should print the register's name.
        !          3022:    The names can be found in an array `reg_names' whose type is
        !          3023:    `char *[]'.  `reg_names' is initialized from `REGISTER_NAMES'.
        !          3024: 
        !          3025:    When the machine description has a specification `%PUNCT' (a `%'
        !          3026:    followed by a punctuation character), this macro is called with
        !          3027:    a null pointer for X and the punctuation character for CODE.
        !          3028: 
        !          3029:    See mips.c for the MIPS specific codes.  */
        !          3030: 
        !          3031: #define PRINT_OPERAND(FILE, X, CODE) print_operand (FILE, X, CODE)
        !          3032: 
        !          3033: /* A C expression which evaluates to true if CODE is a valid
        !          3034:    punctuation character for use in the `PRINT_OPERAND' macro.  If
        !          3035:    `PRINT_OPERAND_PUNCT_VALID_P' is not defined, it means that no
        !          3036:    punctuation characters (except for the standard one, `%') are
        !          3037:    used in this way.  */
        !          3038: 
        !          3039: #define PRINT_OPERAND_PUNCT_VALID_P(CODE) mips_print_operand_punct[CODE]
        !          3040: 
        !          3041: /* A C compound statement to output to stdio stream STREAM the
        !          3042:    assembler syntax for an instruction operand that is a memory
        !          3043:    reference whose address is ADDR.  ADDR is an RTL expression.
        !          3044: 
        !          3045:    On some machines, the syntax for a symbolic address depends on
        !          3046:    the section that the address refers to.  On these machines,
        !          3047:    define the macro `ENCODE_SECTION_INFO' to store the information
        !          3048:    into the `symbol_ref', and then check for it here.  */
        !          3049: 
        !          3050: #define PRINT_OPERAND_ADDRESS(FILE, ADDR) print_operand_address (FILE, ADDR)
        !          3051: 
        !          3052: 
        !          3053: /* A C statement, to be executed after all slot-filler instructions
        !          3054:    have been output.  If necessary, call `dbr_sequence_length' to
        !          3055:    determine the number of slots filled in a sequence (zero if not
        !          3056:    currently outputting a sequence), to decide how many no-ops to
        !          3057:    output, or whatever.
        !          3058: 
        !          3059:    Don't define this macro if it has nothing to do, but it is
        !          3060:    helpful in reading assembly output if the extent of the delay
        !          3061:    sequence is made explicit (e.g. with white space).
        !          3062: 
        !          3063:    Note that output routines for instructions with delay slots must
        !          3064:    be prepared to deal with not being output as part of a sequence
        !          3065:    (i.e.  when the scheduling pass is not run, or when no slot
        !          3066:    fillers could be found.)  The variable `final_sequence' is null
        !          3067:    when not processing a sequence, otherwise it contains the
        !          3068:    `sequence' rtx being output.  */
        !          3069: 
        !          3070: #define DBR_OUTPUT_SEQEND(STREAM)                                      \
        !          3071: do                                                                     \
        !          3072:   {                                                                    \
        !          3073:     if (set_nomacro > 0 && --set_nomacro == 0)                         \
        !          3074:       fputs ("\t.set\tmacro\n", STREAM);                               \
        !          3075:                                                                        \
        !          3076:     if (set_noreorder > 0 && --set_noreorder == 0)                     \
        !          3077:       fputs ("\t.set\treorder\n", STREAM);                             \
        !          3078:                                                                        \
        !          3079:     dslots_jump_filled++;                                              \
        !          3080:     fputs ("\n", STREAM);                                              \
        !          3081:   }                                                                    \
        !          3082: while (0)
        !          3083: 
        !          3084: 
        !          3085: /* How to tell the debugger about changes of source files.  Note, the
        !          3086:    mips ECOFF format cannot deal with changes of files inside of
        !          3087:    functions, which means the output of parser generators like bison
        !          3088:    is generally not debuggable without using the -l switch.  Lose,
        !          3089:    lose, lose.  Silicon graphics seems to want all .file's hardwired
        !          3090:    to 1.  */
        !          3091: 
        !          3092: #ifndef SET_FILE_NUMBER
        !          3093: #define SET_FILE_NUMBER() ++num_source_filenames
        !          3094: #endif
        !          3095: 
        !          3096: #define ASM_OUTPUT_SOURCE_FILENAME(STREAM, NAME)                       \
        !          3097:   mips_output_filename (STREAM, NAME)
        !          3098: 
        !          3099: /* This is how to output a note the debugger telling it the line number
        !          3100:    to which the following sequence of instructions corresponds.
        !          3101:    Silicon graphics puts a label after each .loc.  */
        !          3102: 
        !          3103: #ifndef LABEL_AFTER_LOC
        !          3104: #define LABEL_AFTER_LOC(STREAM)
        !          3105: #endif
        !          3106: 
        !          3107: #define ASM_OUTPUT_SOURCE_LINE(STREAM, LINE)                           \
        !          3108:   mips_output_lineno (STREAM, LINE)
        !          3109: 
        !          3110: /* The MIPS implementation uses some labels for it's own purposed.  The
        !          3111:    following lists what labels are created, and are all formed by the
        !          3112:    pattern $L[a-z].*.  The machine independent portion of GCC creates
        !          3113:    labels matching:  $L[A-Z][0-9]+ and $L[0-9]+.
        !          3114: 
        !          3115:        LM[0-9]+        Silicon Graphics/ECOFF stabs label before each stmt.
        !          3116:        $Lb[0-9]+       Begin blocks for MIPS debug support
        !          3117:        $Lc[0-9]+       Label for use in s<xx> operation.
        !          3118:        $Le[0-9]+       End blocks for MIPS debug support
        !          3119:        $Lp\..+         Half-pic labels. */
        !          3120: 
        !          3121: /* This is how to output the definition of a user-level label named NAME,
        !          3122:    such as the label on a static function or variable NAME.
        !          3123: 
        !          3124:    If we are optimizing the gp, remember that this label has been put
        !          3125:    out, so we know not to emit an .extern for it in mips_asm_file_end.
        !          3126:    We use one of the common bits in the IDENTIFIER tree node for this,
        !          3127:    since those bits seem to be unused, and we don't have any method
        !          3128:    of getting the decl nodes from the name.  */
        !          3129: 
        !          3130: #define ASM_OUTPUT_LABEL(STREAM,NAME)                                  \
        !          3131: do {                                                                   \
        !          3132:   assemble_name (STREAM, NAME);                                                \
        !          3133:   fputs (":\n", STREAM);                                               \
        !          3134: } while (0)
        !          3135: 
        !          3136: 
        !          3137: /* A C statement (sans semicolon) to output to the stdio stream
        !          3138:    STREAM any text necessary for declaring the name NAME of an
        !          3139:    initialized variable which is being defined.  This macro must
        !          3140:    output the label definition (perhaps using `ASM_OUTPUT_LABEL'). 
        !          3141:    The argument DECL is the `VAR_DECL' tree node representing the
        !          3142:    variable.
        !          3143: 
        !          3144:    If this macro is not defined, then the variable name is defined
        !          3145:    in the usual manner as a label (by means of `ASM_OUTPUT_LABEL').  */
        !          3146: 
        !          3147: #define ASM_DECLARE_OBJECT_NAME(STREAM, NAME, DECL)                    \
        !          3148: do                                                                     \
        !          3149:  {                                                                     \
        !          3150:    mips_declare_object (STREAM, NAME, "", ":\n", 0);                   \
        !          3151:    HALF_PIC_DECLARE (NAME);                                            \
        !          3152:  }                                                                     \
        !          3153: while (0)
        !          3154: 
        !          3155: 
        !          3156: /* This is how to output a command to make the user-level label named NAME
        !          3157:    defined for reference from other files.  */
        !          3158: 
        !          3159: #define ASM_GLOBALIZE_LABEL(STREAM,NAME)                               \
        !          3160:   do {                                                                 \
        !          3161:     fputs ("\t.globl\t", STREAM);                                      \
        !          3162:     assemble_name (STREAM, NAME);                                      \
        !          3163:     fputs ("\n", STREAM);                                              \
        !          3164:   } while (0)
        !          3165: 
        !          3166: /* This says how to define a global common symbol.  */
        !          3167: 
        !          3168: #define ASM_OUTPUT_COMMON(STREAM, NAME, SIZE, ROUNDED)                 \
        !          3169:   mips_declare_object (STREAM, NAME, "\n\t.comm\t", ",%u\n", (ROUNDED))
        !          3170: 
        !          3171: /* This says how to define a local common symbol (ie, not visible to
        !          3172:    linker).  */
        !          3173: 
        !          3174: #define ASM_OUTPUT_LOCAL(STREAM, NAME, SIZE, ROUNDED)                  \
        !          3175:   mips_declare_object (STREAM, NAME, "\n\t.lcomm\t", ",%u\n", (ROUNDED))
        !          3176: 
        !          3177: 
        !          3178: /* This says how to output an external.  It would be possible not to
        !          3179:    output anything and let undefined symbol become external. However
        !          3180:    the assembler uses length information on externals to allocate in
        !          3181:    data/sdata bss/sbss, thereby saving exec time.  */
        !          3182: 
        !          3183: #define ASM_OUTPUT_EXTERNAL(STREAM,DECL,NAME) \
        !          3184:   mips_output_external(STREAM,DECL,NAME)
        !          3185: 
        !          3186: /* This says what to print at the end of the assembly file */
        !          3187: #define ASM_FILE_END(STREAM) mips_asm_file_end(STREAM)
        !          3188: 
        !          3189: 
        !          3190: /* This is how to declare a function name.  The actual work of
        !          3191:    emitting the label is moved to function_prologue, so that we can
        !          3192:    get the line number correctly emitted before the .ent directive,
        !          3193:    and after any .file directives.
        !          3194: 
        !          3195:    Also, switch files if we are optimizing the global pointer.  */
        !          3196: 
        !          3197: #define ASM_DECLARE_FUNCTION_NAME(STREAM,NAME,DECL)                    \
        !          3198: {                                                                      \
        !          3199:   extern FILE *asm_out_text_file;                                      \
        !          3200:   if (TARGET_GP_OPT)                                                   \
        !          3201:     STREAM = asm_out_text_file;                                                \
        !          3202:                                                                        \
        !          3203:   current_function_name = NAME;                                                \
        !          3204:   HALF_PIC_DECLARE (NAME);                                             \
        !          3205: }
        !          3206: 
        !          3207: /* This is how to output a reference to a user-level label named NAME.
        !          3208:    `assemble_name' uses this.  */
        !          3209: 
        !          3210: #define ASM_OUTPUT_LABELREF(STREAM,NAME) fprintf (STREAM, "%s", NAME)
        !          3211: 
        !          3212: /* This is how to output an internal numbered label where
        !          3213:    PREFIX is the class of label and NUM is the number within the class.  */
        !          3214: 
        !          3215: #define ASM_OUTPUT_INTERNAL_LABEL(STREAM,PREFIX,NUM)                   \
        !          3216:   fprintf (STREAM, "$%s%d:\n", PREFIX, NUM)
        !          3217: 
        !          3218: /* This is how to store into the string LABEL
        !          3219:    the symbol_ref name of an internal numbered label where
        !          3220:    PREFIX is the class of label and NUM is the number within the class.
        !          3221:    This is suitable for output with `assemble_name'.  */
        !          3222: 
        !          3223: #define ASM_GENERATE_INTERNAL_LABEL(LABEL,PREFIX,NUM)                  \
        !          3224:   sprintf (LABEL, "*$%s%d", PREFIX, NUM)
        !          3225: 
        !          3226: /* This is how to output an assembler line defining a `double' constant.  */
        !          3227: 
        !          3228: #define ASM_OUTPUT_DOUBLE(STREAM,VALUE)                                        \
        !          3229:   mips_output_double (STREAM, VALUE)
        !          3230: 
        !          3231: 
        !          3232: /* This is how to output an assembler line defining a `float' constant.  */
        !          3233: 
        !          3234: #define ASM_OUTPUT_FLOAT(STREAM,VALUE)                                 \
        !          3235:   mips_output_float (STREAM, VALUE)
        !          3236: 
        !          3237: 
        !          3238: /* This is how to output an assembler line defining an `int' constant.  */
        !          3239: 
        !          3240: #define ASM_OUTPUT_INT(STREAM,VALUE)                                   \
        !          3241: do {                                                                   \
        !          3242:   fprintf (STREAM, "\t.word\t");                                       \
        !          3243:   output_addr_const (STREAM, (VALUE));                                 \
        !          3244:   fprintf (STREAM, "\n");                                              \
        !          3245: } while (0)
        !          3246: 
        !          3247: /* Likewise for `char' and `short' constants.  */
        !          3248: 
        !          3249: #define ASM_OUTPUT_SHORT(STREAM,VALUE)                                 \
        !          3250: {                                                                      \
        !          3251:   fprintf (STREAM, "\t.half\t");                                       \
        !          3252:   output_addr_const (STREAM, (VALUE));                                 \
        !          3253:   fprintf (STREAM, "\n");                                              \
        !          3254: }
        !          3255: 
        !          3256: #define ASM_OUTPUT_CHAR(STREAM,VALUE)                                  \
        !          3257: {                                                                      \
        !          3258:   fprintf (STREAM, "\t.byte\t");                                       \
        !          3259:   output_addr_const (STREAM, (VALUE));                                 \
        !          3260:   fprintf (STREAM, "\n");                                              \
        !          3261: }
        !          3262: 
        !          3263: /* This is how to output an assembler line for a numeric constant byte.  */
        !          3264: 
        !          3265: #define ASM_OUTPUT_BYTE(STREAM,VALUE)                                  \
        !          3266:   fprintf (STREAM, "\t.byte\t0x%x\n", (VALUE))
        !          3267: 
        !          3268: /* This is how to output an element of a case-vector that is absolute.  */
        !          3269: 
        !          3270: #define ASM_OUTPUT_ADDR_VEC_ELT(STREAM, VALUE)                         \
        !          3271:   fprintf (STREAM, "\t.word\t$L%d\n", VALUE)
        !          3272: 
        !          3273: /* This is how to output an element of a case-vector that is relative.
        !          3274:    (We  do not use such vectors,
        !          3275:    but we must define this macro anyway.)  */
        !          3276: 
        !          3277: #define ASM_OUTPUT_ADDR_DIFF_ELT(STREAM, VALUE, REL)                   \
        !          3278:   fprintf (STREAM, "\t.word\t$L%d-$L%d\n", VALUE, REL)
        !          3279: 
        !          3280: /* This is how to emit the initial label for switch statements.  We
        !          3281:    need to put the switch labels somewhere else from the text section,
        !          3282:    because the MIPS assembler gets real confused about line numbers if
        !          3283:    .word's appear in the text section.  */
        !          3284: 
        !          3285: #define ASM_OUTPUT_CASE_LABEL(STREAM, PREFIX, NUM, JUMPTABLE)          \
        !          3286: {                                                                      \
        !          3287:   rdata_section ();                                                    \
        !          3288:   ASM_OUTPUT_ALIGN (STREAM, 2);                                                \
        !          3289:   ASM_OUTPUT_INTERNAL_LABEL (STREAM, PREFIX, NUM);                     \
        !          3290: }
        !          3291: 
        !          3292: /* This is how to output an assembler line
        !          3293:    that says to advance the location counter
        !          3294:    to a multiple of 2**LOG bytes.  */
        !          3295: 
        !          3296: #define ASM_OUTPUT_ALIGN(STREAM,LOG)                                   \
        !          3297: {                                                                      \
        !          3298:   int mask = (1 << (LOG)) - 1;                                         \
        !          3299:   fprintf (STREAM, "\t.align\t%d\n", (LOG));                           \
        !          3300: }
        !          3301: 
        !          3302: /* This is how to output an assembler line to to advance the location
        !          3303:    counter by SIZE bytes.  */
        !          3304: 
        !          3305: #define ASM_OUTPUT_SKIP(STREAM,SIZE)                                   \
        !          3306:   fprintf (STREAM, "\t.space\t%u\n", (SIZE))
        !          3307: 
        !          3308: 
        !          3309: /* This is how to output a string.  */
        !          3310: #define ASM_OUTPUT_ASCII(STREAM, STRING, LEN)                          \
        !          3311: do {                                                                   \
        !          3312:   register int i, c, len = (LEN), cur_pos = 17;                                \
        !          3313:   register unsigned char *string = (unsigned char *)(STRING);          \
        !          3314:   fprintf ((STREAM), "\t.ascii\t\"");                                  \
        !          3315:   for (i = 0; i < len; i++)                                            \
        !          3316:     {                                                                  \
        !          3317:       register int c = string[i];                                      \
        !          3318:                                                                        \
        !          3319:       switch (c)                                                       \
        !          3320:        {                                                               \
        !          3321:        case '\"':                                                      \
        !          3322:        case '\\':                                                      \
        !          3323:          putc ('\\', (STREAM));                                        \
        !          3324:          putc (c, (STREAM));                                           \
        !          3325:          cur_pos += 2;                                                 \
        !          3326:          break;                                                        \
        !          3327:                                                                        \
        !          3328:        case TARGET_NEWLINE:                                            \
        !          3329:          fputs ("\\n", (STREAM));                                      \
        !          3330:          if (i+1 < len                                                 \
        !          3331:              && (((c = string[i+1]) >= '\040' && c <= '~')             \
        !          3332:                  || c == TARGET_TAB))                                  \
        !          3333:            cur_pos = 32767;            /* break right here */          \
        !          3334:          else                                                          \
        !          3335:            cur_pos += 2;                                               \
        !          3336:          break;                                                        \
        !          3337:                                                                        \
        !          3338:        case TARGET_TAB:                                                \
        !          3339:          fputs ("\\t", (STREAM));                                      \
        !          3340:          cur_pos += 2;                                                 \
        !          3341:          break;                                                        \
        !          3342:                                                                        \
        !          3343:        case TARGET_FF:                                                 \
        !          3344:          fputs ("\\f", (STREAM));                                      \
        !          3345:          cur_pos += 2;                                                 \
        !          3346:          break;                                                        \
        !          3347:                                                                        \
        !          3348:        case TARGET_BS:                                                 \
        !          3349:          fputs ("\\b", (STREAM));                                      \
        !          3350:          cur_pos += 2;                                                 \
        !          3351:          break;                                                        \
        !          3352:                                                                        \
        !          3353:        case TARGET_CR:                                                 \
        !          3354:          fputs ("\\r", (STREAM));                                      \
        !          3355:          cur_pos += 2;                                                 \
        !          3356:          break;                                                        \
        !          3357:                                                                        \
        !          3358:        default:                                                        \
        !          3359:          if (c >= ' ' && c < 0177)                                     \
        !          3360:            {                                                           \
        !          3361:              putc (c, (STREAM));                                       \
        !          3362:              cur_pos++;                                                \
        !          3363:            }                                                           \
        !          3364:          else                                                          \
        !          3365:            {                                                           \
        !          3366:              fprintf ((STREAM), "\\%03o", c);                          \
        !          3367:              cur_pos += 4;                                             \
        !          3368:            }                                                           \
        !          3369:        }                                                               \
        !          3370:                                                                        \
        !          3371:       if (cur_pos > 72 && i+1 < len)                                   \
        !          3372:        {                                                               \
        !          3373:          cur_pos = 17;                                                 \
        !          3374:          fprintf ((STREAM), "\"\n\t.ascii\t\"");                       \
        !          3375:        }                                                               \
        !          3376:     }                                                                  \
        !          3377:   fprintf ((STREAM), "\"\n");                                          \
        !          3378: } while (0)
        !          3379: 
        !          3380: /* Handle certain cpp directives used in header files on sysV.  */
        !          3381: #define SCCS_DIRECTIVE
        !          3382: 
        !          3383: /* Output #ident as a in the read-only data section.  */
        !          3384: #define ASM_OUTPUT_IDENT(FILE, STRING)                                 \
        !          3385: {                                                                      \
        !          3386:   char *p = STRING;                                                    \
        !          3387:   int size = strlen (p) + 1;                                           \
        !          3388:   rdata_section ();                                                    \
        !          3389:   assemble_string (p, size);                                           \
        !          3390: }
        !          3391: 
        !          3392: /* Default to -G 8 */
        !          3393: #ifndef MIPS_DEFAULT_GVALUE
        !          3394: #define MIPS_DEFAULT_GVALUE 8
        !          3395: #endif
        !          3396: 
        !          3397: /* Define the strings to put out for each section in the object file.  */
        !          3398: #define TEXT_SECTION_ASM_OP    "\t.text"       /* instructions */
        !          3399: #define DATA_SECTION_ASM_OP    "\t.data"       /* large data */
        !          3400: #define SDATA_SECTION_ASM_OP   "\t.sdata"      /* small data */
        !          3401: #define RDATA_SECTION_ASM_OP   "\t.rdata"      /* read-only data */
        !          3402: #define READONLY_DATA_SECTION  rdata_section
        !          3403: 
        !          3404: /* What other sections we support other than the normal .data/.text.  */
        !          3405: 
        !          3406: #define EXTRA_SECTIONS in_sdata, in_rdata, in_last_p1
        !          3407: 
        !          3408: /* Define the additional functions to select our additional sections.  */
        !          3409: 
        !          3410: /* on the MIPS it is not a good idea to put constants in the text
        !          3411:    section, since this defeats the sdata/data mechanism. This is
        !          3412:    especially true when -O is used. In this case an effort is made to
        !          3413:    address with faster (gp) register relative addressing, which can
        !          3414:    only get at sdata and sbss items (there is no stext !!)  However,
        !          3415:    if the constant is too large for sdata, and it's readonly, it
        !          3416:    will go into the .rdata section. */
        !          3417: 
        !          3418: #define EXTRA_SECTION_FUNCTIONS                                                \
        !          3419: void                                                                   \
        !          3420: sdata_section ()                                                       \
        !          3421: {                                                                      \
        !          3422:   if (in_section != in_sdata)                                          \
        !          3423:     {                                                                  \
        !          3424:       fprintf (asm_out_file, "%s\n", SDATA_SECTION_ASM_OP);            \
        !          3425:       in_section = in_sdata;                                           \
        !          3426:     }                                                                  \
        !          3427: }                                                                      \
        !          3428:                                                                        \
        !          3429: void                                                                   \
        !          3430: rdata_section ()                                                       \
        !          3431: {                                                                      \
        !          3432:   if (in_section != in_rdata)                                          \
        !          3433:     {                                                                  \
        !          3434:       fprintf (asm_out_file, "%s\n", RDATA_SECTION_ASM_OP);            \
        !          3435:       in_section = in_rdata;                                           \
        !          3436:     }                                                                  \
        !          3437: }
        !          3438: 
        !          3439: /* Given a decl node or constant node, choose the section to output it in
        !          3440:    and select that section.  */
        !          3441: 
        !          3442: #define SELECT_RTX_SECTION(MODE,RTX)                                   \
        !          3443: {                                                                      \
        !          3444:   if ((GET_MODE_SIZE(MODE) / BITS_PER_UNIT) <= mips_section_threshold  \
        !          3445:       && mips_section_threshold > 0)                                   \
        !          3446:     sdata_section ();                                                  \
        !          3447:   else                                                                 \
        !          3448:     rdata_section ();                                                  \
        !          3449: }                                                                      \
        !          3450: 
        !          3451: #define SELECT_SECTION(DECL, RELOC)                                    \
        !          3452: {                                                                      \
        !          3453:   int size = int_size_in_bytes (TREE_TYPE (DECL));                     \
        !          3454:                                                                        \
        !          3455:   if (size > 0 && size <= mips_section_threshold)                      \
        !          3456:     sdata_section ();                                                  \
        !          3457:                                                                        \
        !          3458:   else if (RELOC)                                                      \
        !          3459:     data_section ();                                                   \
        !          3460:                                                                        \
        !          3461:   else if (TREE_CODE (DECL) == STRING_CST)                             \
        !          3462:     {                                                                  \
        !          3463:       if (flag_writable_strings)                                       \
        !          3464:        data_section ();                                                \
        !          3465:       else                                                             \
        !          3466:        rdata_section ();                                               \
        !          3467:     }                                                                  \
        !          3468:                                                                        \
        !          3469:   else if (TREE_CODE (DECL) != VAR_DECL)                               \
        !          3470:     rdata_section ();                                                  \
        !          3471:                                                                        \
        !          3472:   else if (!TREE_READONLY (DECL))                                      \
        !          3473:     data_section ();                                                   \
        !          3474:                                                                        \
        !          3475:   else                                                                 \
        !          3476:     rdata_section ();                                                  \
        !          3477: }
        !          3478: 
        !          3479: 
        !          3480: /* Store in OUTPUT a string (made with alloca) containing
        !          3481:    an assembler-name for a local static variable named NAME.
        !          3482:    LABELNO is an integer which is different for each call.  */
        !          3483: 
        !          3484: #define ASM_FORMAT_PRIVATE_NAME(OUTPUT, NAME, LABELNO)                 \
        !          3485: ( (OUTPUT) = (char *) alloca (strlen ((NAME)) + 10),                   \
        !          3486:   sprintf ((OUTPUT), "%s.%d", (NAME), (LABELNO)))
        !          3487: 
        !          3488: #define ASM_OUTPUT_REG_PUSH(STREAM,REGNO)                              \
        !          3489: do                                                                     \
        !          3490:   {                                                                    \
        !          3491:     fprintf (STREAM, "\tsubu\t%s,%s,8\n\tsw\t%s,0(%s)\n",              \
        !          3492:             reg_names[STACK_POINTER_REGNUM],                           \
        !          3493:             reg_names[STACK_POINTER_REGNUM],                           \
        !          3494:             reg_names[REGNO],                                          \
        !          3495:             reg_names[STACK_POINTER_REGNUM]);                          \
        !          3496:   }                                                                    \
        !          3497: while (0)
        !          3498: 
        !          3499: #define ASM_OUTPUT_REG_POP(STREAM,REGNO)                               \
        !          3500: do                                                                     \
        !          3501:   {                                                                    \
        !          3502:     if (! set_noreorder)                                               \
        !          3503:       fprintf (STREAM, "\t.set\tnoreorder\n");                         \
        !          3504:                                                                        \
        !          3505:     dslots_load_total++;                                               \
        !          3506:     dslots_load_filled++;                                              \
        !          3507:     fprintf (STREAM, "\tlw\t%s,0(%s)\n\taddu\t%s,%s,8\n",              \
        !          3508:             reg_names[REGNO],                                          \
        !          3509:             reg_names[STACK_POINTER_REGNUM],                           \
        !          3510:             reg_names[STACK_POINTER_REGNUM],                           \
        !          3511:             reg_names[STACK_POINTER_REGNUM]);                          \
        !          3512:                                                                        \
        !          3513:     if (! set_noreorder)                                               \
        !          3514:       fprintf (STREAM, "\t.set\treorder\n");                           \
        !          3515:   }                                                                    \
        !          3516: while (0)
        !          3517: 
        !          3518: /* Define the parentheses used to group arithmetic operations
        !          3519:    in assembler code.  */
        !          3520: 
        !          3521: #define ASM_OPEN_PAREN "("
        !          3522: #define ASM_CLOSE_PAREN ")"
        !          3523: 
        !          3524: /* How to start an assembler comment.  */
        !          3525: #ifndef ASM_COMMENT_START
        !          3526: #define ASM_COMMENT_START "\t\t# "
        !          3527: #endif
        !          3528: 
        !          3529: 
        !          3530: 
        !          3531: /* Macros for mips-tfile.c to encapsulate stabs in ECOFF, and for
        !          3532:    and mips-tdump.c to print them out.
        !          3533: 
        !          3534:    These must match the corresponding definitions in gdb/mipsread.c.
        !          3535:    Unfortunately, gcc and gdb do not currently share any directories. */
        !          3536: 
        !          3537: #define CODE_MASK 0x8F300
        !          3538: #define MIPS_IS_STAB(sym) (((sym)->index & 0xFFF00) == CODE_MASK)
        !          3539: #define MIPS_MARK_STAB(code) ((code)+CODE_MASK)
        !          3540: #define MIPS_UNMARK_STAB(code) ((code)-CODE_MASK)
        !          3541: 
        !          3542: 
        !          3543: /* Default definitions for size_t and ptrdiff_t.  */
        !          3544: 
        !          3545: #ifndef SIZE_TYPE
        !          3546: #define SIZE_TYPE      "unsigned int"
        !          3547: #endif
        !          3548: 
        !          3549: #ifndef PTRDIFF_TYPE
        !          3550: #define PTRDIFF_TYPE   "int"
        !          3551: #endif
        !          3552: 

unix.superglobalmegacorp.com

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