Annotation of GNUtools/cc/config/m88k/m88k.h, revision 1.1.1.1

1.1       root        1: /* Definitions of target machine for GNU compiler.
                      2:    Motorola m88100 in an 88open OCS/BCS environment.
                      3:    Copyright (C) 1988, 1989, 1990, 1991, 1993 Free Software Foundation, Inc.
                      4:    Contributed by Michael Tiemann ([email protected])
                      5:    Enhanced by Michael Meissner ([email protected])
                      6:    Version 2 port by Tom Wood ([email protected])
                      7: 
                      8: This file is part of GNU CC.
                      9: 
                     10: GNU CC is free software; you can redistribute it and/or modify
                     11: it under the terms of the GNU General Public License as published by
                     12: the Free Software Foundation; either version 2, or (at your option)
                     13: any later version.
                     14: 
                     15: GNU CC is distributed in the hope that it will be useful,
                     16: but WITHOUT ANY WARRANTY; without even the implied warranty of
                     17: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     18: GNU General Public License for more details.
                     19: 
                     20: You should have received a copy of the GNU General Public License
                     21: along with GNU CC; see the file COPYING.  If not, write to
                     22: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
                     23: 
                     24: /* The m88100 port of GNU CC adheres to the various standards from 88open.
                     25:    These documents are available by writing:
                     26: 
                     27:        88open Consortium Ltd.
                     28:        100 Homeland Court, Suite 800
                     29:        San Jose, CA  95112
                     30:        (408) 436-6600
                     31: 
                     32:    In brief, the current standards are:
                     33: 
                     34:    Binary Compatibility Standard, Release 1.1A, May 1991
                     35:        This provides for portability of application-level software at the
                     36:        executable level for AT&T System V Release 3.2.
                     37: 
                     38:    Object Compatibility Standard, Release 1.1A, May 1991
                     39:        This provides for portability of application-level software at the
                     40:        object file and library level for C, Fortran, and Cobol, and again,
                     41:        largely for SVR3.
                     42: 
                     43:    Under development are standards for AT&T System V Release 4, based on the
                     44:    [generic] System V Application Binary Interface from AT&T.  These include:
                     45: 
                     46:    System V Application Binary Interface, Motorola 88000 Processor Supplement
                     47:        Another document from AT&T for SVR4 specific to the m88100.
                     48:        Available from Prentice Hall.
                     49: 
                     50:    System V Application Binary Interface, Motorola 88000 Processor Supplement,
                     51:    Release 1.1, Draft H, May 6, 1991
                     52:        A proposed update to the AT&T document from 88open.
                     53: 
                     54:    System V ABI Implementation Guide for the M88000 Processor,
                     55:    Release 1.0, January 1991
                     56:        A companion ABI document from 88open.  */
                     57: 
                     58: /* Other m88k*.h files include this one and override certain items.
                     59:    At present, these are m88kv3.h, m88kv4.h, m88kdgux.h, and m88kluna.h.
                     60:    Additionally, m88kv4.h and m88kdgux.h include svr4.h first.  All other
                     61:    m88k targets except m88kluna.h are based on svr3.h.  */
                     62: 
                     63: /* Choose SVR3 as the default.  */
                     64: #if !defined(DBX_DEBUGGING_INFO) && !defined(DWARF_DEBUGGING_INFO)
                     65: #include "svr3.h"
                     66: #endif
                     67: 
                     68: /* External types used.  */
                     69: 
                     70: /* What instructions are needed to manufacture an integer constant.  */
                     71: enum m88k_instruction {
                     72:   m88k_zero,
                     73:   m88k_or,
                     74:   m88k_subu,
                     75:   m88k_or_lo16,
                     76:   m88k_or_lo8,
                     77:   m88k_set,
                     78:   m88k_oru_hi16,
                     79:   m88k_oru_or
                     80: };
                     81: 
                     82: /* External variables/functions defined in m88k.c.  */
                     83: 
                     84: extern char *m88k_pound_sign;
                     85: extern char *m88k_short_data;
                     86: extern char *m88k_version;
                     87: extern char m88k_volatile_code;
                     88: 
                     89: extern int m88k_gp_threshold;
                     90: extern int m88k_prologue_done;
                     91: extern int m88k_function_number;
                     92: extern int m88k_fp_offset;
                     93: extern int m88k_stack_size;
                     94: extern int m88k_case_index;
                     95: extern int m88k_version_0300;
                     96: 
                     97: extern struct rtx_def *m88k_compare_reg;
                     98: extern struct rtx_def *m88k_compare_op0;
                     99: extern struct rtx_def *m88k_compare_op1;
                    100: 
                    101: extern enum attr_cpu m88k_cpu;
                    102: 
                    103: extern int null_prologue ();
                    104: extern int integer_ok_for_set ();
                    105: extern int m88k_debugger_offset ();
                    106: 
                    107: extern void emit_bcnd ();
                    108: extern void expand_block_move ();
                    109: extern void m88k_layout_frame ();
                    110: extern void m88k_expand_prologue ();
                    111: extern void m88k_begin_prologue ();
                    112: extern void m88k_end_prologue ();
                    113: extern void m88k_expand_epilogue ();
                    114: extern void m88k_begin_epilogue ();
                    115: extern void m88k_end_epilogue ();
                    116: extern void output_function_profiler ();
                    117: extern void output_function_block_profiler ();
                    118: extern void output_block_profiler ();
                    119: extern void output_file_start ();
                    120: extern void output_ascii ();
                    121: extern void output_label ();
                    122: extern void print_operand ();
                    123: extern void print_operand_address ();
                    124: 
                    125: extern char *output_load_const_int ();
                    126: extern char *output_load_const_float ();
                    127: extern char *output_load_const_double ();
                    128: extern char *output_load_const_dimode ();
                    129: extern char *output_and ();
                    130: extern char *output_ior ();
                    131: extern char *output_xor ();
                    132: extern char *output_call ();
                    133: 
                    134: extern struct rtx_def *emit_test ();
                    135: extern struct rtx_def *legitimize_address ();
                    136: extern struct rtx_def *legitimize_operand ();
                    137: extern struct rtx_def *m88k_function_arg ();
                    138: extern struct rtx_def *m88k_builtin_saveregs ();
                    139: 
                    140: extern enum m88k_instruction classify_integer ();
                    141: 
                    142: /* external variables defined elsewhere in the compiler */
                    143: 
                    144: extern int target_flags;                       /* -m compiler switches */
                    145: extern int frame_pointer_needed;               /* current function has a FP */
                    146: extern int current_function_pretend_args_size; /* args size without ... */
                    147: extern int flag_delayed_branch;                        /* -fdelayed-branch */
                    148: extern int flag_pic;                           /* -fpic */
                    149: extern char * reg_names[];
                    150: 
                    151: /* Specify the default monitors.  The meaning of these values can
                    152:    be obtained by doing "grep MONITOR_GCC *m88k*".  Generally, the
                    153:    values downward from 0x8000 are tests that will soon go away.
                    154:    values upward from 0x1 are generally useful tests that will remain.  */
                    155: 
                    156: #ifndef MONITOR_GCC
                    157: #define MONITOR_GCC 0
                    158: #endif
                    159: 
                    160: /*** Controlling the Compilation Driver, `gcc' ***/
                    161: 
                    162: /* Some machines may desire to change what optimizations are performed for
                    163:    various optimization levels.   This macro, if defined, is executed once
                    164:    just after the optimization level is determined and before the remainder
                    165:    of the command options have been parsed.  Values set in this macro are
                    166:    used as the default values for the other command line options.
                    167: 
                    168:    LEVEL is the optimization level specified; 2 if -O2 is specified,
                    169:    1 if -O is specified, and 0 if neither is specified.  */
                    170: 
                    171: /* This macro used to store 0 in flag_signed_bitfields.
                    172:    Not only is that misuse of this macro; the whole idea is wrong.
                    173: 
                    174:    The GNU C dialect makes bitfields signed by default,
                    175:    regardless of machine type.  Making any machine inconsistent in this
                    176:    regard is bad for portability.
                    177: 
                    178:    I chose to make bitfields signed by default because this is consistent
                    179:    with the way ordinary variables are handled: `int' equals `signed int'.
                    180:    If there is a good reason to prefer making bitfields unsigned by default,
                    181:    it cannot have anything to do with the choice of machine.
                    182:    If the reason is good enough, we should change the convention for all machines.
                    183: 
                    184:    -- rms, 20 July 1991.  */
                    185: 
                    186: #define OPTIMIZATION_OPTIONS(LEVEL)                    \
                    187:   do {                                                 \
                    188:     if (LEVEL)                                         \
                    189:       {                                                        \
                    190:        flag_omit_frame_pointer = 1;                    \
                    191:       }                                                        \
                    192:   } while (0)
                    193: 
                    194: /* If -m88100 is in effect, add -D__m88100__; similarly for -m88110.
                    195:    Here, the CPU_DEFAULT is assumed to be -m88100.  */
                    196: #undef CPP_SPEC
                    197: #define        CPP_SPEC "%{!m88000:%{!m88100:%{m88110:-D__m88110__}}} \
                    198:                  %{!m88000:%{!m88110:-D__m88100__}}"
                    199: 
                    200: /* LIB_SPEC, LINK_SPEC, and STARTFILE_SPEC defined in svr3.h.
                    201:    ASM_SPEC, ASM_FINAL_SPEC, LIB_SPEC, LINK_SPEC, and STARTFILE_SPEC redefined
                    202:    in svr4.h.
                    203:    CPP_SPEC, ASM_SPEC, ASM_FINAL_SPEC, LIB_SPEC, LINK_SPEC, and
                    204:    STARTFILE_SPEC redefined in m88kdgux.h.  */
                    205: 
                    206: /*** Run-time Target Specification ***/
                    207: 
                    208: /* Names to predefine in the preprocessor for this target machine.
                    209:    Redefined in m88kv3.h, m88kv4.h, m88kdgux.h, and m88kluna.h.  */
                    210: #define CPP_PREDEFINES "-Dm88000 -Dm88k -Dunix -D__CLASSIFY_TYPE__=2 -Asystem(unix) -Acpu(m88k) -Amachine(m88k)"
                    211: 
                    212: #define TARGET_VERSION fprintf (stderr, " (%s%s)", \
                    213:                                VERSION_INFO1, VERSION_INFO2)
                    214: 
                    215: /* Print subsidiary information on the compiler version in use.
                    216:    Redefined in m88kv4.h, and m88kluna.h.  */
                    217: #define VERSION_INFO1  "88open OCS/BCS, "
                    218: #define VERSION_INFO2  "12/16/92"
                    219: #define VERSION_STRING version_string
                    220: #define        TM_SCCS_ID      "@(#)m88k.h     2.3.3.2 12/16/92 08:26:09"
                    221: 
                    222: /* Run-time compilation parameters selecting different hardware subsets.  */
                    223: 
                    224: /* Macro to define tables used to set the flags.
                    225:    This is a list in braces of pairs in braces,
                    226:    each pair being { "NAME", VALUE }
                    227:    where VALUE is the bits to set or minus the bits to clear.
                    228:    An empty string NAME is used to identify the default VALUE.  */
                    229: 
                    230: #define MASK_88100             0x00000001 /* Target m88100 */
                    231: #define MASK_88110             0x00000002 /* Target m88110 */
                    232: #define MASK_OCS_DEBUG_INFO    0x00000004 /* Emit .tdesc info */
                    233: #define MASK_OCS_FRAME_POSITION        0x00000008 /* Debug frame = CFA, not r30 */
                    234: #define MASK_SVR4              0x00000010 /* Target is AT&T System V.4 */
                    235: #define MASK_NO_UNDERSCORES    0x00000040 /* Don't emit a leading `_' */
                    236: #define MASK_BIG_PIC           0x00000080 /* PIC with large got-rel's -fPIC */
                    237: #define MASK_TRAP_LARGE_SHIFT  0x00000100 /* Trap if shift not <= 31 */
                    238: #define MASK_HANDLE_LARGE_SHIFT        0x00000200 /* Handle shift count >= 32 */
                    239: #define MASK_CHECK_ZERO_DIV    0x00000400 /* Check for int div. by 0 */
                    240: #define MASK_USE_DIV           0x00000800 /* No signed div. checks */
                    241: #define MASK_IDENTIFY_REVISION 0x00001000 /* Emit ident, with GCC rev */
                    242: #define MASK_WARN_PASS_STRUCT  0x00002000 /* Warn about passed structs */
                    243: #define MASK_OPTIMIZE_ARG_AREA 0x00004000 /* Save stack space */
                    244: #define MASK_NO_SERIALIZE_VOLATILE 0x00008000 /* Serialize volatile refs */
                    245: 
                    246: #define MASK_88000 (MASK_88100 | MASK_88110)
                    247: #define MASK_EITHER_LARGE_SHIFT        (MASK_TRAP_LARGE_SHIFT | \
                    248:                                 MASK_HANDLE_LARGE_SHIFT)
                    249: 
                    250: #define TARGET_88100                    ((target_flags & MASK_88000) == MASK_88100)
                    251: #define TARGET_88110            ((target_flags & MASK_88000) == MASK_88110)
                    252: #define TARGET_88000            ((target_flags & MASK_88000) == MASK_88000)
                    253: 
                    254: #define TARGET_OCS_DEBUG_INFO    (target_flags & MASK_OCS_DEBUG_INFO)
                    255: #define TARGET_OCS_FRAME_POSITION (target_flags & MASK_OCS_FRAME_POSITION)
                    256: #define TARGET_SVR4              (target_flags & MASK_SVR4)
                    257: #define TARGET_NO_UNDERSCORES    (target_flags & MASK_NO_UNDERSCORES)
                    258: #define TARGET_BIG_PIC           (target_flags & MASK_BIG_PIC)
                    259: #define TARGET_TRAP_LARGE_SHIFT   (target_flags & MASK_TRAP_LARGE_SHIFT)
                    260: #define TARGET_HANDLE_LARGE_SHIFT (target_flags & MASK_HANDLE_LARGE_SHIFT)
                    261: #define TARGET_CHECK_ZERO_DIV    (target_flags & MASK_CHECK_ZERO_DIV)
                    262: #define        TARGET_USE_DIV            (target_flags & MASK_USE_DIV)
                    263: #define TARGET_IDENTIFY_REVISION  (target_flags & MASK_IDENTIFY_REVISION)
                    264: #define TARGET_WARN_PASS_STRUCT   (target_flags & MASK_WARN_PASS_STRUCT)
                    265: #define TARGET_OPTIMIZE_ARG_AREA  (target_flags & MASK_OPTIMIZE_ARG_AREA)
                    266: #define TARGET_SERIALIZE_VOLATILE (!(target_flags & MASK_NO_SERIALIZE_VOLATILE))
                    267: 
                    268: #define TARGET_EITHER_LARGE_SHIFT (target_flags & MASK_EITHER_LARGE_SHIFT)
                    269: 
                    270: /*  Redefined in m88kv3.h,m88kv4.h, and m88kdgux.h.  */
                    271: #define TARGET_DEFAULT (MASK_CHECK_ZERO_DIV)
                    272: #define CPU_DEFAULT MASK_88100
                    273: 
                    274: #define TARGET_SWITCHES \
                    275:   { \
                    276:     { "88110",                          MASK_88110 }, \
                    277:     { "88100",                          MASK_88100 }, \
                    278:     { "88000",                          MASK_88000 }, \
                    279:     { "ocs-debug-info",                         MASK_OCS_DEBUG_INFO }, \
                    280:     { "no-ocs-debug-info",             -MASK_OCS_DEBUG_INFO }, \
                    281:     { "ocs-frame-position",             MASK_OCS_FRAME_POSITION }, \
                    282:     { "no-ocs-frame-position",         -MASK_OCS_FRAME_POSITION }, \
                    283:     { "svr4",                           MASK_SVR4 }, \
                    284:     { "svr3",                          -MASK_SVR4 }, \
                    285:     { "no-underscores",                         MASK_NO_UNDERSCORES }, \
                    286:     { "big-pic",                        MASK_BIG_PIC }, \
                    287:     { "trap-large-shift",               MASK_TRAP_LARGE_SHIFT }, \
                    288:     { "handle-large-shift",             MASK_HANDLE_LARGE_SHIFT }, \
                    289:     { "check-zero-division",            MASK_CHECK_ZERO_DIV }, \
                    290:     { "no-check-zero-division",                -MASK_CHECK_ZERO_DIV }, \
                    291:     { "use-div-instruction",            MASK_USE_DIV }, \
                    292:     { "identify-revision",              MASK_IDENTIFY_REVISION }, \
                    293:     { "warn-passed-structs",            MASK_WARN_PASS_STRUCT }, \
                    294:     { "optimize-arg-area",              MASK_OPTIMIZE_ARG_AREA }, \
                    295:     { "no-optimize-arg-area",          -MASK_OPTIMIZE_ARG_AREA }, \
                    296:     { "no-serialize-volatile",          MASK_NO_SERIALIZE_VOLATILE }, \
                    297:     { "serialize-volatile",            -MASK_NO_SERIALIZE_VOLATILE }, \
                    298:     SUBTARGET_SWITCHES \
                    299:     /* Default switches */ \
                    300:     { "",                               TARGET_DEFAULT }, \
                    301:   }
                    302: 
                    303: /* Redefined in m88kdgux.h.  */
                    304: #define SUBTARGET_SWITCHES
                    305: 
                    306: /* Macro to define table for command options with values.  */
                    307: 
                    308: #define TARGET_OPTIONS { { "short-data-", &m88k_short_data }, \
                    309:                         { "version-", &m88k_version } }
                    310: 
                    311: /* Do any checking or such that is needed after processing the -m switches.  */
                    312: 
                    313: #define OVERRIDE_OPTIONS                                                    \
                    314:   do {                                                                      \
                    315:     register int i;                                                         \
                    316:                                                                             \
                    317:     if ((target_flags & MASK_88000) == 0)                                   \
                    318:       target_flags |= CPU_DEFAULT;                                          \
                    319:                                                                             \
                    320:     m88k_cpu = (TARGET_88000 ? CPU_M88000                                   \
                    321:                : (TARGET_88100 ? CPU_M88100 : CPU_M88110));                 \
                    322:                                                                             \
                    323:     if (TARGET_BIG_PIC)                                                             \
                    324:       flag_pic = 2;                                                         \
                    325:                                                                             \
                    326:     if ((target_flags & MASK_EITHER_LARGE_SHIFT) == MASK_EITHER_LARGE_SHIFT) \
                    327:       error ("-mtrap-large-shift and -mhandle-large-shift are incompatible");\
                    328:                                                                             \
                    329:     m88k_version_0300 = (m88k_version != 0                                  \
                    330:                         && strcmp (m88k_version, "03.00") >= 0);            \
                    331:                                                                             \
                    332:     if (VERSION_0300_SYNTAX)                                                \
                    333:       {                                                                             \
                    334:        for (i = 0; i < FIRST_PSEUDO_REGISTER; i++)                          \
                    335:          reg_names[i]--;                                                    \
                    336:        m88k_pound_sign = "#";                                               \
                    337:        if (m88k_version == 0)                                               \
                    338:          m88k_version = VERSION_0400_SYNTAX ? "04.00" : "03.00";            \
                    339:        else if (strcmp (m88k_version, "03.00") < 0)                         \
                    340:          error ("Specified assembler version (%s) is less that 03.00",      \
                    341:                 m88k_version);                                              \
                    342:       }                                                                             \
                    343:                                                                             \
                    344:     m88k_version_0300 = (m88k_version != 0                                  \
                    345:                         && strcmp (m88k_version, "03.00") >= 0);            \
                    346:                                                                             \
                    347:     if (m88k_short_data)                                                    \
                    348:       {                                                                             \
                    349:        char *p = m88k_short_data;                                           \
                    350:        while (*p)                                                           \
                    351:          if (*p >= '0' && *p <= '9')                                        \
                    352:            p++;                                                             \
                    353:          else                                                               \
                    354:            {                                                                \
                    355:              error ("Invalid option `-mshort-data-%s'", m88k_short_data);   \
                    356:              break;                                                         \
                    357:            }                                                                \
                    358:        m88k_gp_threshold = atoi (m88k_short_data);                          \
                    359:        if (flag_pic)                                                        \
                    360:          error ("-mshort-data-%s and PIC are incompatible", m88k_short_data); \
                    361:       }                                                                             \
                    362:   } while (0)
                    363: 
                    364: /*** Storage Layout ***/
                    365: 
                    366: /* Sizes in bits of the various types.  */
                    367: #define CHAR_TYPE_SIZE          8
                    368: #define SHORT_TYPE_SIZE                16
                    369: #define INT_TYPE_SIZE          32
                    370: #define LONG_TYPE_SIZE         32
                    371: #define LONG_LONG_TYPE_SIZE    64
                    372: #define FLOAT_TYPE_SIZE                32
                    373: #define        DOUBLE_TYPE_SIZE        64
                    374: #define LONG_DOUBLE_TYPE_SIZE  64
                    375: 
                    376: /* Define this if most significant bit is lowest numbered
                    377:    in instructions that operate on numbered bit-fields.
                    378:    Somewhat arbitrary.  It matches the bit field patterns.  */
                    379: #define BITS_BIG_ENDIAN 1
                    380: 
                    381: /* Define this if most significant byte of a word is the lowest numbered.
                    382:    That is true on the m88000.  */
                    383: #define BYTES_BIG_ENDIAN 1
                    384: 
                    385: /* Define this if most significant word of a multiword number is the lowest
                    386:    numbered.
                    387:    For the m88000 we can decide arbitrarily since there are no machine
                    388:    instructions for them.  */
                    389: #define WORDS_BIG_ENDIAN 1
                    390: 
                    391: /* Number of bits in an addressable storage unit */
                    392: #define BITS_PER_UNIT 8
                    393: 
                    394: /* Width in bits of a "word", which is the contents of a machine register.
                    395:    Note that this is not necessarily the width of data type `int';
                    396:    if using 16-bit ints on a 68000, this would still be 32.
                    397:    But on a machine with 16-bit registers, this would be 16.  */
                    398: #define BITS_PER_WORD 32
                    399: 
                    400: /* Width of a word, in units (bytes).  */
                    401: #define UNITS_PER_WORD 4
                    402: 
                    403: /* Width in bits of a pointer.
                    404:    See also the macro `Pmode' defined below.  */
                    405: #define POINTER_SIZE 32
                    406: 
                    407: /* Allocation boundary (in *bits*) for storing arguments in argument list.  */
                    408: #define PARM_BOUNDARY 32
                    409: 
                    410: /* Largest alignment for stack parameters (if greater than PARM_BOUNDARY).  */
                    411: #define MAX_PARM_BOUNDARY 64
                    412: 
                    413: /* Boundary (in *bits*) on which stack pointer should be aligned.  */
                    414: #define STACK_BOUNDARY 128
                    415: 
                    416: /* Allocation boundary (in *bits*) for the code of a function.  On the
                    417:    m88100, it is desirable to align to a cache line.  However, SVR3 targets
                    418:    only provided 8 byte alignment.  The m88110 cache is small, so align
                    419:    to an 8 byte boundary.  Pack code tightly when compiling crtstuff.c.  */
                    420: #define FUNCTION_BOUNDARY (flag_inhibit_size_directive ? 32 : \
                    421:                           (TARGET_88100 && TARGET_SVR4 ? 128 : 64))
                    422: 
                    423: /* No data type wants to be aligned rounder than this.  */
                    424: #define BIGGEST_ALIGNMENT 64
                    425: 
                    426: /* The best alignment to use in cases where we have a choice.  */
                    427: #define FASTEST_ALIGNMENT (TARGET_88100 ? 32 : 64)
                    428: 
                    429: /* Make strings 4/8 byte aligned so strcpy from constants will be faster.  */
                    430: #define CONSTANT_ALIGNMENT(EXP, ALIGN)  \
                    431:   ((TREE_CODE (EXP) == STRING_CST      \
                    432:     && (ALIGN) < FASTEST_ALIGNMENT)    \
                    433:    ? FASTEST_ALIGNMENT : (ALIGN))
                    434: 
                    435: /* Make arrays of chars 4/8 byte aligned for the same reasons.  */
                    436: #define DATA_ALIGNMENT(TYPE, ALIGN)            \
                    437:   (TREE_CODE (TYPE) == ARRAY_TYPE              \
                    438:    && TYPE_MODE (TREE_TYPE (TYPE)) == QImode   \
                    439:    && (ALIGN) < FASTEST_ALIGNMENT ? FASTEST_ALIGNMENT : (ALIGN))
                    440: 
                    441: /* Alignment of field after `int : 0' in a structure.
                    442:    Ignored with PCC_BITFIELD_TYPE_MATTERS.  */
                    443: /* #define EMPTY_FIELD_BOUNDARY 8 */
                    444: 
                    445: /* Every structure's size must be a multiple of this.  */
                    446: #define STRUCTURE_SIZE_BOUNDARY 8
                    447: 
                    448: /* Set this nonzero if move instructions will actually fail to work
                    449:    when given unaligned data.  */
                    450: #define STRICT_ALIGNMENT 1
                    451: 
                    452: /* A bitfield declared as `int' forces `int' alignment for the struct.  */
                    453: #define PCC_BITFIELD_TYPE_MATTERS 1
                    454: 
                    455: /* Maximum size (in bits) to use for the largest integral type that
                    456:    replaces a BLKmode type. */
                    457: /* #define MAX_FIXED_MODE_SIZE 0 */
                    458: 
                    459: /* Check a `double' value for validity for a particular machine mode.
                    460:    This is defined to avoid crashes outputting certain constants.
                    461:    Since we output the number in hex, the assembler won't choke on it.  */
                    462: /* #define CHECK_FLOAT_VALUE(MODE,VALUE) */
                    463: 
                    464: /* A code distinguishing the floating point format of the target machine.  */
                    465: /* #define TARGET_FLOAT_FORMAT IEEE_FLOAT_FORMAT */
                    466: 
                    467: /*** Register Usage ***/
                    468: 
                    469: /* Number of actual hardware registers.
                    470:    The hardware registers are assigned numbers for the compiler
                    471:    from 0 to just below FIRST_PSEUDO_REGISTER.
                    472:    All registers that the compiler knows about must be given numbers,
                    473:    even those that are not normally considered general registers.
                    474: 
                    475:    The m88100 has a General Register File (GRF) of 32 32-bit registers.
                    476:    The m88110 adds an Extended Register File (XRF) of 32 80-bit registers.  */
                    477: #define FIRST_PSEUDO_REGISTER 64
                    478: #define FIRST_EXTENDED_REGISTER 32
                    479: 
                    480: /*  General notes on extended registers, their use and misuse.
                    481: 
                    482:     Possible good uses:
                    483: 
                    484:     spill area instead of memory.
                    485:       -waste if only used once
                    486: 
                    487:     floating point calculations
                    488:       -probably a waste unless we have run out of general purpose registers
                    489: 
                    490:     freeing up general purpose registers
                    491:       -e.g. may be able to have more loop invariants if floating
                    492:        point is moved into extended registers.
                    493: 
                    494: 
                    495:     I've noticed wasteful moves into and out of extended registers; e.g. a load
                    496:     into x21, then inside a loop a move into r24, then r24 used as input to
                    497:     an fadd.  Why not just load into r24 to begin with?  Maybe the new cse.c
                    498:     will address this.  This wastes a move, but the load,store and move could
                    499:     have been saved had extended registers been used throughout.
                    500:     E.g. in the code following code, if z and xz are placed in extended
                    501:     registers, there is no need to save preserve registers.
                    502: 
                    503:        long c=1,d=1,e=1,f=1,g=1,h=1,i=1,j=1,k;
                    504: 
                    505:        double z=0,xz=4.5;
                    506: 
                    507:        foo(a,b)
                    508:        long a,b;
                    509:        {
                    510:          while (a < b)
                    511:            {
                    512:              k = b + c + d + e + f + g + h + a + i + j++;
                    513:              z += xz;
                    514:              a++;
                    515:            }
                    516:          printf("k= %d; z=%f;\n", k, z);
                    517:        }
                    518: 
                    519:     I've found that it is possible to change the constraints (putting * before
                    520:     the 'r' constraints int the fadd.ddd instruction) and get the entire
                    521:     addition and store to go into extended registers.  However, this also
                    522:     forces simple addition and return of floating point arguments to a
                    523:     function into extended registers.  Not the correct solution.
                    524: 
                    525:     Found the following note in local-alloc.c which may explain why I can't
                    526:     get both registers to be in extended registers since two are allocated in
                    527:     local-alloc and one in global-alloc.  Doesn't explain (I don't believe)
                    528:     why an extended register is used instead of just using the preserve
                    529:     register.
                    530: 
                    531:        from local-alloc.c:
                    532:        We have provision to exempt registers, even when they are contained
                    533:        within the block, that can be tied to others that are not contained in it.
                    534:        This is so that global_alloc could process them both and tie them then.
                    535:        But this is currently disabled since tying in global_alloc is not
                    536:        yet implemented.
                    537: 
                    538:     The explanation of why the preserved register is not used is as follows,
                    539:     I believe.  The registers are being allocated in order.  Tying is not
                    540:     done so efficiently, so when it comes time to do the first allocation,
                    541:     there are no registers left to use without spilling except extended
                    542:     registers.  Then when the next pseudo register needs a hard reg, there
                    543:     are still no registers to be had for free, but this one must be a GRF
                    544:     reg instead of an extended reg, so a preserve register is spilled.  Thus
                    545:     the move from extended to GRF is necessitated.  I do not believe this can
                    546:     be 'fixed' through the config/*m88k* files.
                    547: 
                    548:     gcc seems to sometimes make worse use of register allocation -- not counting
                    549:     moves -- whenever extended registers are present.  For example in the
                    550:     whetstone, the simple for loop (slightly modified)
                    551:       for(i = 1; i <= n1; i++)
                    552:        {
                    553:          x1 = (x1 + x2 + x3 - x4) * t;
                    554:          x2 = (x1 + x2 - x3 + x4) * t;
                    555:          x3 = (x1 - x2 + x3 + x4) * t;
                    556:          x4 = (x1 + x2 + x3 + x4) * t;
                    557:        }
                    558:     in general loads the high bits of the addresses of x2-x4 and i into registers
                    559:     outside the loop.  Whenever extended registers are used, it loads all of
                    560:     these inside the loop. My conjecture is that since the 88110 has so many
                    561:     registers, and gcc makes no distinction at this point -- just that they are
                    562:     not fixed, that in loop.c it believes it can expect a number of registers
                    563:     to be available.  Then it allocates 'too many' in local-alloc which causes
                    564:     problems later.  'Too many' are allocated because a large portion of the
                    565:     registers are extended registers and cannot be used for certain purposes
                    566:     ( e.g. hold the address of a variable).  When this loop is compiled on its
                    567:     own, the problem does not occur.  I don't know the solution yet, though it
                    568:     is probably in the base sources.  Possibly a different way to calculate
                    569:     "threshold".  */
                    570: 
                    571: /* 1 for registers that have pervasive standard uses and are not available
                    572:    for the register allocator.  Registers r14-r25 and x22-x29 are expected
                    573:    to be preserved across function calls.
                    574: 
                    575:    On the 88000, the standard uses of the General Register File (GRF) are:
                    576:    Reg 0       = Pseudo argument pointer (hardware fixed to 0).
                    577:    Reg 1       = Subroutine return pointer (hardware).
                    578:    Reg 2-9     = Parameter registers (OCS).
                    579:    Reg 10      = OCS reserved temporary.
                    580:    Reg 11      = Static link if needed [OCS reserved temporary].
                    581:    Reg 12      = Address of structure return (OCS).
                    582:    Reg 13      = OCS reserved temporary.
                    583:    Reg 14-25   = Preserved register set.
                    584:    Reg 26-29   = Reserved by OCS and ABI.
                    585:    Reg 30      = Frame pointer (Common use).
                    586:    Reg 31      = Stack pointer.
                    587: 
                    588:    The following follows the current 88open UCS specification for the
                    589:    Extended Register File (XRF):
                    590:    Reg 32       = x0           Always equal to zero
                    591:    Reg 33-53   = x1-x21        Temporary registers (Caller Save)
                    592:    Reg 54-61   = x22-x29       Preserver registers (Callee Save)
                    593:    Reg 62-63   = x30-x31       Reserved for future ABI use.
                    594: 
                    595:    Note:  The current 88110 extended register mapping is subject to change.
                    596:          The bias towards caller-save registers is based on the
                    597:          presumption that memory traffic can potentially be reduced by
                    598:          allowing the "caller" to save only that part of the register
                    599:          which is actually being used.  (i.e. don't do a st.x if a st.d
                    600:          is sufficient).  Also, in scientific code (a.k.a. Fortran), the
                    601:          large number of variables defined in common blocks may require
                    602:          that almost all registers be saved across calls anyway.  */
                    603: 
                    604: #define FIXED_REGISTERS \
                    605:  {1, 0, 0, 0,  0, 0, 0, 0,   0, 0, 0, 0,  0, 0, 0, 0, \
                    606:   0, 0, 0, 0,  0, 0, 0, 0,   0, 0, 1, 1,  1, 1, 1, 1, \
                    607:   1, 0, 0, 0,  0, 0, 0, 0,   0, 0, 0, 0,  0, 0, 0, 0, \
                    608:   0, 0, 0, 0,  0, 0, 0, 0,   0, 0, 0, 0,  0, 0, 1, 1}
                    609: 
                    610: /* 1 for registers not available across function calls.
                    611:    These must include the FIXED_REGISTERS and also any
                    612:    registers that can be used without being saved.
                    613:    The latter must include the registers where values are returned
                    614:    and the register where structure-value addresses are passed.
                    615:    Aside from that, you can include as many other registers as you like.  */
                    616: 
                    617: #define CALL_USED_REGISTERS \
                    618:  {1, 1, 1, 1,  1, 1, 1, 1,   1, 1, 1, 1,  1, 1, 0, 0, \
                    619:   0, 0, 0, 0,  0, 0, 0, 0,   0, 0, 1, 1,  1, 1, 1, 1, \
                    620:   1, 1, 1, 1,  1, 1, 1, 1,   1, 1, 1, 1,  1, 1, 1, 1, \
                    621:   1, 1, 1, 1,  1, 1, 0, 0,   0, 0, 0, 0,  0, 0, 1, 1}
                    622: 
                    623: /* Macro to conditionally modify fixed_regs/call_used_regs.  */
                    624: #define CONDITIONAL_REGISTER_USAGE                     \
                    625:   {                                                    \
                    626:     if (! TARGET_88110)                                        \
                    627:       {                                                        \
                    628:        register int i;                                 \
                    629:          for (i = FIRST_EXTENDED_REGISTER; i < FIRST_PSEUDO_REGISTER; i++) \
                    630:            {                                           \
                    631:              fixed_regs[i] = 1;                        \
                    632:              call_used_regs[i] = 1;                    \
                    633:            }                                           \
                    634:       }                                                        \
                    635:     if (flag_pic)                                      \
                    636:       {                                                        \
                    637:        /* Current hack to deal with -fpic -O2 problems.  */ \
                    638:        fixed_regs[PIC_OFFSET_TABLE_REGNUM] = 1;        \
                    639:        call_used_regs[PIC_OFFSET_TABLE_REGNUM] = 1;    \
                    640:        global_regs[PIC_OFFSET_TABLE_REGNUM] = 1;       \
                    641:       }                                                        \
                    642:   }
                    643: 
                    644: /* These interfaces that don't apply to the m88000.  */
                    645: /* OVERLAPPING_REGNO_P(REGNO) 0 */
                    646: /* INSN_CLOBBERS_REGNO_P(INSN, REGNO) 0 */
                    647: /* PRESERVE_DEATH_INFO_REGNO_P(REGNO) 0 */
                    648: 
                    649: /* True if register is an extended register.  */
                    650: #define XRF_REGNO_P(N) ((N) < FIRST_PSEUDO_REGISTER && (N) >= FIRST_EXTENDED_REGISTER)
                    651:  
                    652: /* Return number of consecutive hard regs needed starting at reg REGNO
                    653:    to hold something of mode MODE.
                    654:    This is ordinarily the length in words of a value of mode MODE
                    655:    but can be less for certain modes in special long registers.
                    656: 
                    657:    On the m88000, GRF registers hold 32-bits and XRF registers hold 80-bits.
                    658:    An XRF register can hold any mode, but two GRF registers are required
                    659:    for larger modes.  */
                    660: #define HARD_REGNO_NREGS(REGNO, MODE)                                  \
                    661:   (XRF_REGNO_P (REGNO)                                                 \
                    662:    ? 1 : ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD))
                    663: 
                    664: /* Value is 1 if hard register REGNO can hold a value of machine-mode MODE.
                    665: 
                    666:    For double integers, we never put the value into an odd register so that
                    667:    the operators don't run into the situation where the high part of one of
                    668:    the inputs is the low part of the result register.  (It's ok if the output
                    669:    registers are the same as the input registers.)  The XRF registers can
                    670:    hold all modes, but only DF and SF modes can be manipulated in these
                    671:    registers.  The compiler should be allowed to use these as a fast spill
                    672:    area.  */
                    673: #define HARD_REGNO_MODE_OK(REGNO, MODE)                                        \
                    674:   (XRF_REGNO_P(REGNO)                                                  \
                    675:     ? (TARGET_88110 && GET_MODE_CLASS (MODE) == MODE_FLOAT)             \
                    676:     : (((MODE) != DImode && (MODE) != DFmode && (MODE) != DCmode)      \
                    677:        || ((REGNO) & 1) == 0))
                    678: 
                    679: /* Value is 1 if it is a good idea to tie two pseudo registers
                    680:    when one has mode MODE1 and one has mode MODE2.
                    681:    If HARD_REGNO_MODE_OK could produce different values for MODE1 and MODE2,
                    682:    for any hard reg, then this must be 0 for correct output.  */
                    683: #define MODES_TIEABLE_P(MODE1, MODE2) \
                    684:   (((MODE1) == DFmode || (MODE1) == DCmode || (MODE1) == DImode \
                    685:     || (TARGET_88110 && GET_MODE_CLASS (MODE1) == MODE_FLOAT)) \
                    686:    == ((MODE2) == DFmode || (MODE2) == DCmode || (MODE2) == DImode \
                    687:        || (TARGET_88110 && GET_MODE_CLASS (MODE2) == MODE_FLOAT)))
                    688: 
                    689: /* Specify the registers used for certain standard purposes.
                    690:    The values of these macros are register numbers.  */
                    691: 
                    692: /* the m88000 pc isn't overloaded on a register that the compiler knows about.  */
                    693: /* #define PC_REGNUM  */
                    694: 
                    695: /* Register to use for pushing function arguments.  */
                    696: #define STACK_POINTER_REGNUM 31
                    697: 
                    698: /* Base register for access to local variables of the function.  */
                    699: #define FRAME_POINTER_REGNUM 30
                    700: 
                    701: /* Base register for access to arguments of the function.  */
                    702: #define ARG_POINTER_REGNUM 0
                    703: 
                    704: /* Register used in cases where a temporary is known to be safe to use.  */
                    705: #define TEMP_REGNUM 10
                    706: 
                    707: /* Register in which static-chain is passed to a function.  */
                    708: #define STATIC_CHAIN_REGNUM 11
                    709: 
                    710: /* Register in which address to store a structure value
                    711:    is passed to a function.  */
                    712: #define STRUCT_VALUE_REGNUM 12
                    713: 
                    714: /* Register to hold the addressing base for position independent
                    715:    code access to data items.  */
                    716: #define PIC_OFFSET_TABLE_REGNUM 25
                    717: 
                    718: /* Order in which registers are preferred (most to least).  Use temp
                    719:    registers, then param registers top down.  Preserve registers are
                    720:    top down to maximize use of double memory ops for register save.
                    721:    The 88open reserved registers (r26-r29 and x30-x31) may commonly be used
                    722:    in most environments with the -fcall-used- or -fcall-saved- options.  */
                    723: #define REG_ALLOC_ORDER                  \
                    724:  {                               \
                    725:   13, 12, 11, 10, 29, 28, 27, 26, \
                    726:   62, 63,  9,  8,  7,  6,  5,  4, \
                    727:    3,  2,  1, 53, 52, 51, 50, 49, \
                    728:   48, 47, 46, 45, 44, 43, 42, 41, \
                    729:   40, 39, 38, 37, 36, 35, 34, 33, \
                    730:   25, 24, 23, 22, 21, 20, 19, 18, \
                    731:   17, 16, 15, 14, 61, 60, 59, 58, \
                    732:   57, 56, 55, 54, 30, 31,  0, 32}
                    733: 
                    734: /* Order for leaf functions.  */
                    735: #define REG_LEAF_ALLOC_ORDER     \
                    736:  {                               \
                    737:    9,  8,  7,  6, 13, 12, 11, 10, \
                    738:   29, 28, 27, 26, 62, 63,  5,  4, \
                    739:    3,  2,  0, 53, 52, 51, 50, 49, \
                    740:   48, 47, 46, 45, 44, 43, 42, 41, \
                    741:   40, 39, 38, 37, 36, 35, 34, 33, \
                    742:   25, 24, 23, 22, 21, 20, 19, 18, \
                    743:   17, 16, 15, 14, 61, 60, 59, 58, \
                    744:   57, 56, 55, 54, 30, 31,  1, 32}
                    745: 
                    746: /* Switch between the leaf and non-leaf orderings.  The purpose is to avoid
                    747:    write-over scoreboard delays between caller and callee.  */
                    748: #define ORDER_REGS_FOR_LOCAL_ALLOC                             \
                    749: {                                                              \
                    750:   static int leaf[] = REG_LEAF_ALLOC_ORDER;                    \
                    751:   static int nonleaf[] = REG_ALLOC_ORDER;                      \
                    752:                                                                \
                    753:   bcopy (regs_ever_live[1] ? nonleaf : leaf, reg_alloc_order,  \
                    754:         FIRST_PSEUDO_REGISTER * sizeof (int));                 \
                    755: }
                    756: 
                    757: /*** Register Classes ***/
                    758: 
                    759: /* Define the classes of registers for register constraints in the
                    760:    machine description.  Also define ranges of constants.
                    761: 
                    762:    One of the classes must always be named ALL_REGS and include all hard regs.
                    763:    If there is more than one class, another class must be named NO_REGS
                    764:    and contain no registers.
                    765: 
                    766:    The name GENERAL_REGS must be the name of a class (or an alias for
                    767:    another name such as ALL_REGS).  This is the class of registers
                    768:    that is allowed by "g" or "r" in a register constraint.
                    769:    Also, registers outside this class are allocated only when
                    770:    instructions express preferences for them.
                    771: 
                    772:    The classes must be numbered in nondecreasing order; that is,
                    773:    a larger-numbered class must never be contained completely
                    774:    in a smaller-numbered class.
                    775: 
                    776:    For any two classes, it is very desirable that there be another
                    777:    class that represents their union.  */
                    778: 
                    779: /* The m88000 hardware has two kinds of registers.  In addition, we denote
                    780:    the arg pointer as a separate class.  */
                    781: 
                    782: enum reg_class { NO_REGS, AP_REG, XRF_REGS, GENERAL_REGS, AGRF_REGS,
                    783:                 XGRF_REGS, ALL_REGS, LIM_REG_CLASSES };
                    784: 
                    785: #define N_REG_CLASSES (int) LIM_REG_CLASSES
                    786: 
                    787: /* Give names of register classes as strings for dump file.   */
                    788: #define REG_CLASS_NAMES {"NO_REGS", "AP_REG", "XRF_REGS", "GENERAL_REGS", \
                    789:                         "AGRF_REGS", "XGRF_REGS", "ALL_REGS" }
                    790: 
                    791: /* Define which registers fit in which classes.
                    792:    This is an initializer for a vector of HARD_REG_SET
                    793:    of length N_REG_CLASSES.  */
                    794: #define REG_CLASS_CONTENTS {{0x00000000, 0x00000000},  \
                    795:                            {0x00000001, 0x00000000},   \
                    796:                            {0x00000000, 0xffffffff},   \
                    797:                            {0xfffffffe, 0x00000000},   \
                    798:                            {0xffffffff, 0x00000000},   \
                    799:                            {0xfffffffe, 0xffffffff},   \
                    800:                            {0xffffffff, 0xffffffff}}
                    801: 
                    802: /* The same information, inverted:
                    803:    Return the class number of the smallest class containing
                    804:    reg number REGNO.  This could be a conditional expression
                    805:    or could index an array.  */
                    806: #define REGNO_REG_CLASS(REGNO) \
                    807:   ((REGNO) ? ((REGNO < 32) ? GENERAL_REGS : XRF_REGS) : AP_REG)
                    808: 
                    809: /* The class value for index registers, and the one for base regs.  */
                    810: #define BASE_REG_CLASS AGRF_REGS
                    811: #define INDEX_REG_CLASS GENERAL_REGS
                    812: 
                    813: /* Get reg_class from a letter such as appears in the machine description.
                    814:    For the 88000, the following class/letter is defined for the XRF:
                    815:        x - Extended register file  */
                    816: #define REG_CLASS_FROM_LETTER(C)       \
                    817:    (((C) == 'x') ? XRF_REGS : NO_REGS)
                    818: 
                    819: /* Macros to check register numbers against specific register classes.
                    820:    These assume that REGNO is a hard or pseudo reg number.
                    821:    They give nonzero only if REGNO is a hard reg of the suitable class
                    822:    or a pseudo reg currently allocated to a suitable hard reg.
                    823:    Since they use reg_renumber, they are safe only once reg_renumber
                    824:    has been allocated, which happens in local-alloc.c.  */
                    825: #define REGNO_OK_FOR_BASE_P(REGNO)                             \
                    826:   ((REGNO) < FIRST_EXTENDED_REGISTER                           \
                    827:    || (unsigned) reg_renumber[REGNO] < FIRST_EXTENDED_REGISTER)
                    828: #define REGNO_OK_FOR_INDEX_P(REGNO)                            \
                    829:   (((REGNO) && (REGNO) < FIRST_EXTENDED_REGISTER)              \
                    830:    || (unsigned) reg_renumber[REGNO] < FIRST_EXTENDED_REGISTER)
                    831: 
                    832: /* Given an rtx X being reloaded into a reg required to be
                    833:    in class CLASS, return the class of reg to actually use.
                    834:    In general this is just CLASS; but on some machines
                    835:    in some cases it is preferable to use a more restrictive class.
                    836:    Double constants should be in a register iff they can be made cheaply.  */
                    837: #define PREFERRED_RELOAD_CLASS(X,CLASS)        \
                    838:    (CONSTANT_P(X) && (CLASS == XRF_REGS) ? NO_REGS : (CLASS))
                    839: 
                    840: /* Return the register class of a scratch register needed to load IN
                    841:    into a register of class CLASS in MODE.  On the m88k, when PIC, we
                    842:    need a temporary when loading some addresses into a register.  */
                    843: #define SECONDARY_INPUT_RELOAD_CLASS(CLASS, MODE, IN)          \
                    844:   ((flag_pic                                                   \
                    845:     && GET_CODE (IN) == CONST                                  \
                    846:     && GET_CODE (XEXP (IN, 0)) == PLUS                         \
                    847:     && GET_CODE (XEXP (XEXP (IN, 0), 0)) == CONST_INT          \
                    848:     && ! SMALL_INT (XEXP (XEXP (IN, 0), 1))) ? GENERAL_REGS : NO_REGS)
                    849: 
                    850: /* Return the maximum number of consecutive registers
                    851:    needed to represent mode MODE in a register of class CLASS.  */
                    852: #define CLASS_MAX_NREGS(CLASS, MODE) \
                    853:   ((((CLASS) == XRF_REGS) ? 1 \
                    854:     : ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD)))
                    855: 
                    856: /* Letters in the range `I' through `P' in a register constraint string can
                    857:    be used to stand for particular ranges of immediate operands.  The C
                    858:    expression is true iff C is a known letter and VALUE is appropriate for
                    859:    that letter.
                    860: 
                    861:    For the m88000, the following constants are used:
                    862:    `I' requires a non-negative 16-bit value.
                    863:    `J' requires a non-positive 16-bit value.
                    864:    `K' requires a non-negative value < 32.
                    865:    `L' requires a constant with only the upper 16-bits set.
                    866:    `M' requires constant values that can be formed with `set'.
                    867:    `N' requires a negative value.
                    868:    `O' requires zero.
                    869:    `P' requires a non-negative value.  */
                    870: 
                    871: /* Quick tests for certain values.  */
                    872: #define SMALL_INT(X) (SMALL_INTVAL (INTVAL (X)))
                    873: #define SMALL_INTVAL(I) ((unsigned) (I) < 0x10000)
                    874: #define ADD_INT(X) (ADD_INTVAL (INTVAL (X)))
                    875: #define ADD_INTVAL(I) ((unsigned) (I) + 0xffff < 0x1ffff)
                    876: #define POWER_OF_2(I) ((I) && POWER_OF_2_or_0(I))
                    877: #define POWER_OF_2_or_0(I) (((I) & ((unsigned)(I) - 1)) == 0)
                    878: 
                    879: #define CONST_OK_FOR_LETTER_P(VALUE, C)                        \
                    880:   ((C) == 'I' ? SMALL_INTVAL (VALUE)                   \
                    881:    : (C) == 'J' ? SMALL_INTVAL (-(VALUE))              \
                    882:    : (C) == 'K' ? (unsigned)(VALUE) < 32               \
                    883:    : (C) == 'L' ? ((VALUE) & 0xffff) == 0              \
                    884:    : (C) == 'M' ? integer_ok_for_set (VALUE)           \
                    885:    : (C) == 'N' ? (VALUE) < 0                          \
                    886:    : (C) == 'O' ? (VALUE) == 0                         \
                    887:    : (C) == 'P' ? (VALUE) >= 0                         \
                    888:    : 0)
                    889: 
                    890: /* Similar, but for floating constants, and defining letters G and H.
                    891:    Here VALUE is the CONST_DOUBLE rtx itself.  For the m88000, the
                    892:    constraints are:  `G' requires zero, and `H' requires one or two.  */
                    893: #define CONST_DOUBLE_OK_FOR_LETTER_P(VALUE, C)                         \
                    894:   ((C) == 'G' ? (CONST_DOUBLE_HIGH (VALUE) == 0                                \
                    895:                 && CONST_DOUBLE_LOW (VALUE) == 0)                      \
                    896:    : 0)
                    897: 
                    898: /* Letters in the range `Q' through `U' in a register constraint string
                    899:    may be defined in a machine-dependent fashion to stand for arbitrary
                    900:    operand types.
                    901: 
                    902:    For the m88k, `Q' handles addresses in a call context.  */
                    903: 
                    904: #define EXTRA_CONSTRAINT(OP, C)                                \
                    905:   ((C) == 'Q' ? symbolic_address_p (OP) : 0)
                    906: 
                    907: /*** Describing Stack Layout ***/
                    908: 
                    909: /* Define this if pushing a word on the stack moves the stack pointer
                    910:    to a smaller address.  */
                    911: #define STACK_GROWS_DOWNWARD
                    912: 
                    913: /* Define this if the addresses of local variable slots are at negative
                    914:    offsets from the frame pointer.  */
                    915: /* #define FRAME_GROWS_DOWNWARD */
                    916: 
                    917: /* Offset from the frame pointer to the first local variable slot to be
                    918:    allocated. For the m88k, the debugger wants the return address (r1)
                    919:    stored at location r30+4, and the previous frame pointer stored at
                    920:    location r30.  */
                    921: #define STARTING_FRAME_OFFSET 8
                    922: 
                    923: /* If we generate an insn to push BYTES bytes, this says how many the
                    924:    stack pointer really advances by.  The m88k has no push instruction.  */
                    925: /*  #define PUSH_ROUNDING(BYTES) */
                    926: 
                    927: /* If defined, the maximum amount of space required for outgoing arguments
                    928:    will be computed and placed into the variable
                    929:    `current_function_outgoing_args_size'.  No space will be pushed
                    930:    onto the stack for each call; instead, the function prologue should
                    931:    increase the stack frame size by this amount.  */
                    932: #define ACCUMULATE_OUTGOING_ARGS
                    933: 
                    934: /* Offset from the stack pointer register to the first location at which
                    935:    outgoing arguments are placed.  Use the default value zero.  */
                    936: /* #define STACK_POINTER_OFFSET 0 */
                    937: 
                    938: /* Offset of first parameter from the argument pointer register value.
                    939:    Using an argument pointer, this is 0 for the m88k.  GCC knows
                    940:    how to eliminate the argument pointer references if necessary.  */
                    941: #define FIRST_PARM_OFFSET(FNDECL) 0
                    942: 
                    943: /* Define this if functions should assume that stack space has been
                    944:    allocated for arguments even when their values are passed in
                    945:    registers.
                    946: 
                    947:    The value of this macro is the size, in bytes, of the area reserved for
                    948:    arguments passed in registers.
                    949: 
                    950:    This space can either be allocated by the caller or be a part of the
                    951:    machine-dependent stack frame: `OUTGOING_REG_PARM_STACK_SPACE'
                    952:    says which.  */
                    953: #define REG_PARM_STACK_SPACE(FNDECL) 32
                    954: 
                    955: /* Define this macro if REG_PARM_STACK_SPACE is defined but stack
                    956:    parameters don't skip the area specified by REG_PARM_STACK_SPACE.
                    957:    Normally, when a parameter is not passed in registers, it is placed on
                    958:    the stack beyond the REG_PARM_STACK_SPACE area.  Defining this macro
                    959:    suppresses this behavior and causes the parameter to be passed on the
                    960:    stack in its natural location.  */
                    961: #define STACK_PARMS_IN_REG_PARM_AREA
                    962: 
                    963: /* Define this if it is the responsibility of the caller to allocate the
                    964:    area reserved for arguments passed in registers.  If
                    965:    `ACCUMULATE_OUTGOING_ARGS' is also defined, the only effect of this
                    966:    macro is to determine whether the space is included in
                    967:    `current_function_outgoing_args_size'.  */
                    968: /* #define OUTGOING_REG_PARM_STACK_SPACE */
                    969: 
                    970: /* Offset from the stack pointer register to an item dynamically allocated
                    971:    on the stack, e.g., by `alloca'.
                    972: 
                    973:    The default value for this macro is `STACK_POINTER_OFFSET' plus the
                    974:    length of the outgoing arguments.  The default is correct for most
                    975:    machines.  See `function.c' for details.  */
                    976: /* #define STACK_DYNAMIC_OFFSET(FUNDECL) ... */
                    977: 
                    978: /* Value is the number of bytes of arguments automatically
                    979:    popped when returning from a subroutine call.
                    980:    FUNTYPE is the data type of the function (as a tree),
                    981:    or for a library call it is an identifier node for the subroutine name.
                    982:    SIZE is the number of bytes of arguments passed on the stack.  */
                    983: #define RETURN_POPS_ARGS(FUNTYPE,SIZE) 0
                    984: 
                    985: /* Define how to find the value returned by a function.
                    986:    VALTYPE is the data type of the value (as a tree).
                    987:    If the precise function being called is known, FUNC is its FUNCTION_DECL;
                    988:    otherwise, FUNC is 0.  */
                    989: #define FUNCTION_VALUE(VALTYPE, FUNC) \
                    990:   gen_rtx (REG, \
                    991:           TYPE_MODE (VALTYPE) == BLKmode ? SImode : TYPE_MODE (VALTYPE), \
                    992:           2)
                    993: 
                    994: /* Define this if it differs from FUNCTION_VALUE.  */
                    995: /* #define FUNCTION_OUTGOING_VALUE(VALTYPE, FUNC) ... */
                    996: 
                    997: /* Disable the promotion of some structures and unions to registers. */
                    998: #define RETURN_IN_MEMORY(TYPE) \
                    999:   (TYPE_MODE (TYPE) == BLKmode \
                   1000:    || ((TREE_CODE (TYPE) == RECORD_TYPE || TREE_CODE(TYPE) == UNION_TYPE) \
                   1001:        && !(TYPE_MODE (TYPE) == SImode \
                   1002:            || (TYPE_MODE (TYPE) == BLKmode \
                   1003:                && TYPE_ALIGN (TYPE) == BITS_PER_WORD \
                   1004:                && int_size_in_bytes (TYPE) == UNITS_PER_WORD))))
                   1005: 
                   1006: /* Don't default to pcc-struct-return, because we have already specified
                   1007:    exactly how to return structures in the RETURN_IN_MEMORY macro.  */
                   1008: #define DEFAULT_PCC_STRUCT_RETURN 0
                   1009: 
                   1010: /* Define how to find the value returned by a library function
                   1011:    assuming the value has mode MODE.  */
                   1012: #define LIBCALL_VALUE(MODE)  gen_rtx (REG, MODE, 2)
                   1013: 
                   1014: /* True if N is a possible register number for a function value
                   1015:    as seen by the caller.  */
                   1016: #define FUNCTION_VALUE_REGNO_P(N) ((N) == 2)
                   1017: 
                   1018: /* Determine whether a function argument is passed in a register, and
                   1019:    which register.  See m88k.c.  */
                   1020: #define FUNCTION_ARG(CUM, MODE, TYPE, NAMED) \
                   1021:   m88k_function_arg (CUM, MODE, TYPE, NAMED)
                   1022: 
                   1023: /* Define this if it differs from FUNCTION_ARG.  */
                   1024: /* #define FUNCTION_INCOMING_ARG(CUM, MODE, TYPE, NAMED) ... */
                   1025: 
                   1026: /* A C expression for the number of words, at the beginning of an
                   1027:    argument, must be put in registers.  The value must be zero for
                   1028:    arguments that are passed entirely in registers or that are entirely
                   1029:    pushed on the stack.  */
                   1030: #define FUNCTION_ARG_PARTIAL_NREGS(CUM, MODE, TYPE, NAMED) (0)
                   1031: 
                   1032: /* A C expression that indicates when an argument must be passed by
                   1033:    reference.  If nonzero for an argument, a copy of that argument is
                   1034:    made in memory and a pointer to the argument is passed instead of the
                   1035:    argument itself.  The pointer is passed in whatever way is appropriate
                   1036:    for passing a pointer to that type.  */
                   1037: #define FUNCTION_ARG_PASS_BY_REFERENCE(CUM, MODE, TYPE, NAMED) (0)
                   1038: 
                   1039: /* A C type for declaring a variable that is used as the first argument
                   1040:    of `FUNCTION_ARG' and other related values.  It suffices to count
                   1041:    the number of words of argument so far.  */
                   1042: #define CUMULATIVE_ARGS int
                   1043: 
                   1044: /* Initialize a variable CUM of type CUMULATIVE_ARGS for a call to a
                   1045:    function whose data type is FNTYPE.  For a library call, FNTYPE is 0. */
                   1046: #define INIT_CUMULATIVE_ARGS(CUM,FNTYPE,LIBNAME) ((CUM) = 0)
                   1047: 
                   1048: /* A C statement (sans semicolon) to update the summarizer variable
                   1049:    CUM to advance past an argument in the argument list.  The values
                   1050:    MODE, TYPE and NAMED describe that argument.  Once this is done,
                   1051:    the variable CUM is suitable for analyzing the *following* argument
                   1052:    with `FUNCTION_ARG', etc.  (TYPE is null for libcalls where that
                   1053:    information may not be available.)  */
                   1054: #define FUNCTION_ARG_ADVANCE(CUM, MODE, TYPE, NAMED)                   \
                   1055:   do {                                                                 \
                   1056:     enum machine_mode __mode = (TYPE) ? TYPE_MODE (TYPE) : (MODE);     \
                   1057:     if ((CUM & 1)                                                      \
                   1058:        && (__mode == DImode || __mode == DFmode                        \
                   1059:            || ((TYPE) && TYPE_ALIGN (TYPE) > BITS_PER_WORD)))          \
                   1060:       CUM++;                                                           \
                   1061:     CUM += (((__mode != BLKmode)                                       \
                   1062:             ? GET_MODE_SIZE (MODE) : int_size_in_bytes (TYPE))         \
                   1063:            + 3) / 4;                                                   \
                   1064:   } while (0)
                   1065: 
                   1066: /* True if N is a possible register number for function argument passing.
                   1067:    On the m88000, these are registers 2 through 9.  */
                   1068: #define FUNCTION_ARG_REGNO_P(N) ((N) <= 9 && (N) >= 2)
                   1069: 
                   1070: /* A C expression which determines whether, and in which direction,
                   1071:    to pad out an argument with extra space.  The value should be of
                   1072:    type `enum direction': either `upward' to pad above the argument,
                   1073:    `downward' to pad below, or `none' to inhibit padding.
                   1074: 
                   1075:    This macro does not control the *amount* of padding; that is always
                   1076:    just enough to reach the next multiple of `FUNCTION_ARG_BOUNDARY'.  */
                   1077: #define FUNCTION_ARG_PADDING(MODE, TYPE) \
                   1078:   ((MODE) == BLKmode \
                   1079:    || ((TYPE) && (TREE_CODE (TYPE) == RECORD_TYPE \
                   1080:                  || TREE_CODE (TYPE) == UNION_TYPE)) \
                   1081:    ? upward : GET_MODE_BITSIZE (MODE) < PARM_BOUNDARY ? downward : none)
                   1082: 
                   1083: /* If defined, a C expression that gives the alignment boundary, in bits,
                   1084:    of an argument with the specified mode and type.  If it is not defined,
                   1085:    `PARM_BOUNDARY' is used for all arguments.  */
                   1086: #define FUNCTION_ARG_BOUNDARY(MODE, TYPE) \
                   1087:   (((TYPE) ? TYPE_ALIGN (TYPE) : GET_MODE_SIZE (MODE)) <= PARM_BOUNDARY \
                   1088:     ? PARM_BOUNDARY : 2 * PARM_BOUNDARY)
                   1089: 
                   1090: /* Generate necessary RTL for __builtin_saveregs().
                   1091:    ARGLIST is the argument list; see expr.c.  */
                   1092: #define EXPAND_BUILTIN_SAVEREGS(ARGLIST) m88k_builtin_saveregs (ARGLIST)
                   1093: 
                   1094: /* Generate the assembly code for function entry. */
                   1095: #define FUNCTION_PROLOGUE(FILE, SIZE) m88k_begin_prologue(FILE, SIZE)
                   1096: 
                   1097: /* Perform special actions at the point where the prologue ends.  */
                   1098: #define FUNCTION_END_PROLOGUE(FILE) m88k_end_prologue(FILE)
                   1099: 
                   1100: /* Output assembler code to FILE to increment profiler label # LABELNO
                   1101:    for profiling a function entry.  Redefined in m88kv3.h, m88kv4.h and
                   1102:    m88kdgux.h.  */
                   1103: #define FUNCTION_PROFILER(FILE, LABELNO) \
                   1104:   output_function_profiler (FILE, LABELNO, "mcount", 1)
                   1105: 
                   1106: /* Maximum length in instructions of the code output by FUNCTION_PROFILER.  */
                   1107: #define FUNCTION_PROFILER_LENGTH (5+3+1+5)
                   1108: 
                   1109: /* Output assembler code to FILE to initialize basic-block profiling for
                   1110:    the current module.  LABELNO is unique to each instance.  */
                   1111: #define FUNCTION_BLOCK_PROFILER(FILE, LABELNO) \
                   1112:   output_function_block_profiler (FILE, LABELNO)
                   1113: 
                   1114: /* Maximum length in instructions of the code output by
                   1115:    FUNCTION_BLOCK_PROFILER.  */
                   1116: #define FUNCTION_BLOCK_PROFILER_LENGTH (3+5+2+5)
                   1117: 
                   1118: /* Output assembler code to FILE to increment the count associated with
                   1119:    the basic block number BLOCKNO.  */
                   1120: #define BLOCK_PROFILER(FILE, BLOCKNO) output_block_profiler (FILE, BLOCKNO)
                   1121: 
                   1122: /* Maximum length in instructions of the code output by BLOCK_PROFILER.  */
                   1123: #define BLOCK_PROFILER_LENGTH 4
                   1124: 
                   1125: /* EXIT_IGNORE_STACK should be nonzero if, when returning from a function,
                   1126:    the stack pointer does not matter.  The value is tested only in
                   1127:    functions that have frame pointers.
                   1128:    No definition is equivalent to always zero.  */
                   1129: #define EXIT_IGNORE_STACK (1)
                   1130: 
                   1131: /* Generate the assembly code for function exit. */
                   1132: #define FUNCTION_EPILOGUE(FILE, SIZE) m88k_end_epilogue(FILE, SIZE)
                   1133: 
                   1134: /* Perform special actions at the point where the epilogue begins.  */
                   1135: #define FUNCTION_BEGIN_EPILOGUE(FILE) m88k_begin_epilogue(FILE)
                   1136: 
                   1137: /* Value should be nonzero if functions must have frame pointers.
                   1138:    Zero means the frame pointer need not be set up (and parms
                   1139:    may be accessed via the stack pointer) in functions that seem suitable.
                   1140:    This is computed in `reload', in reload1.c.  */
                   1141: #define FRAME_POINTER_REQUIRED \
                   1142:   (frame_pointer_needed \
                   1143:    || (write_symbols != NO_DEBUG && !TARGET_OCS_FRAME_POSITION))
                   1144: 
                   1145: /* Definitions for register eliminations.
                   1146: 
                   1147:    We have two registers that can be eliminated on the m88k.  First, the
                   1148:    frame pointer register can often be eliminated in favor of the stack
                   1149:    pointer register.  Secondly, the argument pointer register can always be
                   1150:    eliminated; it is replaced with either the stack or frame pointer.  */
                   1151: 
                   1152: /* This is an array of structures.  Each structure initializes one pair
                   1153:    of eliminable registers.  The "from" register number is given first,
                   1154:    followed by "to".  Eliminations of the same "from" register are listed
                   1155:    in order of preference.  */
                   1156: #define ELIMINABLE_REGS                                \
                   1157: {{ ARG_POINTER_REGNUM, STACK_POINTER_REGNUM},  \
                   1158:  { ARG_POINTER_REGNUM, FRAME_POINTER_REGNUM},  \
                   1159:  { FRAME_POINTER_REGNUM, STACK_POINTER_REGNUM}}
                   1160: 
                   1161: /* Given FROM and TO register numbers, say whether this elimination
                   1162:    is allowed.  */
                   1163: #define CAN_ELIMINATE(FROM, TO) \
                   1164:   (!((FROM) == FRAME_POINTER_REGNUM && FRAME_POINTER_REQUIRED))
                   1165: 
                   1166: /* Define the offset between two registers, one to be eliminated, and the other
                   1167:    its replacement, at the start of a routine.  */
                   1168: #define INITIAL_ELIMINATION_OFFSET(FROM, TO, OFFSET)                    \
                   1169: { m88k_layout_frame ();                                                         \
                   1170:   if ((FROM) == FRAME_POINTER_REGNUM && (TO) == STACK_POINTER_REGNUM)   \
                   1171:       (OFFSET) = m88k_fp_offset;                                        \
                   1172:   else if ((FROM) == ARG_POINTER_REGNUM && (TO) == FRAME_POINTER_REGNUM) \
                   1173:     (OFFSET) = m88k_stack_size - m88k_fp_offset;                        \
                   1174:   else if ((FROM) == ARG_POINTER_REGNUM && (TO) == STACK_POINTER_REGNUM) \
                   1175:     (OFFSET) = m88k_stack_size;                                                 \
                   1176:   else                                                                  \
                   1177:     abort ();                                                           \
                   1178: }
                   1179: 
                   1180: /*** Trampolines for Nested Functions ***/
                   1181: 
                   1182: /* Output assembler code for a block containing the constant parts
                   1183:    of a trampoline, leaving space for the variable parts.
                   1184: 
                   1185:    This block is placed on the stack and filled in.  It is aligned
                   1186:    0 mod 128 and those portions that are executed are constant.
                   1187:    This should work for instruction caches that have cache lines up
                   1188:    to the aligned amount (128 is arbitrary), provided no other code
                   1189:    producer is attempting to play the same game.  This of course is
                   1190:    in violation of any number of 88open standards.  */
                   1191: 
                   1192: #define TRAMPOLINE_TEMPLATE(FILE)                                      \
                   1193: {                                                                      \
                   1194:   char buf[256];                                                       \
                   1195:   static int labelno = 0;                                              \
                   1196:   labelno++;                                                           \
                   1197:   ASM_GENERATE_INTERNAL_LABEL (buf, "LTRMP", labelno);                 \
                   1198:   /* Save the return address (r1) in the static chain reg (r11).  */   \
                   1199:   fprintf (FILE, "\tor\t %s,%s,0\n", reg_names[11], reg_names[1]);     \
                   1200:   /* Locate this block; transfer to the next instruction.  */          \
                   1201:   fprintf (FILE, "\tbsr\t %s\n", &buf[1]);                                     \
                   1202:   ASM_OUTPUT_INTERNAL_LABEL (FILE, "LTRMP", labelno);                  \
                   1203:   /* Save r10; use it as the relative pointer; restore r1.  */         \
                   1204:   fprintf (FILE, "\tst\t %s,%s,24\n", reg_names[10], reg_names[1]);    \
                   1205:   fprintf (FILE, "\tor\t %s,%s,0\n", reg_names[10], reg_names[1]);     \
                   1206:   fprintf (FILE, "\tor\t %s,%s,0\n", reg_names[1], reg_names[11]);     \
                   1207:   /* Load the function's address and go there.  */                     \
                   1208:   fprintf (FILE, "\tld\t %s,%s,32\n", reg_names[11], reg_names[10]);   \
                   1209:   fprintf (FILE, "\tjmp.n\t %s\n", reg_names[11]);                     \
                   1210:   /* Restore r10 and load the static chain register.  */               \
                   1211:   fprintf (FILE, "\tld.d\t %s,%s,24\n", reg_names[10], reg_names[10]); \
                   1212:   /* Storage: r10 save area, static chain, function address.  */       \
                   1213:   ASM_OUTPUT_INT (FILE, const0_rtx);                                   \
                   1214:   ASM_OUTPUT_INT (FILE, const0_rtx);                                   \
                   1215:   ASM_OUTPUT_INT (FILE, const0_rtx);                                   \
                   1216: }
                   1217: 
                   1218: /* Length in units of the trampoline for entering a nested function.
                   1219:    This is really two components.  The first 32 bytes are fixed and
                   1220:    must be copied; the last 12 bytes are just storage that's filled
                   1221:    in later.  So for allocation purposes, it's 32+12 bytes, but for
                   1222:    initialization purposes, it's 32 bytes.  */
                   1223: 
                   1224: #define TRAMPOLINE_SIZE (32+12)
                   1225: 
                   1226: /* Alignment required for a trampoline.  128 is used to find the
                   1227:    beginning of a line in the instruction cache and to allow for
                   1228:    instruction cache lines of up to 128 bytes.  */
                   1229: 
                   1230: #define TRAMPOLINE_ALIGNMENT 128
                   1231: 
                   1232: /* Emit RTL insns to initialize the variable parts of a trampoline.
                   1233:    FNADDR is an RTX for the address of the function's pure code.
                   1234:    CXT is an RTX for the static chain value for the function.  */
                   1235: 
                   1236: #define INITIALIZE_TRAMPOLINE(TRAMP, FNADDR, CXT)                      \
                   1237: {                                                                      \
                   1238:   emit_move_insn (gen_rtx (MEM, SImode, plus_constant (TRAMP, 40)), FNADDR); \
                   1239:   emit_move_insn (gen_rtx (MEM, SImode, plus_constant (TRAMP, 36)), CXT); \
                   1240: }
                   1241: 
                   1242: /*** Library Subroutine Names ***/
                   1243: 
                   1244: /* Define this macro if GNU CC should generate calls to the System V
                   1245:    (and ANSI C) library functions `memcpy' and `memset' rather than
                   1246:    the BSD functions `bcopy' and `bzero'.  */
                   1247: #define TARGET_MEM_FUNCTIONS
                   1248: 
                   1249: /*** Addressing Modes ***/
                   1250: 
                   1251: #define EXTRA_CC_MODES CCEVENmode
                   1252: 
                   1253: #define EXTRA_CC_NAMES "CCEVEN"
                   1254: 
                   1255: #define SELECT_CC_MODE(OP,X,Y) CCmode
                   1256: 
                   1257: /* #define HAVE_POST_INCREMENT */
                   1258: /* #define HAVE_POST_DECREMENT */
                   1259: 
                   1260: /* #define HAVE_PRE_DECREMENT */
                   1261: /* #define HAVE_PRE_INCREMENT */
                   1262: 
                   1263: /* Recognize any constant value that is a valid address.  */
                   1264: #define CONSTANT_ADDRESS_P(X)   \
                   1265:   (GET_CODE (X) == LABEL_REF || GET_CODE (X) == SYMBOL_REF             \
                   1266:    || GET_CODE (X) == CONST_INT || GET_CODE (X) == CONST               \
                   1267:    || GET_CODE (X) == HIGH)
                   1268: 
                   1269: /* Maximum number of registers that can appear in a valid memory address.  */
                   1270: #define MAX_REGS_PER_ADDRESS 2
                   1271: 
                   1272: /* The condition for memory shift insns.  */
                   1273: #define SCALED_ADDRESS_P(ADDR)                 \
                   1274:   (GET_CODE (ADDR) == PLUS                     \
                   1275:    && (GET_CODE (XEXP (ADDR, 0)) == MULT       \
                   1276:        || GET_CODE (XEXP (ADDR, 1)) == MULT))
                   1277: 
                   1278: /* Can the reference to X be made short?  */
                   1279: #define SHORT_ADDRESS_P(X,TEMP) \
                   1280:   ((TEMP) = (GET_CODE (X) == CONST ? get_related_value (X) : X), \
                   1281:    ((TEMP) && GET_CODE (TEMP) == SYMBOL_REF && SYMBOL_REF_FLAG (TEMP)))
                   1282: 
                   1283: /* GO_IF_LEGITIMATE_ADDRESS recognizes an RTL expression
                   1284:    that is a valid memory address for an instruction.
                   1285:    The MODE argument is the machine mode for the MEM expression
                   1286:    that wants to use this address.
                   1287: 
                   1288:    On the m88000, a legitimate address has the form REG, REG+REG,
                   1289:    REG+SMALLINT, REG+(REG*modesize) (REG[REG]), or SMALLINT.
                   1290: 
                   1291:    The register elimination process should deal with the argument
                   1292:    pointer and frame pointer changing to REG+SMALLINT.  */
                   1293: 
                   1294: #define LEGITIMATE_INDEX_P(X, MODE)                    \
                   1295:    ((GET_CODE (X) == CONST_INT                         \
                   1296:      && SMALL_INT (X))                                 \
                   1297:     || (REG_P (X)                                      \
                   1298:        && REG_OK_FOR_INDEX_P (X))                      \
                   1299:     || (GET_CODE (X) == MULT                           \
                   1300:        && REG_P (XEXP (X, 0))                          \
                   1301:        && REG_OK_FOR_INDEX_P (XEXP (X, 0))             \
                   1302:        && GET_CODE (XEXP (X, 1)) == CONST_INT          \
                   1303:        && INTVAL (XEXP (X, 1)) == GET_MODE_SIZE (MODE)))
                   1304: 
                   1305: #define GO_IF_LEGITIMATE_ADDRESS(MODE, X, ADDR)                \
                   1306: {                                                      \
                   1307:   register rtx _x;                                     \
                   1308:   if (REG_P (X))                                       \
                   1309:     {                                                  \
                   1310:       if (REG_OK_FOR_BASE_P (X))                       \
                   1311:        goto ADDR;                                      \
                   1312:     }                                                  \
                   1313:   else if (GET_CODE (X) == PLUS)                       \
                   1314:     {                                                  \
                   1315:       register rtx _x0 = XEXP (X, 0);                  \
                   1316:       register rtx _x1 = XEXP (X, 1);                  \
                   1317:       if ((flag_pic                                    \
                   1318:           && _x0 == pic_offset_table_rtx               \
                   1319:           && (flag_pic == 2                            \
                   1320:               ? REG_P (_x1)                            \
                   1321:               : (GET_CODE (_x1) == SYMBOL_REF          \
                   1322:                  || GET_CODE (_x1) == LABEL_REF)))     \
                   1323:          || (REG_P (_x0)                               \
                   1324:              && (REG_OK_FOR_BASE_P (_x0)               \
                   1325:                  && LEGITIMATE_INDEX_P (_x1, MODE)))   \
                   1326:          || (REG_P (_x1)                               \
                   1327:              && (REG_OK_FOR_BASE_P (_x1)               \
                   1328:                  && LEGITIMATE_INDEX_P (_x0, MODE))))  \
                   1329:        goto ADDR;                                      \
                   1330:     }                                                  \
                   1331:   else if (GET_CODE (X) == LO_SUM)                     \
                   1332:     {                                                  \
                   1333:       register rtx _x0 = XEXP (X, 0);                  \
                   1334:       register rtx _x1 = XEXP (X, 1);                  \
                   1335:       if (((REG_P (_x0)                                        \
                   1336:            && REG_OK_FOR_BASE_P (_x0))                 \
                   1337:           || (GET_CODE (_x0) == SUBREG                 \
                   1338:               && REG_P (SUBREG_REG (_x0))              \
                   1339:               && REG_OK_FOR_BASE_P (SUBREG_REG (_x0)))) \
                   1340:          && CONSTANT_P (_x1))                          \
                   1341:        goto ADDR;                                      \
                   1342:     }                                                  \
                   1343:   else if (GET_CODE (X) == CONST_INT                   \
                   1344:           && SMALL_INT (X))                            \
                   1345:     goto ADDR;                                         \
                   1346:   else if (SHORT_ADDRESS_P (X, _x))                    \
                   1347:     goto ADDR;                                         \
                   1348: }
                   1349: 
                   1350: /* The macros REG_OK_FOR..._P assume that the arg is a REG rtx
                   1351:    and check its validity for a certain class.
                   1352:    We have two alternate definitions for each of them.
                   1353:    The usual definition accepts all pseudo regs; the other rejects
                   1354:    them unless they have been allocated suitable hard regs.
                   1355:    The symbol REG_OK_STRICT causes the latter definition to be used.
                   1356: 
                   1357:    Most source files want to accept pseudo regs in the hope that
                   1358:    they will get allocated to the class that the insn wants them to be in.
                   1359:    Source files for reload pass need to be strict.
                   1360:    After reload, it makes no difference, since pseudo regs have
                   1361:    been eliminated by then.  */
                   1362: 
                   1363: #ifndef REG_OK_STRICT
                   1364: 
                   1365: /* Nonzero if X is a hard reg that can be used as an index
                   1366:    or if it is a pseudo reg.  Not the argument pointer.  */
                   1367: #define REG_OK_FOR_INDEX_P(X)                                         \
                   1368:   (!XRF_REGNO_P(REGNO (X)))
                   1369: /* Nonzero if X is a hard reg that can be used as a base reg
                   1370:    or if it is a pseudo reg.  */
                   1371: #define REG_OK_FOR_BASE_P(X) (REG_OK_FOR_INDEX_P (X))
                   1372: 
                   1373: #else
                   1374: 
                   1375: /* Nonzero if X is a hard reg that can be used as an index.  */
                   1376: #define REG_OK_FOR_INDEX_P(X) REGNO_OK_FOR_INDEX_P (REGNO (X))
                   1377: /* Nonzero if X is a hard reg that can be used as a base reg.  */
                   1378: #define REG_OK_FOR_BASE_P(X) REGNO_OK_FOR_BASE_P (REGNO (X))
                   1379: 
                   1380: #endif
                   1381: 
                   1382: /* Try machine-dependent ways of modifying an illegitimate address
                   1383:    to be legitimate.  If we find one, return the new, valid address.
                   1384:    This macro is used in only one place: `memory_address' in explow.c.
                   1385: 
                   1386:    OLDX is the address as it was before break_out_memory_refs was called.
                   1387:    In some cases it is useful to look at this to decide what needs to be done.
                   1388: 
                   1389:    MODE and WIN are passed so that this macro can use
                   1390:    GO_IF_LEGITIMATE_ADDRESS.
                   1391: 
                   1392:    It is always safe for this macro to do nothing.  It exists to recognize
                   1393:    opportunities to optimize the output.  */
                   1394: 
                   1395: /* On the m88000, change REG+N into REG+REG, and REG+(X*Y) into REG+REG.  */
                   1396: 
                   1397: #define LEGITIMIZE_ADDRESS(X,OLDX,MODE,WIN)                    \
                   1398: {                                                              \
                   1399:   if (GET_CODE (X) == PLUS && CONSTANT_ADDRESS_P (XEXP (X, 1)))        \
                   1400:     (X) = gen_rtx (PLUS, SImode, XEXP (X, 0),                  \
                   1401:                   copy_to_mode_reg (SImode, XEXP (X, 1)));     \
                   1402:   if (GET_CODE (X) == PLUS && CONSTANT_ADDRESS_P (XEXP (X, 0)))        \
                   1403:     (X) = gen_rtx (PLUS, SImode, XEXP (X, 1),                  \
                   1404:                   copy_to_mode_reg (SImode, XEXP (X, 0)));     \
                   1405:   if (GET_CODE (X) == PLUS && GET_CODE (XEXP (X, 0)) == MULT)  \
                   1406:     (X) = gen_rtx (PLUS, SImode, XEXP (X, 1),                  \
                   1407:                   force_operand (XEXP (X, 0), 0));             \
                   1408:   if (GET_CODE (X) == PLUS && GET_CODE (XEXP (X, 1)) == MULT)  \
                   1409:     (X) = gen_rtx (PLUS, SImode, XEXP (X, 0),                  \
                   1410:                   force_operand (XEXP (X, 1), 0));             \
                   1411:   if (GET_CODE (X) == SYMBOL_REF || GET_CODE (X) == CONST      \
                   1412:           || GET_CODE (X) == LABEL_REF)                        \
                   1413:     (X) = legitimize_address (flag_pic, X, 0, 0);              \
                   1414:   if (memory_address_p (MODE, X))                              \
                   1415:     goto WIN; }
                   1416: 
                   1417: /* Go to LABEL if ADDR (a legitimate address expression)
                   1418:    has an effect that depends on the machine mode it is used for.
                   1419:    On the the m88000 this is never true.  */
                   1420: 
                   1421: #define GO_IF_MODE_DEPENDENT_ADDRESS(ADDR,LABEL)
                   1422: 
                   1423: /* Nonzero if the constant value X is a legitimate general operand.
                   1424:    It is given that X satisfies CONSTANT_P or is a CONST_DOUBLE.  */
                   1425: #define LEGITIMATE_CONSTANT_P(X) (1)
                   1426: 
                   1427: /*** Condition Code Information ***/
                   1428: 
                   1429: /* C code for a data type which is used for declaring the `mdep'
                   1430:    component of `cc_status'.  It defaults to `int'.  */
                   1431: /* #define CC_STATUS_MDEP int */
                   1432: 
                   1433: /* A C expression to initialize the `mdep' field to "empty".  */
                   1434: /* #define CC_STATUS_MDEP_INIT (cc_status.mdep = 0) */
                   1435: 
                   1436: /* Macro to zap the normal portions of CC_STATUS, but leave the
                   1437:    machine dependent parts (ie, literal synthesis) alone.  */
                   1438: /* #define CC_STATUS_INIT_NO_MDEP \
                   1439:   (cc_status.flags = 0, cc_status.value1 = 0, cc_status.value2 = 0) */
                   1440: 
                   1441: /* When using a register to hold the condition codes, the cc_status
                   1442:    mechanism cannot be used.  */
                   1443: #define NOTICE_UPDATE_CC(EXP, INSN) (0)
                   1444: 
                   1445: /*** Miscellaneous Parameters ***/
                   1446: 
                   1447: /* Define the codes that are matched by predicates in m88k.c.  */
                   1448: #define PREDICATE_CODES                                                        \
                   1449:   {"move_operand", {SUBREG, REG, CONST_INT, LO_SUM, MEM}},             \
                   1450:   {"call_address_operand", {SUBREG, REG, SYMBOL_REF, LABEL_REF, CONST}}, \
                   1451:   {"arith_operand", {SUBREG, REG, CONST_INT}},                         \
                   1452:   {"arith5_operand", {SUBREG, REG, CONST_INT}},                                \
                   1453:   {"arith32_operand", {SUBREG, REG, CONST_INT}},                       \
                   1454:   {"arith64_operand", {SUBREG, REG, CONST_INT}},                       \
                   1455:   {"int5_operand", {CONST_INT}},                                       \
                   1456:   {"int32_operand", {CONST_INT}},                                      \
                   1457:   {"add_operand", {SUBREG, REG, CONST_INT}},                           \
                   1458:   {"reg_or_bbx_mask_operand", {SUBREG, REG, CONST_INT}},               \
                   1459:   {"real_or_0_operand", {SUBREG, REG, CONST_DOUBLE}},                  \
                   1460:   {"reg_or_0_operand", {SUBREG, REG, CONST_INT}},                      \
                   1461:   {"relop", {EQ, NE, LT, LE, GE, GT, LTU, LEU, GEU, GTU}},             \
                   1462:   {"even_relop", {EQ, LT, GT, LTU, GTU}},              \
                   1463:   {"odd_relop", { NE, LE, GE, LEU, GEU}},              \
                   1464:   {"partial_ccmode_register_operand", { SUBREG, REG}},                 \
                   1465:   {"relop_no_unsigned", {EQ, NE, LT, LE, GE, GT}},                     \
                   1466:   {"equality_op", {EQ, NE}},                                           \
                   1467:   {"pc_or_label_ref", {PC, LABEL_REF}},
                   1468: 
                   1469: /* The case table contains either words or branch instructions.  This says
                   1470:    which.  We always claim that the vector is PC-relative.  It is position
                   1471:    independent when -fpic is used.  */
                   1472: #define CASE_VECTOR_INSNS (TARGET_88100 || flag_pic)
                   1473: 
                   1474: /* An alias for a machine mode name.  This is the machine mode that
                   1475:    elements of a jump-table should have.  */
                   1476: #define CASE_VECTOR_MODE SImode
                   1477: 
                   1478: /* Define this macro if jump-tables should contain relative addresses.  */
                   1479: #define CASE_VECTOR_PC_RELATIVE
                   1480: 
                   1481: /* Define this if control falls through a `case' insn when the index
                   1482:    value is out of range.  This means the specified default-label is
                   1483:    actually ignored by the `case' insn proper.  */
                   1484: /* #define CASE_DROPS_THROUGH */
                   1485: 
                   1486: /* Define this to be the smallest number of different values for which it
                   1487:    is best to use a jump-table instead of a tree of conditional branches.
                   1488:    The default is 4 for machines with a casesi instruction and 5 otherwise.
                   1489:    The best 88110 number is around 7, though the exact number isn't yet
                   1490:    known.  A third alternative for the 88110 is to use a binary tree of
                   1491:    bb1 instructions on bits 2/1/0 if the range is dense.  This may not
                   1492:    win very much though.  */
                   1493: #define CASE_VALUES_THRESHOLD (TARGET_88100 ? 4 : 7)
                   1494: 
                   1495: /* Specify the tree operation to be used to convert reals to integers.  */
                   1496: #define IMPLICIT_FIX_EXPR FIX_ROUND_EXPR
                   1497: 
                   1498: /* This is the kind of divide that is easiest to do in the general case.  */
                   1499: #define EASY_DIV_EXPR TRUNC_DIV_EXPR
                   1500: 
                   1501: /* Define this as 1 if `char' should by default be signed; else as 0.  */
                   1502: #define DEFAULT_SIGNED_CHAR 1
                   1503: 
                   1504: /* The 88open ABI says size_t is unsigned int.  */
                   1505: #define SIZE_TYPE "unsigned int"
                   1506: 
                   1507: /* Allow and ignore #sccs directives */
                   1508: #define SCCS_DIRECTIVE
                   1509: 
                   1510: /* Handle #pragma pack and sometimes #pragma weak.  */
                   1511: #define HANDLE_SYSV_PRAGMA
                   1512: 
                   1513: /* Tell when to handle #pragma weak.  This is only done for V.4.  */
                   1514: #define HANDLE_PRAGMA_WEAK TARGET_SVR4
                   1515: 
                   1516: /* Max number of bytes we can move from memory to memory
                   1517:    in one reasonably fast instruction.  */
                   1518: #define MOVE_MAX 8
                   1519: 
                   1520: /* Define if operations between registers always perform the operation
                   1521:    on the full register even if a narrower mode is specified.  */
                   1522: #define WORD_REGISTER_OPERATIONS
                   1523: 
                   1524: /* Define if loading in MODE, an integral mode narrower than BITS_PER_WORD
                   1525:    will either zero-extend or sign-extend.  The value of this macro should
                   1526:    be the code that says which one of the two operations is implicitly
                   1527:    done, NIL if none.  */
                   1528: #define LOAD_EXTEND_OP(MODE) ZERO_EXTEND
                   1529: 
                   1530: /* Zero if access to memory by bytes is faster.  */
                   1531: #define SLOW_BYTE_ACCESS 1
                   1532: 
                   1533: /* Value is 1 if truncating an integer of INPREC bits to OUTPREC bits
                   1534:    is done just by pretending it is already truncated.  */
                   1535: #define TRULY_NOOP_TRUNCATION(OUTPREC, INPREC) 1
                   1536: 
                   1537: /* Define this if addresses of constant functions
                   1538:    shouldn't be put through pseudo regs where they can be cse'd.
                   1539:    Desirable on machines where ordinary constants are expensive
                   1540:    but a CALL with constant address is cheap.  */
                   1541: #define NO_FUNCTION_CSE
                   1542: 
                   1543: /* Define this macro if an argument declared as `char' or
                   1544:    `short' in a prototype should actually be passed as an
                   1545:    `int'.  In addition to avoiding errors in certain cases of
                   1546:    mismatch, it also makes for better code on certain machines.  */
                   1547: #define PROMOTE_PROTOTYPES
                   1548: 
                   1549: /* Define this macro if a float function always returns float
                   1550:    (even in traditional mode).  Redefined in m88kluna.h.  */
                   1551: #define TRADITIONAL_RETURN_FLOAT
                   1552: 
                   1553: /* We assume that the store-condition-codes instructions store 0 for false
                   1554:    and some other value for true.  This is the value stored for true.  */
                   1555: #define STORE_FLAG_VALUE -1
                   1556: 
                   1557: /* Specify the machine mode that pointers have.
                   1558:    After generation of rtl, the compiler makes no further distinction
                   1559:    between pointers and any other objects of this machine mode.  */
                   1560: #define Pmode SImode
                   1561: 
                   1562: /* A function address in a call instruction
                   1563:    is a word address (for indexing purposes)
                   1564:    so give the MEM rtx word mode.  */
                   1565: #define FUNCTION_MODE SImode
                   1566: 
                   1567: /* A barrier will be aligned so account for the possible expansion.
                   1568:    A volatile load may be preceded by a serializing instruction.
                   1569:    Account for profiling code output at NOTE_INSN_PROLOGUE_END.
                   1570:    Account for block profiling code at basic block boundaries.  */
                   1571: #define ADJUST_INSN_LENGTH(RTX, LENGTH)                                        \
                   1572:   if (GET_CODE (RTX) == BARRIER                                                \
                   1573:       || (TARGET_SERIALIZE_VOLATILE                                    \
                   1574:          && GET_CODE (RTX) == INSN                                     \
                   1575:          && GET_CODE (PATTERN (RTX)) == SET                            \
                   1576:          && ((GET_CODE (SET_SRC (PATTERN (RTX))) == MEM                \
                   1577:               && MEM_VOLATILE_P (SET_SRC (PATTERN (RTX)))))))          \
                   1578:     LENGTH += 1;                                                       \
                   1579:   else if (GET_CODE (RTX) == NOTE                                      \
                   1580:           && NOTE_LINE_NUMBER (RTX) == NOTE_INSN_PROLOGUE_END)         \
                   1581:     {                                                                  \
                   1582:       if (profile_block_flag)                                          \
                   1583:        LENGTH += FUNCTION_BLOCK_PROFILER_LENGTH;                       \
                   1584:       if (profile_flag)                                                        \
                   1585:        LENGTH += (FUNCTION_PROFILER_LENGTH + REG_PUSH_LENGTH           \
                   1586:                   + REG_POP_LENGTH);                                   \
                   1587:     }                                                                  \
                   1588:   else if (profile_block_flag                                          \
                   1589:           && (GET_CODE (RTX) == CODE_LABEL                             \
                   1590:               || GET_CODE (RTX) == JUMP_INSN                           \
                   1591:               || (GET_CODE (RTX) == INSN                               \
                   1592:                   && GET_CODE (PATTERN (RTX)) == SEQUENCE              \
                   1593:                   && GET_CODE (XVECEXP (PATTERN (RTX), 0, 0)) == JUMP_INSN)))\
                   1594:     LENGTH += BLOCK_PROFILER_LENGTH;
                   1595: 
                   1596: /* Track the state of the last volatile memory reference.  Clear the
                   1597:    state with CC_STATUS_INIT for now.  */
                   1598: #define CC_STATUS_INIT m88k_volatile_code = '\0'
                   1599: 
                   1600: /* Compute the cost of computing a constant rtl expression RTX
                   1601:    whose rtx-code is CODE.  The body of this macro is a portion
                   1602:    of a switch statement.  If the code is computed here,
                   1603:    return it with a return statement.  Otherwise, break from the switch.
                   1604: 
                   1605:    We assume that any 16 bit integer can easily be recreated, so we
                   1606:    indicate 0 cost, in an attempt to get GCC not to optimize things
                   1607:    like comparison against a constant.
                   1608: 
                   1609:    The cost of CONST_DOUBLE is zero (if it can be placed in an insn, it
                   1610:    is as good as a register; since it can't be placed in any insn, it
                   1611:    won't do anything in cse, but it will cause expand_binop to pass the
                   1612:    constant to the define_expands).  */
                   1613: #define CONST_COSTS(RTX,CODE,OUTER_CODE)               \
                   1614:   case CONST_INT:                                      \
                   1615:     if (SMALL_INT (RTX))                               \
                   1616:       return 0;                                                \
                   1617:     else if (SMALL_INTVAL (- INTVAL (RTX)))            \
                   1618:       return 2;                                                \
                   1619:     else if (classify_integer (SImode, INTVAL (RTX)) != m88k_oru_or) \
                   1620:       return 4;                                                \
                   1621:     return 7;                                          \
                   1622:   case HIGH:                                           \
                   1623:     return 2;                                          \
                   1624:   case CONST:                                          \
                   1625:   case LABEL_REF:                                      \
                   1626:   case SYMBOL_REF:                                     \
                   1627:     if (flag_pic)                                      \
                   1628:       return (flag_pic == 2) ? 11 : 8;                 \
                   1629:     return 5;                                          \
                   1630:   case CONST_DOUBLE:                                   \
                   1631:     return 0;
                   1632: 
                   1633: /* Provide the costs of an addressing mode that contains ADDR.
                   1634:    If ADDR is not a valid address, its cost is irrelevant.
                   1635:    REG+REG is made slightly more expensive because it might keep
                   1636:    a register live for longer than we might like.  */
                   1637: #define ADDRESS_COST(ADDR)                             \
                   1638:   (GET_CODE (ADDR) == REG ? 1 :                                \
                   1639:    GET_CODE (ADDR) == LO_SUM ? 1 :                     \
                   1640:    GET_CODE (ADDR) == HIGH ? 2 :                       \
                   1641:    GET_CODE (ADDR) == MULT ? 1 :                       \
                   1642:    GET_CODE (ADDR) != PLUS ? 4 :                       \
                   1643:    (REG_P (XEXP (ADDR, 0)) && REG_P (XEXP (ADDR, 1))) ? 2 : 1)
                   1644: 
                   1645: /* Provide the costs of a rtl expression.  This is in the body of a
                   1646:    switch on CODE.  */
                   1647: #define RTX_COSTS(X,CODE,OUTER_CODE)                           \
                   1648:   case MEM:                                            \
                   1649:     return COSTS_N_INSNS (2);                          \
                   1650:   case MULT:                                           \
                   1651:     return COSTS_N_INSNS (3);                          \
                   1652:   case DIV:                                            \
                   1653:   case UDIV:                                           \
                   1654:   case MOD:                                            \
                   1655:   case UMOD:                                           \
                   1656:     return COSTS_N_INSNS (38);
                   1657: 
                   1658: /* A C expressions returning the cost of moving data of MODE from a register
                   1659:    to or from memory.  This is more costly than between registers.  */
                   1660: #define MEMORY_MOVE_COST(MODE) 4
                   1661: 
                   1662: /* Provide the cost of a branch.  Exact meaning under development.  */
                   1663: #define BRANCH_COST (TARGET_88100 ? 1 : 2)
                   1664: 
                   1665: /* A C statement (sans semicolon) to update the integer variable COST
                   1666:    based on the relationship between INSN that is dependent on
                   1667:    DEP_INSN through the dependence LINK.  The default is to make no
                   1668:    adjustment to COST.  On the m88k, ignore the cost of anti- and
                   1669:    output-dependencies.  On the m88100, a store can issue two cycles
                   1670:    before the value (not the address) has finished computing.  */
                   1671: #define ADJUST_COST(INSN,LINK,DEP_INSN,COST)                           \
                   1672:   do {                                                                 \
                   1673:     if (REG_NOTE_KIND (LINK) != 0)                                     \
                   1674:       (COST) = 0; /* Anti or output dependence.  */                    \
                   1675:     else if (! TARGET_88100                                            \
                   1676:             && recog_memoized (INSN) >= 0                              \
                   1677:             && get_attr_type (INSN) == TYPE_STORE                      \
                   1678:             && SET_SRC (PATTERN (INSN)) == SET_DEST (PATTERN (DEP_INSN))) \
                   1679:       (COST) -= 4; /* 88110 store reservation station.  */             \
                   1680:   } while (0)
                   1681: 
                   1682: /* Define this to be nonzero if the character `$' should be allowed
                   1683:    by default in identifier names.  */
                   1684: #define        DOLLARS_IN_IDENTIFIERS  1
                   1685: 
                   1686: /* Do not break .stabs pseudos into continuations.  */
                   1687: #define DBX_CONTIN_LENGTH 0
                   1688: 
                   1689: /*** Output of Assembler Code ***/
                   1690: 
                   1691: /* Control the assembler format that we output.  */
                   1692: 
                   1693: /* Which assembler syntax.  Redefined in m88kdgux.h.  */
                   1694: #define VERSION_0300_SYNTAX TARGET_SVR4
                   1695: 
                   1696: /* At some point, m88kv4.h will redefine this.  */
                   1697: #define VERSION_0400_SYNTAX 0
                   1698: 
                   1699: /* Allow pseudo-ops to be overridden.  Override these in svr[34].h.  */
                   1700: #undef INT_ASM_OP
                   1701: #undef ASCII_DATA_ASM_OP
                   1702: #undef CONST_SECTION_ASM_OP
                   1703: #undef CTORS_SECTION_ASM_OP
                   1704: #undef DTORS_SECTION_ASM_OP
                   1705: #undef INIT_SECTION_ASM_OP
                   1706: #undef FINI_SECTION_ASM_OP
                   1707: #undef TYPE_ASM_OP
                   1708: #undef SIZE_ASM_OP
                   1709: #undef WEAK_ASM_OP
                   1710: #undef SET_ASM_OP
                   1711: #undef SKIP_ASM_OP
                   1712: #undef COMMON_ASM_OP
                   1713: #undef ALIGN_ASM_OP
                   1714: #undef IDENT_ASM_OP
                   1715: 
                   1716: /* These are used in varasm.c as well.  */
                   1717: #define TEXT_SECTION_ASM_OP    "text"
                   1718: #define DATA_SECTION_ASM_OP    "data"
                   1719: 
                   1720: /* Other sections.  */
                   1721: #define CONST_SECTION_ASM_OP (VERSION_0300_SYNTAX              \
                   1722:                              ? "section\t .rodata,\"a\""       \
                   1723:                              : "section\t .rodata,\"x\"")
                   1724: #define TDESC_SECTION_ASM_OP (VERSION_0300_SYNTAX              \
                   1725:                              ? "section\t .tdesc,\"a\""        \
                   1726:                              : "section\t .tdesc,\"x\"")
                   1727: 
                   1728: /* These must be constant strings for crtstuff.c.  */
                   1729: #define CTORS_SECTION_ASM_OP   "section\t .ctors,\"d\""
                   1730: #define DTORS_SECTION_ASM_OP   "section\t .dtors,\"d\""
                   1731: #define INIT_SECTION_ASM_OP    "section\t .init,\"x\""
                   1732: #define FINI_SECTION_ASM_OP    "section\t .fini,\"x\""
                   1733: 
                   1734: /* These are pretty much common to all assemblers.  */
                   1735: #define IDENT_ASM_OP           "ident"
                   1736: #define FILE_ASM_OP            "file"
                   1737: #define SECTION_ASM_OP         "section"
                   1738: #define SET_ASM_OP             "def"
                   1739: #define GLOBAL_ASM_OP          "global"
                   1740: #define ALIGN_ASM_OP           "align"
                   1741: #define SKIP_ASM_OP            "zero"
                   1742: #define COMMON_ASM_OP          "comm"
                   1743: #define BSS_ASM_OP             "bss"
                   1744: #define FLOAT_ASM_OP           "float"
                   1745: #define DOUBLE_ASM_OP          "double"
                   1746: #define INT_ASM_OP             "word"
                   1747: #define ASM_LONG               INT_ASM_OP
                   1748: #define SHORT_ASM_OP           "half"
                   1749: #define CHAR_ASM_OP            "byte"
                   1750: #define ASCII_DATA_ASM_OP      "string"
                   1751: 
                   1752: /* These are particular to the global pool optimization.  */
                   1753: #define SBSS_ASM_OP            "sbss"
                   1754: #define SCOMM_ASM_OP           "scomm"
                   1755: #define SDATA_SECTION_ASM_OP   "sdata"
                   1756: 
                   1757: /* These are specific to PIC.  */
                   1758: #define TYPE_ASM_OP            "type"
                   1759: #define SIZE_ASM_OP            "size"
                   1760: #define WEAK_ASM_OP            "weak"
                   1761: #ifndef AS_BUG_POUND_TYPE /* Faulty assemblers require @ rather than #.  */
                   1762: #undef TYPE_OPERAND_FMT
                   1763: #define TYPE_OPERAND_FMT       "#%s"
                   1764: #endif
                   1765: 
                   1766: /* These are specific to version 03.00 assembler syntax.  */
                   1767: #define INTERNAL_ASM_OP                "local"
                   1768: #define VERSION_ASM_OP         "version"
                   1769: #define UNALIGNED_SHORT_ASM_OP "uahalf"
                   1770: #define UNALIGNED_INT_ASM_OP   "uaword"
                   1771: #define PUSHSECTION_ASM_OP     "section"
                   1772: #define POPSECTION_ASM_OP      "previous"
                   1773: 
                   1774: /* These are specific to the version 04.00 assembler syntax.  */
                   1775: #define REQUIRES_88110_ASM_OP  "requires_88110"
                   1776: 
                   1777: /* Output any initial stuff to the assembly file.  Always put out
                   1778:    a file directive, even if not debugging.
                   1779: 
                   1780:    Immediately after putting out the file, put out a "sem.<value>"
                   1781:    declaration.  This should be harmless on other systems, and
                   1782:    is used in DG/UX by the debuggers to supplement COFF.  The
                   1783:    fields in the integer value are as follows:
                   1784: 
                   1785:    Bits        Value   Meaning
                   1786:    ----        -----   -------
                   1787:    0-1 0       No information about stack locations
                   1788:        1       Auto/param locations are based on r30
                   1789:        2       Auto/param locations are based on CFA
                   1790: 
                   1791:    3-2 0       No information on dimension order
                   1792:        1       Array dims in sym table matches source language
                   1793:        2       Array dims in sym table is in reverse order
                   1794: 
                   1795:    5-4 0       No information about the case of global names
                   1796:        1       Global names appear in the symbol table as in the source
                   1797:        2       Global names have been converted to lower case
                   1798:        3       Global names have been converted to upper case.  */
                   1799: 
                   1800: #ifdef SDB_DEBUGGING_INFO
                   1801: #define ASM_COFFSEM(FILE)                                              \
                   1802:     if (write_symbols == SDB_DEBUG)                                    \
                   1803:       {                                                                        \
                   1804:        fprintf (FILE, "\nsem.%x:\t\t; %s\n",                           \
                   1805:                 (((TARGET_OCS_FRAME_POSITION) ? 2 : 1) << 0) + (1 << 2) + (1 << 4),\
                   1806:                 (TARGET_OCS_FRAME_POSITION)                            \
                   1807:                        ? "frame is CFA, normal array dims, case unchanged" \
                   1808:                        : "frame is r30, normal array dims, case unchanged"); \
                   1809:       }
                   1810: #else
                   1811: #define ASM_COFFSEM(FILE)
                   1812: #endif
                   1813: 
                   1814: /* Output the first line of the assembly file.  Redefined in m88kdgux.h.  */
                   1815: 
                   1816: #define ASM_FIRST_LINE(FILE)                                           \
                   1817:   do {                                                                 \
                   1818:     if (m88k_version)                                                  \
                   1819:       fprintf (FILE, "\t%s\t \"%s\"\n", VERSION_ASM_OP, m88k_version); \
                   1820:   } while (0)
                   1821: 
                   1822: /* Override svr[34].h.  */
                   1823: #undef ASM_FILE_START
                   1824: #define ASM_FILE_START(FILE) \
                   1825:   output_file_start (FILE, f_options, sizeof f_options / sizeof f_options[0], \
                   1826:                     W_options, sizeof W_options / sizeof W_options[0])
                   1827: 
                   1828: #undef ASM_FILE_END
                   1829: 
                   1830: #define ASM_OUTPUT_SOURCE_FILENAME(FILE, NAME) \
                   1831:   do { fprintf (FILE, "\t%s\t ", FILE_ASM_OP);                 \
                   1832:        output_quoted_string (FILE, NAME);                      \
                   1833:        fprintf (FILE, "\n");                                   \
                   1834:   } while (0)
                   1835: 
                   1836: #ifdef SDB_DEBUGGING_INFO
                   1837: #define ASM_OUTPUT_SOURCE_LINE(FILE, LINE)                     \
                   1838:   if (m88k_prologue_done)                                      \
                   1839:     fprintf (FILE, "\n\tln\t %d\t\t\t\t; Real source line %d\n",\
                   1840:             LINE - sdb_begin_function_line, LINE)
                   1841: #endif
                   1842: 
                   1843: /* Code to handle #ident directives.  Override svr[34].h definition.  */
                   1844: #undef ASM_OUTPUT_IDENT
                   1845: #ifdef DBX_DEBUGGING_INFO
                   1846: #define ASM_OUTPUT_IDENT(FILE, NAME)
                   1847: #else
                   1848: #define ASM_OUTPUT_IDENT(FILE, NAME) \
                   1849:   output_ascii (FILE, IDENT_ASM_OP, 4000, NAME, strlen (NAME));
                   1850: #endif
                   1851: 
                   1852: /* Output to assembler file text saying following lines
                   1853:    may contain character constants, extra white space, comments, etc.  */
                   1854: #define ASM_APP_ON ""
                   1855: 
                   1856: /* Output to assembler file text saying following lines
                   1857:    no longer contain unusual constructs.  */
                   1858: #define ASM_APP_OFF ""
                   1859: 
                   1860: /* Format the assembly opcode so that the arguments are all aligned.
                   1861:    The maximum instruction size is 8 characters (fxxx.xxx), so a tab and a
                   1862:    space will do to align the output.  Abandon the output if a `%' is
                   1863:    encountered.  */
                   1864: #define ASM_OUTPUT_OPCODE(STREAM, PTR)                                 \
                   1865:   {                                                                    \
                   1866:     int ch;                                                            \
                   1867:     char *orig_ptr;                                                    \
                   1868:                                                                        \
                   1869:     for (orig_ptr = (PTR);                                             \
                   1870:         (ch = *(PTR)) && ch != ' ' && ch != '\t' && ch != '\n' && ch != '%'; \
                   1871:         (PTR)++)                                                       \
                   1872:       putc (ch, STREAM);                                               \
                   1873:                                                                        \
                   1874:     if (ch == ' ' && orig_ptr != (PTR) && (PTR) - orig_ptr < 8)                \
                   1875:       putc ('\t', STREAM);                                             \
                   1876:   }
                   1877: 
                   1878: /* How to refer to registers in assembler output.
                   1879:    This sequence is indexed by compiler's hard-register-number.
                   1880:    Updated by OVERRIDE_OPTIONS to include the # for version 03.00 syntax.  */
                   1881: 
                   1882: #define REGISTER_NAMES \
                   1883:   {"#r0"+1, "#r1"+1, "#r2"+1, "#r3"+1, "#r4"+1, "#r5"+1, "#r6"+1, "#r7"+1, \
                   1884:    "#r8"+1, "#r9"+1, "#r10"+1,"#r11"+1,"#r12"+1,"#r13"+1,"#r14"+1,"#r15"+1,\
                   1885:    "#r16"+1,"#r17"+1,"#r18"+1,"#r19"+1,"#r20"+1,"#r21"+1,"#r22"+1,"#r23"+1,\
                   1886:    "#r24"+1,"#r25"+1,"#r26"+1,"#r27"+1,"#r28"+1,"#r29"+1,"#r30"+1,"#r31"+1,\
                   1887:    "#x0"+1, "#x1"+1, "#x2"+1, "#x3"+1, "#x4"+1, "#x5"+1, "#x6"+1, "#x7"+1, \
                   1888:    "#x8"+1, "#x9"+1, "#x10"+1,"#x11"+1,"#x12"+1,"#x13"+1,"#x14"+1,"#x15"+1,\
                   1889:    "#x16"+1,"#x17"+1,"#x18"+1,"#x19"+1,"#x20"+1,"#x21"+1,"#x22"+1,"#x23"+1,\
                   1890:    "#x24"+1,"#x25"+1,"#x26"+1,"#x27"+1,"#x28"+1,"#x29"+1,"#x30"+1,"#x31"+1}
                   1891: 
                   1892: /* Define additional names for use in asm clobbers and asm declarations.
                   1893: 
                   1894:    We define the fake Condition Code register as an alias for reg 0 (which
                   1895:    is our `condition code' register), so that condition codes can easily
                   1896:    be clobbered by an asm.  The carry bit in the PSR is now used.  */
                   1897: 
                   1898: #define ADDITIONAL_REGISTER_NAMES      {"psr", 0, "cc", 0}
                   1899: 
                   1900: /* How to renumber registers for dbx and gdb.  */
                   1901: #define DBX_REGISTER_NUMBER(REGNO) (REGNO)
                   1902: 
                   1903: /* Tell when to declare ASM names.  Override svr4.h to provide this hook.  */
                   1904: #undef DECLARE_ASM_NAME
                   1905: #define DECLARE_ASM_NAME TARGET_SVR4
                   1906: 
                   1907: /* Write the extra assembler code needed to declare a function properly.  */
                   1908: #undef ASM_DECLARE_FUNCTION_NAME
                   1909: #define ASM_DECLARE_FUNCTION_NAME(FILE, NAME, DECL)                    \
                   1910:   do {                                                                 \
                   1911:     if (DECLARE_ASM_NAME)                                              \
                   1912:       {                                                                        \
                   1913:        fprintf (FILE, "\t%s\t ", TYPE_ASM_OP);                         \
                   1914:        assemble_name (FILE, NAME);                                     \
                   1915:        putc (',', FILE);                                               \
                   1916:        fprintf (FILE, TYPE_OPERAND_FMT, "function");                   \
                   1917:        putc ('\n', FILE);                                              \
                   1918:       }                                                                        \
                   1919:     ASM_OUTPUT_LABEL(FILE, NAME);                                      \
                   1920:   } while (0)
                   1921: 
                   1922: /* Write the extra assembler code needed to declare an object properly.  */
                   1923: #undef ASM_DECLARE_OBJECT_NAME
                   1924: #define ASM_DECLARE_OBJECT_NAME(FILE, NAME, DECL)                          \
                   1925:   do {                                                                     \
                   1926:     if (DECLARE_ASM_NAME)                                                  \
                   1927:       {                                                                            \
                   1928:        fprintf (FILE, "\t%s\t ", TYPE_ASM_OP);                             \
                   1929:        assemble_name (FILE, NAME);                                         \
                   1930:        putc (',', FILE);                                                   \
                   1931:        fprintf (FILE, TYPE_OPERAND_FMT, "object");                         \
                   1932:        putc ('\n', FILE);                                                  \
                   1933:         size_directive_output = 0;                                         \
                   1934:        if (!flag_inhibit_size_directive && DECL_SIZE (DECL))               \
                   1935:          {                                                                 \
                   1936:             size_directive_output = 1;                                     \
                   1937:            fprintf (FILE, "\t%s\t ", SIZE_ASM_OP);                         \
                   1938:            assemble_name (FILE, NAME);                                     \
                   1939:            fprintf (FILE, ",%d\n",  int_size_in_bytes (TREE_TYPE (DECL))); \
                   1940:          }                                                                 \
                   1941:       }                                                                            \
                   1942:     ASM_OUTPUT_LABEL(FILE, NAME);                                          \
                   1943:   } while (0)
                   1944: 
                   1945: /* Output the size directive for a decl in rest_of_decl_compilation
                   1946:    in the case where we did not do so before the initializer.
                   1947:    Once we find the error_mark_node, we know that the value of
                   1948:    size_directive_output was set
                   1949:    by ASM_DECLARE_OBJECT_NAME when it was run for the same decl.  */
                   1950: 
                   1951: #undef ASM_FINISH_DECLARE_OBJECT
                   1952: #define ASM_FINISH_DECLARE_OBJECT(FILE, DECL, TOP_LEVEL, AT_END)        \
                   1953: do {                                                                    \
                   1954:      char *name = XSTR (XEXP (DECL_RTL (DECL), 0), 0);                  \
                   1955:      if (!flag_inhibit_size_directive && DECL_SIZE (DECL)               \
                   1956:         && DECLARE_ASM_NAME                                             \
                   1957:          && ! AT_END && TOP_LEVEL                                       \
                   1958:         && DECL_INITIAL (DECL) == error_mark_node                       \
                   1959:         && !size_directive_output)                                      \
                   1960:        {                                                                \
                   1961:         fprintf (FILE, "\t%s\t ", SIZE_ASM_OP);                         \
                   1962:         assemble_name (FILE, name);                                     \
                   1963:         fprintf (FILE, ",%d\n",  int_size_in_bytes (TREE_TYPE (DECL))); \
                   1964:        }                                                                \
                   1965:    } while (0)
                   1966: 
                   1967: /* This is how to declare the size of a function.  */
                   1968: #undef ASM_DECLARE_FUNCTION_SIZE
                   1969: #define ASM_DECLARE_FUNCTION_SIZE(FILE, FNAME, DECL)                   \
                   1970:   do {                                                                 \
                   1971:     if (DECLARE_ASM_NAME)                                              \
                   1972:       {                                                                        \
                   1973:        if (!flag_inhibit_size_directive)                               \
                   1974:          {                                                             \
                   1975:            char label[256];                                            \
                   1976:            static int labelno = 0;                                     \
                   1977:            labelno++;                                                  \
                   1978:            ASM_GENERATE_INTERNAL_LABEL (label, "Lfe", labelno);        \
                   1979:            ASM_OUTPUT_INTERNAL_LABEL (FILE, "Lfe", labelno);           \
                   1980:            fprintf (FILE, "\t%s\t ", SIZE_ASM_OP);                     \
                   1981:            assemble_name (FILE, (FNAME));                              \
                   1982:            fprintf (FILE, ",%s-", &label[1]);                          \
                   1983:            assemble_name (FILE, (FNAME));                              \
                   1984:            putc ('\n', FILE);                                          \
                   1985:          }                                                             \
                   1986:       }                                                                        \
                   1987:   } while (0)
                   1988: 
                   1989: /* This is how to output the definition of a user-level label named NAME,
                   1990:    such as the label on a static function or variable NAME.  */
                   1991: #define ASM_OUTPUT_LABEL(FILE,NAME)    \
                   1992:   do { assemble_name (FILE, NAME); fputs (":\n", FILE); } while (0)
                   1993: 
                   1994: /* This is how to output a command to make the user-level label named NAME
                   1995:    defined for reference from other files.  */
                   1996: #define ASM_GLOBALIZE_LABEL(FILE,NAME)                 \
                   1997:   do {                                                 \
                   1998:     fprintf (FILE, "\t%s\t ", GLOBAL_ASM_OP);          \
                   1999:     assemble_name (FILE, NAME);                                \
                   2000:     putc ('\n', FILE);                                 \
                   2001:   } while (0)
                   2002: 
                   2003: /* This is how to output a reference to a user-level label named NAME.
                   2004:    Override svr[34].h.  */
                   2005: #undef ASM_OUTPUT_LABELREF
                   2006: #define ASM_OUTPUT_LABELREF(FILE,NAME)                 \
                   2007:   {                                                    \
                   2008:     if (! TARGET_NO_UNDERSCORES && ! VERSION_0300_SYNTAX) \
                   2009:       fputc ('_', FILE);                               \
                   2010:     fputs (NAME, FILE);                                        \
                   2011:   }
                   2012: 
                   2013: /* This is how to output an internal numbered label where
                   2014:    PREFIX is the class of label and NUM is the number within the class.
                   2015:    For V.4, labels use `.' rather than `@'.  */
                   2016: 
                   2017: #undef ASM_OUTPUT_INTERNAL_LABEL
                   2018: #ifdef AS_BUG_DOT_LABELS /* The assembler requires a declaration of local.  */
                   2019: #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM)                     \
                   2020:   fprintf (FILE, VERSION_0300_SYNTAX ? ".%s%d:\n\t%s\t .%s%d\n" : "@%s%d:\n", \
                   2021:           PREFIX, NUM, INTERNAL_ASM_OP, PREFIX, NUM)
                   2022: #else
                   2023: #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM)                     \
                   2024:   fprintf (FILE, VERSION_0300_SYNTAX ? ".%s%d:\n" : "@%s%d:\n", PREFIX, NUM)
                   2025: #endif /* AS_BUG_DOT_LABELS */
                   2026: 
                   2027: /* This is how to store into the string LABEL
                   2028:    the symbol_ref name of an internal numbered label where
                   2029:    PREFIX is the class of label and NUM is the number within the class.
                   2030:    This is suitable for output with `assemble_name'.  This must agree
                   2031:    with ASM_OUTPUT_INTERNAL_LABEL above, except for being prefixed
                   2032:    with an `*'.  */
                   2033: 
                   2034: #undef ASM_GENERATE_INTERNAL_LABEL
                   2035: #define ASM_GENERATE_INTERNAL_LABEL(LABEL,PREFIX,NUM)                  \
                   2036:   sprintf (LABEL, VERSION_0300_SYNTAX ? "*.%s%d" : "*@%s%d", PREFIX, NUM)
                   2037: 
                   2038: /* Internal macro to get a single precision floating point value into
                   2039:    an int, so we can print it's value in hex.  */
                   2040: #define FLOAT_TO_INT_INTERNAL( FVALUE, IVALUE )                                \
                   2041:   { union {                                                            \
                   2042:       REAL_VALUE_TYPE d;                                               \
                   2043:       struct {                                                         \
                   2044:        unsigned sign      :  1;                                        \
                   2045:        unsigned exponent1 :  1;                                        \
                   2046:        unsigned exponent2 :  3;                                        \
                   2047:        unsigned exponent3 :  7;                                        \
                   2048:        unsigned mantissa1 : 20;                                        \
                   2049:        unsigned mantissa2 :  3;                                        \
                   2050:        unsigned mantissa3 : 29;                                        \
                   2051:       } s;                                                             \
                   2052:     } _u;                                                              \
                   2053:                                                                        \
                   2054:     union {                                                            \
                   2055:       int i;                                                           \
                   2056:       struct {                                                         \
                   2057:         unsigned sign      :  1;                                       \
                   2058:        unsigned exponent1 :  1;                                        \
                   2059:        unsigned exponent3 :  7;                                        \
                   2060:         unsigned mantissa1 : 20;                                       \
                   2061:         unsigned mantissa2 :  3;                                       \
                   2062:       } s;                                                             \
                   2063:     } _u2;                                                             \
                   2064:                                                                        \
                   2065:     _u.d = REAL_VALUE_TRUNCATE (SFmode, FVALUE);                       \
                   2066:     _u2.s.sign = _u.s.sign;                                            \
                   2067:     _u2.s.exponent1 = _u.s.exponent1;                                  \
                   2068:     _u2.s.exponent3 = _u.s.exponent3;                                  \
                   2069:     _u2.s.mantissa1 = _u.s.mantissa1;                                  \
                   2070:     _u2.s.mantissa2 = _u.s.mantissa2;                                  \
                   2071:     IVALUE = _u2.i;                                                    \
                   2072:   }
                   2073: 
                   2074: /* This is how to output an assembler line defining a `double' constant.
                   2075:    Use "word" pseudos to avoid printing NaNs, infinity, etc.  */
                   2076: #define ASM_OUTPUT_DOUBLE(FILE,VALUE)                                  \
                   2077:   do {                                                                 \
                   2078:     union { REAL_VALUE_TYPE d; long l[2]; } x;                         \
                   2079:     x.d = (VALUE);                                                     \
                   2080:     fprintf (FILE, "\t%s\t 0x%.8x, 0x%.8x\n", INT_ASM_OP,                      \
                   2081:             x.l[0], x.l[1]);                                           \
                   2082:   } while (0)
                   2083: 
                   2084: /* This is how to output an assembler line defining a `float' constant.  */
                   2085: #define ASM_OUTPUT_FLOAT(FILE,VALUE)                                   \
                   2086:   do {                                                                 \
                   2087:     int i;                                                             \
                   2088:     FLOAT_TO_INT_INTERNAL (VALUE, i);                                  \
                   2089:     fprintf (FILE, "\t%s\t 0x%.8x\n", INT_ASM_OP, i);                  \
                   2090:   } while (0)
                   2091: 
                   2092: /* Likewise for `int', `short', and `char' constants.  */
                   2093: #define ASM_OUTPUT_INT(FILE,VALUE)                                     \
                   2094: ( fprintf (FILE, "\t%s\t ", INT_ASM_OP),                               \
                   2095:   output_addr_const (FILE, (VALUE)),                                   \
                   2096:   fprintf (FILE, "\n"))
                   2097: 
                   2098: #define ASM_OUTPUT_SHORT(FILE,VALUE)                                   \
                   2099: ( fprintf (FILE, "\t%s\t ", SHORT_ASM_OP),                             \
                   2100:   output_addr_const (FILE, (VALUE)),                                   \
                   2101:   fprintf (FILE, "\n"))
                   2102: 
                   2103: #define ASM_OUTPUT_CHAR(FILE,VALUE)                                    \
                   2104: ( fprintf (FILE, "\t%s\t ", CHAR_ASM_OP),                              \
                   2105:   output_addr_const (FILE, (VALUE)),                                   \
                   2106:   fprintf (FILE, "\n"))
                   2107: 
                   2108: /* This is how to output an assembler line for a numeric constant byte.  */
                   2109: #define ASM_OUTPUT_BYTE(FILE,VALUE)  \
                   2110:   fprintf (FILE, "\t%s\t 0x%x\n", CHAR_ASM_OP, (VALUE))
                   2111: 
                   2112: /* The single-byte pseudo-op is the default.  Override svr[34].h.  */
                   2113: #undef ASM_BYTE_OP
                   2114: #define ASM_BYTE_OP "byte"
                   2115: #undef ASM_OUTPUT_ASCII
                   2116: #define ASM_OUTPUT_ASCII(FILE, P, SIZE)  \
                   2117:   output_ascii (FILE, ASCII_DATA_ASM_OP, 48, P, SIZE)
                   2118: 
                   2119: /* Override svr4.h.  Change to the readonly data section for a table of
                   2120:    addresses.  final_scan_insn changes back to the text section.  */
                   2121: #undef ASM_OUTPUT_CASE_LABEL
                   2122: #define ASM_OUTPUT_CASE_LABEL(FILE, PREFIX, NUM, TABLE)                        \
                   2123:   do {                                                                 \
                   2124:     if (! CASE_VECTOR_INSNS)                                           \
                   2125:       {                                                                        \
                   2126:         readonly_data_section ();                                      \
                   2127:         ASM_OUTPUT_ALIGN (FILE, 2);                                    \
                   2128:       }                                                                        \
                   2129:     ASM_OUTPUT_INTERNAL_LABEL (FILE, PREFIX, NUM);                     \
                   2130:   } while (0)
                   2131: 
                   2132: /* Epilogue for case labels.  This jump instruction is called by casesi
                   2133:    to transfer to the appropriate branch instruction within the table.
                   2134:    The label `@L<n>e' is coined to mark the end of the table.  */
                   2135: #define ASM_OUTPUT_CASE_END(FILE, NUM, TABLE)                          \
                   2136:   do {                                                                 \
                   2137:     if (CASE_VECTOR_INSNS)                                             \
                   2138:       {                                                                        \
                   2139:        char label[256];                                                \
                   2140:        ASM_GENERATE_INTERNAL_LABEL (label, "L", NUM);                  \
                   2141:        fprintf (FILE, "%se:\n", &label[1]);                            \
                   2142:        if (! flag_delayed_branch)                                      \
                   2143:          fprintf (FILE, "\tlda\t %s,%s[%s]\n", reg_names[1],           \
                   2144:                   reg_names[1], reg_names[m88k_case_index]);           \
                   2145:        fprintf (FILE, "\tjmp\t %s\n", reg_names[1]);                   \
                   2146:       }                                                                        \
                   2147:   } while (0)
                   2148: 
                   2149: /* This is how to output an element of a case-vector that is absolute.  */
                   2150: #define ASM_OUTPUT_ADDR_VEC_ELT(FILE, VALUE)                           \
                   2151:   do {                                                                 \
                   2152:     char buffer[256];                                                  \
                   2153:     ASM_GENERATE_INTERNAL_LABEL (buffer, "L", VALUE);                  \
                   2154:     fprintf (FILE, CASE_VECTOR_INSNS ? "\tbr\t %s\n" : "\tword\t %s\n",        \
                   2155:             &buffer[1]);                                               \
                   2156:   } while (0)
                   2157: 
                   2158: /* This is how to output an element of a case-vector that is relative.  */
                   2159: #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL) \
                   2160:   ASM_OUTPUT_ADDR_VEC_ELT (FILE, VALUE)
                   2161: 
                   2162: /* This is how to output an assembler line
                   2163:    that says to advance the location counter
                   2164:    to a multiple of 2**LOG bytes.  */
                   2165: #define ASM_OUTPUT_ALIGN(FILE,LOG)     \
                   2166:   if ((LOG) != 0)                      \
                   2167:     fprintf (FILE, "\t%s\t %d\n", ALIGN_ASM_OP, 1<<(LOG))
                   2168: 
                   2169: /* On the m88100, align the text address to half a cache boundary when it
                   2170:    can only be reached by jumping.  Pack code tightly when compiling
                   2171:    crtstuff.c.  */
                   2172: #define ASM_OUTPUT_ALIGN_CODE(FILE) \
                   2173:   ASM_OUTPUT_ALIGN (FILE, \
                   2174:                    (TARGET_88100 && !flag_inhibit_size_directive ? 3 : 2))
                   2175: 
                   2176: /* Override svr[34].h.  */
                   2177: #undef ASM_OUTPUT_SKIP
                   2178: #define ASM_OUTPUT_SKIP(FILE,SIZE)  \
                   2179:   fprintf (FILE, "\t%s\t %u\n", SKIP_ASM_OP, (SIZE))
                   2180: 
                   2181: /* Override svr4.h.  */
                   2182: #undef ASM_OUTPUT_EXTERNAL_LIBCALL
                   2183: 
                   2184: /* This says how to output an assembler line to define a global common
                   2185:    symbol.  Size can be zero for the unusual case of a `struct { int : 0; }'.
                   2186:    Override svr[34].h.  */
                   2187: #undef ASM_OUTPUT_COMMON
                   2188: #undef ASM_OUTPUT_ALIGNED_COMMON
                   2189: #define ASM_OUTPUT_COMMON(FILE, NAME, SIZE, ROUNDED)   \
                   2190: ( fprintf ((FILE), "\t%s\t ",                          \
                   2191:           ((SIZE) ? (SIZE) : 1) <= m88k_gp_threshold ? SCOMM_ASM_OP : COMMON_ASM_OP), \
                   2192:   assemble_name ((FILE), (NAME)),                      \
                   2193:   fprintf ((FILE), ",%u\n", (SIZE) ? (SIZE) : 1))
                   2194: 
                   2195: /* This says how to output an assembler line to define a local common
                   2196:    symbol.  Override svr[34].h.  */
                   2197: #undef ASM_OUTPUT_LOCAL
                   2198: #undef ASM_OUTPUT_ALIGNED_LOCAL
                   2199: #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE, ROUNDED)    \
                   2200: ( fprintf ((FILE), "\t%s\t ",                          \
                   2201:           ((SIZE) ? (SIZE) : 1) <= m88k_gp_threshold ? SBSS_ASM_OP : BSS_ASM_OP), \
                   2202:   assemble_name ((FILE), (NAME)),                      \
                   2203:   fprintf ((FILE), ",%u,%d\n", (SIZE) ? (SIZE) : 1, (SIZE) <= 4 ? 4 : 8))
                   2204: 
                   2205: /* Store in OUTPUT a string (made with alloca) containing
                   2206:    an assembler-name for a local static variable named NAME.
                   2207:    LABELNO is an integer which is different for each call.  */
                   2208: #define ASM_FORMAT_PRIVATE_NAME(OUTPUT, NAME, LABELNO) \
                   2209: ( (OUTPUT) = (char *) alloca (strlen ((NAME)) + 10),   \
                   2210:   sprintf ((OUTPUT), "%s.%d", (NAME), (LABELNO)))
                   2211: 
                   2212: /* This is how to output an insn to push a register on the stack.
                   2213:    It need not be very fast code.  */
                   2214: #define ASM_OUTPUT_REG_PUSH(FILE,REGNO)  \
                   2215:   fprintf (FILE, "\tsubu\t %s,%s,%d\n\tst\t %s,%s,0\n",        \
                   2216:           reg_names[STACK_POINTER_REGNUM],             \
                   2217:           reg_names[STACK_POINTER_REGNUM],             \
                   2218:           (STACK_BOUNDARY / BITS_PER_UNIT),            \
                   2219:           reg_names[REGNO],                            \
                   2220:           reg_names[STACK_POINTER_REGNUM])
                   2221: 
                   2222: /* Length in instructions of the code output by ASM_OUTPUT_REG_PUSH.  */
                   2223: #define REG_PUSH_LENGTH 2
                   2224: 
                   2225: /* This is how to output an insn to pop a register from the stack.  */
                   2226: #define ASM_OUTPUT_REG_POP(FILE,REGNO)  \
                   2227:   fprintf (FILE, "\tld\t %s,%s,0\n\taddu\t %s,%s,%d\n",        \
                   2228:           reg_names[REGNO],                            \
                   2229:           reg_names[STACK_POINTER_REGNUM],             \
                   2230:           reg_names[STACK_POINTER_REGNUM],             \
                   2231:           reg_names[STACK_POINTER_REGNUM],             \
                   2232:           (STACK_BOUNDARY / BITS_PER_UNIT))
                   2233: 
                   2234: /* Length in instructions of the code output by ASM_OUTPUT_REG_POP.  */
                   2235: #define REG_POP_LENGTH 2
                   2236: 
                   2237: /* Define the parentheses used to group arithmetic operations
                   2238:    in assembler code.  */
                   2239: #define ASM_OPEN_PAREN "("
                   2240: #define ASM_CLOSE_PAREN ")"
                   2241: 
                   2242: /* Define results of standard character escape sequences.  */
                   2243: #define TARGET_BELL 007
                   2244: #define TARGET_BS 010
                   2245: #define TARGET_TAB 011
                   2246: #define TARGET_NEWLINE 012
                   2247: #define TARGET_VT 013
                   2248: #define TARGET_FF 014
                   2249: #define TARGET_CR 015
                   2250: 
                   2251: /* Macros to deal with OCS debug information */
                   2252: 
                   2253: #define OCS_START_PREFIX       "Ltb"
                   2254: #define OCS_END_PREFIX         "Lte"
                   2255: 
                   2256: #define PUT_OCS_FUNCTION_START(FILE) \
                   2257:   { ASM_OUTPUT_INTERNAL_LABEL (FILE, OCS_START_PREFIX, m88k_function_number); }
                   2258: 
                   2259: #define PUT_OCS_FUNCTION_END(FILE) \
                   2260:   { ASM_OUTPUT_INTERNAL_LABEL (FILE, OCS_END_PREFIX, m88k_function_number); }
                   2261: 
                   2262: /* Macros for debug information */
                   2263: #define DEBUGGER_AUTO_OFFSET(X) \
                   2264:   (m88k_debugger_offset (X, 0) \
                   2265:    + (TARGET_OCS_FRAME_POSITION ? 0 : m88k_stack_size - m88k_fp_offset))
                   2266: 
                   2267: #define DEBUGGER_ARG_OFFSET(OFFSET, X) \
                   2268:   (m88k_debugger_offset (X, OFFSET) \
                   2269:    + (TARGET_OCS_FRAME_POSITION ? 0 : m88k_stack_size - m88k_fp_offset))
                   2270: 
                   2271: /* Macros to deal with SDB debug information */
                   2272: #ifdef SDB_DEBUGGING_INFO
                   2273: 
                   2274: /* Output structure tag names even when it causes a forward reference. */
                   2275: #define SDB_ALLOW_FORWARD_REFERENCES
                   2276: 
                   2277: /* Print out extra debug information in the assembler file */
                   2278: #define PUT_SDB_SCL(a)                                         \
                   2279:   do {                                                         \
                   2280:     register int s = (a);                                      \
                   2281:     register char *scl;                                                \
                   2282:     switch (s)                                                 \
                   2283:       {                                                                \
                   2284:       case C_EFCN:     scl = "end of function";        break;  \
                   2285:       case C_NULL:     scl = "NULL storage class";     break;  \
                   2286:       case C_AUTO:     scl = "automatic";              break;  \
                   2287:       case C_EXT:      scl = "external";               break;  \
                   2288:       case C_STAT:     scl = "static";                 break;  \
                   2289:       case C_REG:      scl = "register";               break;  \
                   2290:       case C_EXTDEF:   scl = "external definition";    break;  \
                   2291:       case C_LABEL:    scl = "label";                  break;  \
                   2292:       case C_ULABEL:   scl = "undefined label";        break;  \
                   2293:       case C_MOS:      scl = "structure member";       break;  \
                   2294:       case C_ARG:      scl = "argument";               break;  \
                   2295:       case C_STRTAG:   scl = "structure tag";          break;  \
                   2296:       case C_MOU:      scl = "union member";           break;  \
                   2297:       case C_UNTAG:    scl = "union tag";              break;  \
                   2298:       case C_TPDEF:    scl = "typedef";                break;  \
                   2299:       case C_USTATIC:  scl = "uninitialized static";   break;  \
                   2300:       case C_ENTAG:    scl = "enumeration tag";        break;  \
                   2301:       case C_MOE:      scl = "member of enumeration";  break;  \
                   2302:       case C_REGPARM:  scl = "register parameter";     break;  \
                   2303:       case C_FIELD:    scl = "bit field";              break;  \
                   2304:       case C_BLOCK:    scl = "block start/end";        break;  \
                   2305:       case C_FCN:      scl = "function start/end";     break;  \
                   2306:       case C_EOS:      scl = "end of structure";       break;  \
                   2307:       case C_FILE:     scl = "filename";               break;  \
                   2308:       case C_LINE:     scl = "line";                   break;  \
                   2309:       case C_ALIAS:    scl = "duplicated tag";         break;  \
                   2310:       case C_HIDDEN:   scl = "hidden";                 break;  \
                   2311:       default:         scl = "unknown";                break;  \
                   2312:       }                                                                \
                   2313:                                                                \
                   2314:     fprintf(asm_out_file, "\tscl\t %d\t\t\t\t; %s\n", s, scl); \
                   2315:   } while (0)
                   2316: 
                   2317: #define PUT_SDB_TYPE(a)                                                \
                   2318:   do {                                                         \
                   2319:     register int t = (a);                                      \
                   2320:     static char buffer[100];                                   \
                   2321:     register char *p = buffer, *q;                             \
                   2322:     register int typ = t;                                      \
                   2323:     register int i,d;                                          \
                   2324:                                                                \
                   2325:     for (i = 0; i <= 5; i++)                                   \
                   2326:       {                                                                \
                   2327:        switch ((typ >> ((i*N_TSHIFT) + N_BTSHFT)) & 03)        \
                   2328:          {                                                     \
                   2329:          case DT_PTR:                                          \
                   2330:            strcpy (p, "ptr to ");                              \
                   2331:            p += sizeof("ptr to");                              \
                   2332:            break;                                              \
                   2333:                                                                \
                   2334:          case DT_ARY:                                          \
                   2335:            strcpy (p, "array of ");                            \
                   2336:            p += sizeof("array of");                            \
                   2337:            break;                                              \
                   2338:                                                                \
                   2339:          case DT_FCN:                                          \
                   2340:            strcpy (p, "func ret ");                            \
                   2341:            p += sizeof("func ret");                            \
                   2342:            break;                                              \
                   2343:          }                                                     \
                   2344:       }                                                                \
                   2345:                                                                \
                   2346:   switch (typ & N_BTMASK)                                      \
                   2347:     {                                                          \
                   2348:     case T_NULL:       q = "<no type>";        break;          \
                   2349:     case T_CHAR:       q = "char";             break;          \
                   2350:     case T_SHORT:      q = "short";            break;          \
                   2351:     case T_INT:                q = "int";              break;          \
                   2352:     case T_LONG:       q = "long";             break;          \
                   2353:     case T_FLOAT:      q = "float";            break;          \
                   2354:     case T_DOUBLE:     q = "double";           break;          \
                   2355:     case T_STRUCT:     q = "struct";           break;          \
                   2356:     case T_UNION:      q = "union";            break;          \
                   2357:     case T_ENUM:       q = "enum";             break;          \
                   2358:     case T_MOE:                q = "enum member";      break;          \
                   2359:     case T_UCHAR:      q = "unsigned char";    break;          \
                   2360:     case T_USHORT:     q = "unsigned short";   break;          \
                   2361:     case T_UINT:       q = "unsigned int";     break;          \
                   2362:     case T_ULONG:      q = "unsigned long";    break;          \
                   2363:     default:           q = "void";             break;          \
                   2364:     }                                                          \
                   2365:                                                                \
                   2366:     strcpy (p, q);                                             \
                   2367:     fprintf(asm_out_file, "\ttype\t %d\t\t\t\t; %s\n",         \
                   2368:            t, buffer);                                         \
                   2369:   } while (0)
                   2370: 
                   2371: #define PUT_SDB_INT_VAL(a) \
                   2372:   fprintf (asm_out_file, "\tval\t %d\n", (a))
                   2373: 
                   2374: #define PUT_SDB_VAL(a)                                 \
                   2375: ( fprintf (asm_out_file, "\tval\t "),                  \
                   2376:   output_addr_const (asm_out_file, (a)),               \
                   2377:   fputc ('\n', asm_out_file))
                   2378: 
                   2379: #define PUT_SDB_DEF(a)                                         \
                   2380:   do { fprintf (asm_out_file, "\tsdef\t ");                    \
                   2381:     ASM_OUTPUT_LABELREF (asm_out_file, a);                     \
                   2382:     fputc ('\n', asm_out_file);                                        \
                   2383:   } while (0)
                   2384: 
                   2385: #define PUT_SDB_PLAIN_DEF(a) \
                   2386:   fprintf(asm_out_file,"\tsdef\t .%s\n", a)
                   2387: 
                   2388: /* Simply and endef now.  */
                   2389: #define PUT_SDB_ENDEF \
                   2390:   fputs("\tendef\n\n", asm_out_file)
                   2391: 
                   2392: #define PUT_SDB_SIZE(a) \
                   2393:   fprintf (asm_out_file, "\tsize\t %d\n", (a))
                   2394: 
                   2395: /* Max dimensions to store for debug information (limited by COFF).  */
                   2396: #define SDB_MAX_DIM 6
                   2397: 
                   2398: /* New method for dim operations.  */
                   2399: #define PUT_SDB_START_DIM \
                   2400:   fputs("\tdim\t ", asm_out_file)
                   2401: 
                   2402: /* How to end the DIM sequence.  */
                   2403: #define PUT_SDB_LAST_DIM(a) \
                   2404:   fprintf(asm_out_file, "%d\n", a)
                   2405: 
                   2406: #define PUT_SDB_TAG(a)                                         \
                   2407:   do {                                                         \
                   2408:     fprintf (asm_out_file, "\ttag\t ");                                \
                   2409:     ASM_OUTPUT_LABELREF (asm_out_file, a);                     \
                   2410:     fputc ('\n', asm_out_file);                                        \
                   2411:   } while( 0 )
                   2412: 
                   2413: #define PUT_SDB_BLOCK_OR_FUNCTION(NAME, SCL, LINE)             \
                   2414:   do {                                                         \
                   2415:     fprintf (asm_out_file, "\n\tsdef\t %s\n\tval\t .\n",       \
                   2416:             NAME);                                             \
                   2417:     PUT_SDB_SCL( SCL );                                                \
                   2418:     fprintf (asm_out_file, "\tline\t %d\n\tendef\n\n",         \
                   2419:             (LINE));                                           \
                   2420:   } while (0)
                   2421: 
                   2422: #define PUT_SDB_BLOCK_START(LINE) \
                   2423:   PUT_SDB_BLOCK_OR_FUNCTION (".bb", C_BLOCK, (LINE))
                   2424: 
                   2425: #define PUT_SDB_BLOCK_END(LINE) \
                   2426:   PUT_SDB_BLOCK_OR_FUNCTION (".eb", C_BLOCK, (LINE))
                   2427: 
                   2428: #define PUT_SDB_FUNCTION_START(LINE)                           \
                   2429:   do {                                                         \
                   2430:     fprintf (asm_out_file, "\tln\t 1\n");                      \
                   2431:     PUT_SDB_BLOCK_OR_FUNCTION (".bf", C_FCN, (LINE));          \
                   2432:   } while (0)
                   2433: 
                   2434: #define PUT_SDB_FUNCTION_END(LINE)                             \
                   2435:   do {                                                         \
                   2436:     PUT_SDB_BLOCK_OR_FUNCTION (".ef", C_FCN, (LINE));          \
                   2437:   } while (0)
                   2438: 
                   2439: #define PUT_SDB_EPILOGUE_END(NAME)                             \
                   2440:   do {                                                         \
                   2441:     text_section ();                                           \
                   2442:     fprintf (asm_out_file, "\n\tsdef\t ");                     \
                   2443:     ASM_OUTPUT_LABELREF(asm_out_file, (NAME));                 \
                   2444:     fputc('\n', asm_out_file);                                 \
                   2445:     PUT_SDB_SCL( C_EFCN );                                     \
                   2446:     fprintf (asm_out_file, "\tendef\n\n");                     \
                   2447:   } while (0)
                   2448: 
                   2449: #define SDB_GENERATE_FAKE(BUFFER, NUMBER) \
                   2450:   sprintf ((BUFFER), ".%dfake", (NUMBER));
                   2451: 
                   2452: #endif /* SDB_DEBUGGING_INFO */
                   2453: 
                   2454: /* Support const and tdesc sections.  Generally, a const section will
                   2455:    be distinct from the text section whenever we do V.4-like things
                   2456:    and so follows DECLARE_ASM_NAME.  Note that strings go in text
                   2457:    rather than const.  Override svr[34].h.  */
                   2458: 
                   2459: #undef USE_CONST_SECTION
                   2460: #undef EXTRA_SECTIONS
                   2461: 
                   2462: #define USE_CONST_SECTION DECLARE_ASM_NAME
                   2463: 
                   2464: #if defined(USING_SVR4_H)
                   2465: 
                   2466: #define EXTRA_SECTIONS in_const, in_tdesc, in_sdata, in_ctors, in_dtors
                   2467: #define INIT_SECTION_FUNCTION
                   2468: #define FINI_SECTION_FUNCTION
                   2469: 
                   2470: #else
                   2471: #if defined(USING_SVR3_H)
                   2472: 
                   2473: #define EXTRA_SECTIONS in_const, in_tdesc, in_sdata, in_ctors, in_dtors, \
                   2474:                       in_init, in_fini
                   2475: 
                   2476: #else /* m88kluna or other not based on svr[34].h.  */
                   2477: 
                   2478: #undef INIT_SECTION_ASM_OP
                   2479: #define EXTRA_SECTIONS in_const, in_tdesc, in_sdata
                   2480: #define CONST_SECTION_FUNCTION                                         \
                   2481: void                                                                   \
                   2482: const_section ()                                                       \
                   2483: {                                                                      \
                   2484:   text_section();                                                      \
                   2485: }
                   2486: #define CTORS_SECTION_FUNCTION
                   2487: #define DTORS_SECTION_FUNCTION
                   2488: #define INIT_SECTION_FUNCTION
                   2489: #define FINI_SECTION_FUNCTION
                   2490: 
                   2491: #endif /* USING_SVR3_H */
                   2492: #endif /* USING_SVR4_H */
                   2493: 
                   2494: #undef EXTRA_SECTION_FUNCTIONS
                   2495: #define EXTRA_SECTION_FUNCTIONS                                                \
                   2496:   CONST_SECTION_FUNCTION                                               \
                   2497:                                                                        \
                   2498: void                                                                   \
                   2499: tdesc_section ()                                                       \
                   2500: {                                                                      \
                   2501:   if (in_section != in_tdesc)                                          \
                   2502:     {                                                                  \
                   2503:       fprintf (asm_out_file, "%s\n", TDESC_SECTION_ASM_OP);            \
                   2504:       in_section = in_tdesc;                                           \
                   2505:     }                                                                  \
                   2506: }                                                                      \
                   2507:                                                                        \
                   2508: void                                                                   \
                   2509: sdata_section ()                                                       \
                   2510: {                                                                      \
                   2511:   if (in_section != in_sdata)                                          \
                   2512:     {                                                                  \
                   2513:       fprintf (asm_out_file, "%s\n", SDATA_SECTION_ASM_OP);            \
                   2514:       in_section = in_sdata;                                           \
                   2515:     }                                                                  \
                   2516: }                                                                      \
                   2517:                                                                        \
                   2518:   CTORS_SECTION_FUNCTION                                               \
                   2519:   DTORS_SECTION_FUNCTION                                               \
                   2520:   INIT_SECTION_FUNCTION                                                        \
                   2521:   FINI_SECTION_FUNCTION
                   2522: 
                   2523: /* A C statement or statements to switch to the appropriate
                   2524:    section for output of DECL.  DECL is either a `VAR_DECL' node
                   2525:    or a constant of some sort.  RELOC indicates whether forming
                   2526:    the initial value of DECL requires link-time relocations.
                   2527: 
                   2528:    For strings, the section is selected before the segment info is encoded.  */
                   2529: #undef SELECT_SECTION
                   2530: #define SELECT_SECTION(DECL,RELOC)                                     \
                   2531: {                                                                      \
                   2532:   if (TREE_CODE (DECL) == STRING_CST)                                  \
                   2533:     {                                                                  \
                   2534:       if (! flag_writable_strings)                                     \
                   2535:        const_section ();                                               \
                   2536:       else if (m88k_gp_threshold > 0                                   \
                   2537:               && TREE_STRING_LENGTH (DECL) <= m88k_gp_threshold)       \
                   2538:        sdata_section ();                                               \
                   2539:       else                                                             \
                   2540:        data_section ();                                                \
                   2541:     }                                                                  \
                   2542:   else if (TREE_CODE (DECL) == VAR_DECL)                               \
                   2543:     {                                                                  \
                   2544:       if (SYMBOL_REF_FLAG (XEXP (DECL_RTL (DECL), 0)))                 \
                   2545:        sdata_section ();                                               \
                   2546:       else if ((flag_pic && RELOC)                                     \
                   2547:          || !TREE_READONLY (DECL) || TREE_SIDE_EFFECTS (DECL))         \
                   2548:        data_section ();                                                \
                   2549:       else                                                             \
                   2550:        const_section ();                                               \
                   2551:     }                                                                  \
                   2552:   else                                                                 \
                   2553:     const_section ();                                                  \
                   2554: }
                   2555: 
                   2556: /* Jump tables consist of branch instructions and should be output in
                   2557:    the text section.  When we use a table of addresses, we explicitly
                   2558:    change to the readonly data section.  */
                   2559: #define JUMP_TABLES_IN_TEXT_SECTION 1
                   2560: 
                   2561: /* Define this macro if references to a symbol must be treated differently
                   2562:    depending on something about the variable or function named by the
                   2563:    symbol (such as what section it is in).
                   2564: 
                   2565:    The macro definition, if any, is executed immediately after the rtl for
                   2566:    DECL has been created and stored in `DECL_RTL (DECL)'.  The value of the
                   2567:    rtl will be a `mem' whose address is a `symbol_ref'.
                   2568: 
                   2569:    For the m88k, determine if the item should go in the global pool.  */
                   2570: #define ENCODE_SECTION_INFO(DECL)                                      \
                   2571:   do {                                                                 \
                   2572:     if (m88k_gp_threshold > 0)                                         \
                   2573:       if (TREE_CODE (DECL) == VAR_DECL)                                        \
                   2574:        {                                                               \
                   2575:          if (!TREE_READONLY (DECL) || TREE_SIDE_EFFECTS (DECL))        \
                   2576:            {                                                           \
                   2577:              int size = int_size_in_bytes (TREE_TYPE (DECL));          \
                   2578:                                                                        \
                   2579:              if (size > 0 && size <= m88k_gp_threshold)                \
                   2580:                SYMBOL_REF_FLAG (XEXP (DECL_RTL (DECL), 0)) = 1;        \
                   2581:            }                                                           \
                   2582:        }                                                               \
                   2583:       else if (TREE_CODE (DECL) == STRING_CST                          \
                   2584:               && flag_writable_strings                                 \
                   2585:               && TREE_STRING_LENGTH (DECL) <= m88k_gp_threshold)       \
                   2586:        SYMBOL_REF_FLAG (XEXP (TREE_CST_RTL (DECL), 0)) = 1;            \
                   2587:   } while (0)
                   2588: 
                   2589: /* Print operand X (an rtx) in assembler syntax to file FILE.
                   2590:    CODE is a letter or dot (`z' in `%z0') or 0 if no letter was specified.
                   2591:    For `%' followed by punctuation, CODE is the punctuation and X is null.  */
                   2592: #define PRINT_OPERAND_PUNCT_VALID_P(c) \
                   2593:   ((c) == '#' || (c) == '.' || (c) == '!' || (c) == '*' || (c) == ';')
                   2594: 
                   2595: #define PRINT_OPERAND(FILE, X, CODE) print_operand (FILE, X, CODE)
                   2596: 
                   2597: /* Print a memory address as an operand to reference that memory location.  */
                   2598: #define PRINT_OPERAND_ADDRESS(FILE, ADDR) print_operand_address (FILE, ADDR)

unix.superglobalmegacorp.com

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