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

1.1       root        1: /* Definitions of target machine for GNU compiler.  Vax version.
                      2:    Copyright (C) 1987, 1988, 1991, 1993 Free Software Foundation, Inc.
                      3: 
                      4: This file is part of GNU CC.
                      5: 
                      6: GNU CC is free software; you can redistribute it and/or modify
                      7: it under the terms of the GNU General Public License as published by
                      8: the Free Software Foundation; either version 2, or (at your option)
                      9: any later version.
                     10: 
                     11: GNU CC is distributed in the hope that it will be useful,
                     12: but WITHOUT ANY WARRANTY; without even the implied warranty of
                     13: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     14: GNU General Public License for more details.
                     15: 
                     16: You should have received a copy of the GNU General Public License
                     17: along with GNU CC; see the file COPYING.  If not, write to
                     18: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
                     19: 
                     20: 
                     21: /* Names to predefine in the preprocessor for this target machine.  */
                     22: 
                     23: #define CPP_PREDEFINES "-Dvax -Dunix -Asystem(unix) -Asystem(bsd) -Acpu(vax) -Amachine(vax)"
                     24: 
                     25: /* If using g-format floating point, alter math.h.  */
                     26: 
                     27: #define        CPP_SPEC "%{mg:-DGFLOAT}"
                     28: 
                     29: /* Choose proper libraries depending on float format.
                     30:    Note that there are no profiling libraries for g-format.
                     31:    Also use -lg for the sake of dbx.  */
                     32: 
                     33: #define LIB_SPEC "%{g:-lg}\
                     34:  %{mg:%{lm:-lmg} -lcg \
                     35:   %{p:%eprofiling not supported with -mg\n}\
                     36:   %{pg:%eprofiling not supported with -mg\n}}\
                     37:  %{!mg:%{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
                     38: 
                     39: /* Print subsidiary information on the compiler version in use.  */
                     40: 
                     41: #define TARGET_VERSION fprintf (stderr, " (vax)");
                     42: 
                     43: /* Run-time compilation parameters selecting different hardware subsets.  */
                     44: 
                     45: extern int target_flags;
                     46: 
                     47: /* Macros used in the machine description to test the flags.  */
                     48: 
                     49: /* Nonzero if compiling code that Unix assembler can assemble.  */
                     50: #define TARGET_UNIX_ASM (target_flags & 1)
                     51: 
                     52: /* Nonzero if compiling with VAX-11 "C" style structure alignment */
                     53: #define        TARGET_VAXC_ALIGNMENT (target_flags & 2)
                     54: 
                     55: /* Nonzero if compiling with `G'-format floating point */
                     56: #define TARGET_G_FLOAT (target_flags & 4)
                     57: 
                     58: /* Macro to define tables used to set the flags.
                     59:    This is a list in braces of pairs in braces,
                     60:    each pair being { "NAME", VALUE }
                     61:    where VALUE is the bits to set or minus the bits to clear.
                     62:    An empty string NAME is used to identify the default VALUE.  */
                     63: 
                     64: #define TARGET_SWITCHES  \
                     65:   { {"unix", 1},  \
                     66:     {"gnu", -1},  \
                     67:     {"vaxc-alignment", 2}, \
                     68:     {"g", 4}, \
                     69:     {"g-float", 4}, \
                     70:     {"d", -4}, \
                     71:     {"d-float", -4}, \
                     72:     { "", TARGET_DEFAULT}}
                     73: 
                     74: /* Default target_flags if no switches specified.  */
                     75: 
                     76: #ifndef TARGET_DEFAULT
                     77: #define TARGET_DEFAULT 1
                     78: #endif
                     79: 
                     80: /* Target machine storage layout */
                     81: 
                     82: /* Define for software floating point emulation of VAX format
                     83:    when cross compiling from a non-VAX host. */
                     84: /* #define REAL_ARITHMETIC */
                     85: 
                     86: /* Define this if most significant bit is lowest numbered
                     87:    in instructions that operate on numbered bit-fields.
                     88:    This is not true on the vax.  */
                     89: #define BITS_BIG_ENDIAN 0
                     90: 
                     91: /* Define this if most significant byte of a word is the lowest numbered.  */
                     92: /* That is not true on the vax.  */
                     93: #define BYTES_BIG_ENDIAN 0
                     94: 
                     95: /* Define this if most significant word of a multiword number is the lowest
                     96:    numbered.  */
                     97: /* This is not true on the vax.  */
                     98: #define WORDS_BIG_ENDIAN 0
                     99: 
                    100: /* Number of bits in an addressable storage unit */
                    101: #define BITS_PER_UNIT 8
                    102: 
                    103: /* Width in bits of a "word", which is the contents of a machine register.
                    104:    Note that this is not necessarily the width of data type `int';
                    105:    if using 16-bit ints on a 68000, this would still be 32.
                    106:    But on a machine with 16-bit registers, this would be 16.  */
                    107: #define BITS_PER_WORD 32
                    108: 
                    109: /* Width of a word, in units (bytes).  */
                    110: #define UNITS_PER_WORD 4
                    111: 
                    112: /* Width in bits of a pointer.
                    113:    See also the macro `Pmode' defined below.  */
                    114: #define POINTER_SIZE 32
                    115: 
                    116: /* Allocation boundary (in *bits*) for storing arguments in argument list.  */
                    117: #define PARM_BOUNDARY 32
                    118: 
                    119: /* Allocation boundary (in *bits*) for the code of a function.  */
                    120: #define FUNCTION_BOUNDARY 16
                    121: 
                    122: /* Alignment of field after `int : 0' in a structure.  */
                    123: #define EMPTY_FIELD_BOUNDARY (TARGET_VAXC_ALIGNMENT ? 8 : 32)
                    124: 
                    125: /* Every structure's size must be a multiple of this.  */
                    126: #define STRUCTURE_SIZE_BOUNDARY 8
                    127: 
                    128: /* A bitfield declared as `int' forces `int' alignment for the struct.  */
                    129: #define PCC_BITFIELD_TYPE_MATTERS (! TARGET_VAXC_ALIGNMENT)
                    130: 
                    131: /* No data type wants to be aligned rounder than this.  */
                    132: #define BIGGEST_ALIGNMENT 32
                    133: 
                    134: /* No structure field wants to be aligned rounder than this.  */
                    135: #define BIGGEST_FIELD_ALIGNMENT (TARGET_VAXC_ALIGNMENT ? 8 : 32)
                    136: 
                    137: /* Set this nonzero if move instructions will actually fail to work
                    138:    when given unaligned data.  */
                    139: #define STRICT_ALIGNMENT 0
                    140: 
                    141: /* Let's keep the stack somewhat aligned.  */
                    142: #define STACK_BOUNDARY 32
                    143: 
                    144: /* Standard register usage.  */
                    145: 
                    146: /* Number of actual hardware registers.
                    147:    The hardware registers are assigned numbers for the compiler
                    148:    from 0 to just below FIRST_PSEUDO_REGISTER.
                    149:    All registers that the compiler knows about must be given numbers,
                    150:    even those that are not normally considered general registers.  */
                    151: #define FIRST_PSEUDO_REGISTER 16
                    152: 
                    153: /* 1 for registers that have pervasive standard uses
                    154:    and are not available for the register allocator.
                    155:    On the vax, these are the AP, FP, SP and PC.  */
                    156: #define FIXED_REGISTERS {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1}
                    157: 
                    158: /* 1 for registers not available across function calls.
                    159:    These must include the FIXED_REGISTERS and also any
                    160:    registers that can be used without being saved.
                    161:    The latter must include the registers where values are returned
                    162:    and the register where structure-value addresses are passed.
                    163:    Aside from that, you can include as many other registers as you like.  */
                    164: #define CALL_USED_REGISTERS {1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1}
                    165: 
                    166: /* Return number of consecutive hard regs needed starting at reg REGNO
                    167:    to hold something of mode MODE.
                    168:    This is ordinarily the length in words of a value of mode MODE
                    169:    but can be less for certain modes in special long registers.
                    170:    On the vax, all registers are one word long.  */
                    171: #define HARD_REGNO_NREGS(REGNO, MODE)   \
                    172:  ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD)
                    173: 
                    174: /* Value is 1 if hard register REGNO can hold a value of machine-mode MODE.
                    175:    On the vax, all registers can hold all modes.  */
                    176: #define HARD_REGNO_MODE_OK(REGNO, MODE) 1
                    177: 
                    178: /* Value is 1 if it is a good idea to tie two pseudo registers
                    179:    when one has mode MODE1 and one has mode MODE2.
                    180:    If HARD_REGNO_MODE_OK could produce different values for MODE1 and MODE2,
                    181:    for any hard reg, then this must be 0 for correct output.  */
                    182: #define MODES_TIEABLE_P(MODE1, MODE2)  1
                    183: 
                    184: /* Specify the registers used for certain standard purposes.
                    185:    The values of these macros are register numbers.  */
                    186: 
                    187: /* Vax pc is overloaded on a register.  */
                    188: #define PC_REGNUM 15
                    189: 
                    190: /* Register to use for pushing function arguments.  */
                    191: #define STACK_POINTER_REGNUM 14
                    192: 
                    193: /* Base register for access to local variables of the function.  */
                    194: #define FRAME_POINTER_REGNUM 13
                    195: 
                    196: /* Value should be nonzero if functions must have frame pointers.
                    197:    Zero means the frame pointer need not be set up (and parms
                    198:    may be accessed via the stack pointer) in functions that seem suitable.
                    199:    This is computed in `reload', in reload1.c.  */
                    200: #define FRAME_POINTER_REQUIRED 1
                    201: 
                    202: /* Base register for access to arguments of the function.  */
                    203: #define ARG_POINTER_REGNUM 12
                    204: 
                    205: /* Register in which static-chain is passed to a function.  */
                    206: #define STATIC_CHAIN_REGNUM 0
                    207: 
                    208: /* Register in which address to store a structure value
                    209:    is passed to a function.  */
                    210: #define STRUCT_VALUE_REGNUM 1
                    211: 
                    212: /* Define the classes of registers for register constraints in the
                    213:    machine description.  Also define ranges of constants.
                    214: 
                    215:    One of the classes must always be named ALL_REGS and include all hard regs.
                    216:    If there is more than one class, another class must be named NO_REGS
                    217:    and contain no registers.
                    218: 
                    219:    The name GENERAL_REGS must be the name of a class (or an alias for
                    220:    another name such as ALL_REGS).  This is the class of registers
                    221:    that is allowed by "g" or "r" in a register constraint.
                    222:    Also, registers outside this class are allocated only when
                    223:    instructions express preferences for them.
                    224: 
                    225:    The classes must be numbered in nondecreasing order; that is,
                    226:    a larger-numbered class must never be contained completely
                    227:    in a smaller-numbered class.
                    228: 
                    229:    For any two classes, it is very desirable that there be another
                    230:    class that represents their union.  */
                    231:    
                    232: /* The vax has only one kind of registers, so NO_REGS and ALL_REGS
                    233:    are the only classes.  */
                    234: 
                    235: enum reg_class { NO_REGS, ALL_REGS, LIM_REG_CLASSES };
                    236: 
                    237: #define N_REG_CLASSES (int) LIM_REG_CLASSES
                    238: 
                    239: /* Since GENERAL_REGS is the same class as ALL_REGS,
                    240:    don't give it a different class number; just make it an alias.  */
                    241: 
                    242: #define GENERAL_REGS ALL_REGS
                    243: 
                    244: /* Give names of register classes as strings for dump file.   */
                    245: 
                    246: #define REG_CLASS_NAMES \
                    247:  {"NO_REGS", "ALL_REGS" }
                    248: 
                    249: /* Define which registers fit in which classes.
                    250:    This is an initializer for a vector of HARD_REG_SET
                    251:    of length N_REG_CLASSES.  */
                    252: 
                    253: #define REG_CLASS_CONTENTS {0, 0xffff}
                    254: 
                    255: /* The same information, inverted:
                    256:    Return the class number of the smallest class containing
                    257:    reg number REGNO.  This could be a conditional expression
                    258:    or could index an array.  */
                    259: 
                    260: #define REGNO_REG_CLASS(REGNO) ALL_REGS
                    261: 
                    262: /* The class value for index registers, and the one for base regs.  */
                    263: 
                    264: #define INDEX_REG_CLASS ALL_REGS
                    265: #define BASE_REG_CLASS ALL_REGS
                    266: 
                    267: /* Get reg_class from a letter such as appears in the machine description.  */
                    268: 
                    269: #define REG_CLASS_FROM_LETTER(C) NO_REGS
                    270: 
                    271: /* The letters I, J, K, L and M in a register constraint string
                    272:    can be used to stand for particular ranges of immediate operands.
                    273:    This macro defines what the ranges are.
                    274:    C is the letter, and VALUE is a constant value.
                    275:    Return 1 if VALUE is in the range specified by C.
                    276: 
                    277:    `I' is the constant zero.  */
                    278: 
                    279: #define CONST_OK_FOR_LETTER_P(VALUE, C) \
                    280:   ((C) == 'I' ? (VALUE) == 0           \
                    281:    : 0)
                    282: 
                    283: /* Similar, but for floating constants, and defining letters G and H.
                    284:    Here VALUE is the CONST_DOUBLE rtx itself. 
                    285: 
                    286:    `G' is a floating-point zero.  */
                    287: 
                    288: #define CONST_DOUBLE_OK_FOR_LETTER_P(VALUE, C) \
                    289:   ((C) == 'G' ? ((VALUE) == CONST0_RTX (DFmode)                \
                    290:                 || (VALUE) == CONST0_RTX (SFmode))     \
                    291:    : 0)
                    292: 
                    293: /* Optional extra constraints for this machine.
                    294: 
                    295:    For the VAX, `Q' means that OP is a MEM that does not have a mode-dependent
                    296:    address.  */
                    297: 
                    298: #define EXTRA_CONSTRAINT(OP, C) \
                    299:   ((C) == 'Q'                                                          \
                    300:    ? GET_CODE (OP) == MEM && ! mode_dependent_address_p (XEXP (OP, 0)) \
                    301:    : 0)
                    302: 
                    303: /* Given an rtx X being reloaded into a reg required to be
                    304:    in class CLASS, return the class of reg to actually use.
                    305:    In general this is just CLASS; but on some machines
                    306:    in some cases it is preferable to use a more restrictive class.  */
                    307: 
                    308: #define PREFERRED_RELOAD_CLASS(X,CLASS)  (CLASS)
                    309: 
                    310: /* Return the maximum number of consecutive registers
                    311:    needed to represent mode MODE in a register of class CLASS.  */
                    312: /* On the vax, this is always the size of MODE in words,
                    313:    since all registers are the same size.  */
                    314: #define CLASS_MAX_NREGS(CLASS, MODE)   \
                    315:  ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD)
                    316: 
                    317: /* Stack layout; function entry, exit and calling.  */
                    318: 
                    319: /* Define this if pushing a word on the stack
                    320:    makes the stack pointer a smaller address.  */
                    321: #define STACK_GROWS_DOWNWARD
                    322: 
                    323: /* Define this if longjmp restores from saved registers
                    324:    rather than from what setjmp saved.  */
                    325: #define LONGJMP_RESTORE_FROM_STACK
                    326: 
                    327: /* Define this if the nominal address of the stack frame
                    328:    is at the high-address end of the local variables;
                    329:    that is, each additional local variable allocated
                    330:    goes at a more negative offset in the frame.  */
                    331: #define FRAME_GROWS_DOWNWARD
                    332: 
                    333: /* Offset within stack frame to start allocating local variables at.
                    334:    If FRAME_GROWS_DOWNWARD, this is the offset to the END of the
                    335:    first local allocated.  Otherwise, it is the offset to the BEGINNING
                    336:    of the first local allocated.  */
                    337: #define STARTING_FRAME_OFFSET 0
                    338: 
                    339: /* Given an rtx for the address of a frame,
                    340:    return an rtx for the address of the word in the frame
                    341:    that holds the dynamic chain--the previous frame's address.  */
                    342: #define DYNAMIC_CHAIN_ADDRESS(frame) \
                    343: gen_rtx (PLUS, Pmode, frame, gen_rtx (CONST_INT, VOIDmode, 12))
                    344: 
                    345: /* If we generate an insn to push BYTES bytes,
                    346:    this says how many the stack pointer really advances by.
                    347:    On the vax, -(sp) pushes only the bytes of the operands.  */
                    348: #define PUSH_ROUNDING(BYTES) (BYTES)
                    349: 
                    350: /* Offset of first parameter from the argument pointer register value.  */
                    351: #define FIRST_PARM_OFFSET(FNDECL) 4
                    352: 
                    353: /* Value is the number of bytes of arguments automatically
                    354:    popped when returning from a subroutine call.
                    355:    FUNTYPE is the data type of the function (as a tree),
                    356:    or for a library call it is an identifier node for the subroutine name.
                    357:    SIZE is the number of bytes of arguments passed on the stack.
                    358: 
                    359:    On the Vax, the RET insn always pops all the args for any function.  */
                    360: 
                    361: #define RETURN_POPS_ARGS(FUNTYPE,SIZE) (SIZE)
                    362: 
                    363: /* Define how to find the value returned by a function.
                    364:    VALTYPE is the data type of the value (as a tree).
                    365:    If the precise function being called is known, FUNC is its FUNCTION_DECL;
                    366:    otherwise, FUNC is 0.  */
                    367: 
                    368: /* On the Vax the return value is in R0 regardless.  */   
                    369: 
                    370: #define FUNCTION_VALUE(VALTYPE, FUNC)  \
                    371:   gen_rtx (REG, TYPE_MODE (VALTYPE), 0)
                    372: 
                    373: /* Define how to find the value returned by a library function
                    374:    assuming the value has mode MODE.  */
                    375: 
                    376: /* On the Vax the return value is in R0 regardless.  */   
                    377: 
                    378: #define LIBCALL_VALUE(MODE)  gen_rtx (REG, MODE, 0)
                    379: 
                    380: /* Define this if PCC uses the nonreentrant convention for returning
                    381:    structure and union values.  */
                    382: 
                    383: #define PCC_STATIC_STRUCT_RETURN
                    384: 
                    385: /* 1 if N is a possible register number for a function value.
                    386:    On the Vax, R0 is the only register thus used.  */
                    387: 
                    388: #define FUNCTION_VALUE_REGNO_P(N) ((N) == 0)
                    389: 
                    390: /* 1 if N is a possible register number for function argument passing.
                    391:    On the Vax, no registers are used in this way.  */
                    392: 
                    393: #define FUNCTION_ARG_REGNO_P(N) 0
                    394: 
                    395: /* Define a data type for recording info about an argument list
                    396:    during the scan of that argument list.  This data type should
                    397:    hold all necessary information about the function itself
                    398:    and about the args processed so far, enough to enable macros
                    399:    such as FUNCTION_ARG to determine where the next arg should go.
                    400: 
                    401:    On the vax, this is a single integer, which is a number of bytes
                    402:    of arguments scanned so far.  */
                    403: 
                    404: #define CUMULATIVE_ARGS int
                    405: 
                    406: /* Initialize a variable CUM of type CUMULATIVE_ARGS
                    407:    for a call to a function whose data type is FNTYPE.
                    408:    For a library call, FNTYPE is 0.
                    409: 
                    410:    On the vax, the offset starts at 0.  */
                    411: 
                    412: #define INIT_CUMULATIVE_ARGS(CUM,FNTYPE,LIBNAME)       \
                    413:  ((CUM) = 0)
                    414: 
                    415: /* Update the data in CUM to advance over an argument
                    416:    of mode MODE and data type TYPE.
                    417:    (TYPE is null for libcalls where that information may not be available.)  */
                    418: 
                    419: #define FUNCTION_ARG_ADVANCE(CUM, MODE, TYPE, NAMED)   \
                    420:  ((CUM) += ((MODE) != BLKmode                  \
                    421:            ? (GET_MODE_SIZE (MODE) + 3) & ~3   \
                    422:            : (int_size_in_bytes (TYPE) + 3) & ~3))
                    423: 
                    424: /* Define where to put the arguments to a function.
                    425:    Value is zero to push the argument on the stack,
                    426:    or a hard register in which to store the argument.
                    427: 
                    428:    MODE is the argument's machine mode.
                    429:    TYPE is the data type of the argument (as a tree).
                    430:     This is null for libcalls where that information may
                    431:     not be available.
                    432:    CUM is a variable of type CUMULATIVE_ARGS which gives info about
                    433:     the preceding args and about the function being called.
                    434:    NAMED is nonzero if this argument is a named parameter
                    435:     (otherwise it is an extra parameter matching an ellipsis).  */
                    436: 
                    437: /* On the vax all args are pushed.  */   
                    438: 
                    439: #define FUNCTION_ARG(CUM, MODE, TYPE, NAMED) 0
                    440: 
                    441: /* This macro generates the assembly code for function entry.
                    442:    FILE is a stdio stream to output the code to.
                    443:    SIZE is an int: how many units of temporary storage to allocate.
                    444:    Refer to the array `regs_ever_live' to determine which registers
                    445:    to save; `regs_ever_live[I]' is nonzero if register number I
                    446:    is ever used in the function.  This macro is responsible for
                    447:    knowing which registers should not be saved even if used.  */
                    448: 
                    449: #define FUNCTION_PROLOGUE(FILE, SIZE)     \
                    450: { register int regno;                                          \
                    451:   register int mask = 0;                                       \
                    452:   extern char call_used_regs[];                                        \
                    453:   for (regno = 0; regno < FIRST_PSEUDO_REGISTER; regno++)      \
                    454:     if (regs_ever_live[regno] && !call_used_regs[regno])       \
                    455:        mask |= 1 << regno;                                     \
                    456:   fprintf (FILE, "\t.word 0x%x\n", mask);                      \
                    457:   MAYBE_VMS_FUNCTION_PROLOGUE(FILE)                            \
                    458:   if ((SIZE) >= 64) fprintf (FILE, "\tmovab %d(sp),sp\n", -SIZE);\
                    459:   else if (SIZE) fprintf (FILE, "\tsubl2 $%d,sp\n", (SIZE)); }
                    460: 
                    461: /* vms.h redefines this.  */
                    462: #define MAYBE_VMS_FUNCTION_PROLOGUE(FILE)
                    463: 
                    464: /* Output assembler code to FILE to increment profiler label # LABELNO
                    465:    for profiling a function entry.  */
                    466: 
                    467: #define FUNCTION_PROFILER(FILE, LABELNO)  \
                    468:    fprintf (FILE, "\tmovab LP%d,r0\n\tjsb mcount\n", (LABELNO));
                    469: 
                    470: /* Output assembler code to FILE to initialize this source file's
                    471:    basic block profiling info, if that has not already been done.  */
                    472: 
                    473: #define FUNCTION_BLOCK_PROFILER(FILE, LABELNO)  \
                    474:   fprintf (FILE, "\ttstl LPBX0\n\tjneq LPI%d\n\tpushal LPBX0\n\tcalls $1,__bb_init_func\nLPI%d:\n",  \
                    475:           LABELNO, LABELNO);
                    476: 
                    477: /* Output assembler code to FILE to increment the entry-count for
                    478:    the BLOCKNO'th basic block in this source file.  This is a real pain in the
                    479:    sphincter on a VAX, since we do not want to change any of the bits in the
                    480:    processor status word.  The way it is done here, it is pushed onto the stack
                    481:    before any flags have changed, and then the stack is fixed up to account for
                    482:    the fact that the instruction to restore the flags only reads a word.
                    483:    It may seem a bit clumsy, but at least it works.
                    484: */
                    485: 
                    486: #define BLOCK_PROFILER(FILE, BLOCKNO)  \
                    487:   fprintf (FILE, "\tmovpsl -(sp)\n\tmovw (sp),2(sp)\n\taddl2 $2,sp\n\taddl2 $1,LPBX2+%d\n\tbicpsw $255\n\tbispsw (sp)+\n", \
                    488:                4 * BLOCKNO)
                    489: 
                    490: /* EXIT_IGNORE_STACK should be nonzero if, when returning from a function,
                    491:    the stack pointer does not matter.  The value is tested only in
                    492:    functions that have frame pointers.
                    493:    No definition is equivalent to always zero.  */
                    494: 
                    495: #define EXIT_IGNORE_STACK 1
                    496: 
                    497: /* This macro generates the assembly code for function exit,
                    498:    on machines that need it.  If FUNCTION_EPILOGUE is not defined
                    499:    then individual return instructions are generated for each
                    500:    return statement.  Args are same as for FUNCTION_PROLOGUE.  */
                    501: 
                    502: /* #define FUNCTION_EPILOGUE(FILE, SIZE)  */
                    503: 
                    504: /* Store in the variable DEPTH the initial difference between the
                    505:    frame pointer reg contents and the stack pointer reg contents,
                    506:    as of the start of the function body.  This depends on the layout
                    507:    of the fixed parts of the stack frame and on how registers are saved.
                    508: 
                    509:    On the Vax, FRAME_POINTER_REQUIRED is always 1, so the definition of this
                    510:    macro doesn't matter.  But it must be defined.  */
                    511: 
                    512: #define INITIAL_FRAME_POINTER_OFFSET(DEPTH) (DEPTH) = 0;
                    513: 
                    514: /* Output assembler code for a block containing the constant parts
                    515:    of a trampoline, leaving space for the variable parts.  */
                    516: 
                    517: /* On the vax, the trampoline contains an entry mask and two instructions:
                    518:      .word NN
                    519:      movl $STATIC,r0   (store the functions static chain)
                    520:      jmp  *$FUNCTION   (jump to function code at address FUNCTION)  */
                    521: 
                    522: #define TRAMPOLINE_TEMPLATE(FILE)                                      \
                    523: {                                                                      \
                    524:   ASM_OUTPUT_SHORT (FILE, const0_rtx);                                 \
                    525:   ASM_OUTPUT_SHORT (FILE, gen_rtx (CONST_INT, VOIDmode, 0x8fd0));      \
                    526:   ASM_OUTPUT_INT (FILE, const0_rtx);                                   \
                    527:   ASM_OUTPUT_BYTE  (FILE, 0x50+STATIC_CHAIN_REGNUM);                   \
                    528:   ASM_OUTPUT_SHORT (FILE, gen_rtx (CONST_INT, VOIDmode, 0x9f17));      \
                    529:   ASM_OUTPUT_INT (FILE, const0_rtx);                                   \
                    530: }
                    531: 
                    532: /* Length in units of the trampoline for entering a nested function.  */
                    533: 
                    534: #define TRAMPOLINE_SIZE 15
                    535: 
                    536: /* Emit RTL insns to initialize the variable parts of a trampoline.
                    537:    FNADDR is an RTX for the address of the function's pure code.
                    538:    CXT is an RTX for the static chain value for the function.  */
                    539: 
                    540: /* We copy the register-mask from the function's pure code
                    541:    to the start of the trampoline.  */
                    542: #define INITIALIZE_TRAMPOLINE(TRAMP, FNADDR, CXT)                      \
                    543: {                                                                      \
                    544:   emit_insn (gen_rtx (ASM_INPUT, VOIDmode,                             \
                    545:                      "movpsl -(sp)\n\tpushal 1(pc)\n\trei"));          \
                    546:   emit_move_insn (gen_rtx (MEM, HImode, TRAMP),                                \
                    547:                  gen_rtx (MEM, HImode, FNADDR));                       \
                    548:   emit_move_insn (gen_rtx (MEM, SImode, plus_constant (TRAMP, 4)), CXT);\
                    549:   emit_move_insn (gen_rtx (MEM, SImode, plus_constant (TRAMP, 11)),    \
                    550:                  plus_constant (FNADDR, 2));                           \
                    551: }
                    552: 
                    553: /* Addressing modes, and classification of registers for them.  */
                    554: 
                    555: #define HAVE_POST_INCREMENT
                    556: /* #define HAVE_POST_DECREMENT */
                    557: 
                    558: #define HAVE_PRE_DECREMENT
                    559: /* #define HAVE_PRE_INCREMENT */
                    560: 
                    561: /* Macros to check register numbers against specific register classes.  */
                    562: 
                    563: /* These assume that REGNO is a hard or pseudo reg number.
                    564:    They give nonzero only if REGNO is a hard reg of the suitable class
                    565:    or a pseudo reg currently allocated to a suitable hard reg.
                    566:    Since they use reg_renumber, they are safe only once reg_renumber
                    567:    has been allocated, which happens in local-alloc.c.  */
                    568: 
                    569: #define REGNO_OK_FOR_INDEX_P(regno)  \
                    570: ((regno) < FIRST_PSEUDO_REGISTER || reg_renumber[regno] >= 0)
                    571: #define REGNO_OK_FOR_BASE_P(regno) \
                    572: ((regno) < FIRST_PSEUDO_REGISTER || reg_renumber[regno] >= 0)
                    573: 
                    574: /* Maximum number of registers that can appear in a valid memory address.  */
                    575: 
                    576: #define MAX_REGS_PER_ADDRESS 2
                    577: 
                    578: /* 1 if X is an rtx for a constant that is a valid address.  */
                    579: 
                    580: #define CONSTANT_ADDRESS_P(X)   \
                    581:   (GET_CODE (X) == LABEL_REF || GET_CODE (X) == SYMBOL_REF             \
                    582:    || GET_CODE (X) == CONST_INT || GET_CODE (X) == CONST               \
                    583:    || GET_CODE (X) == HIGH)
                    584: 
                    585: /* Nonzero if the constant value X is a legitimate general operand.
                    586:    It is given that X satisfies CONSTANT_P or is a CONST_DOUBLE.  */
                    587: 
                    588: #define LEGITIMATE_CONSTANT_P(X) 1
                    589: 
                    590: /* The macros REG_OK_FOR..._P assume that the arg is a REG rtx
                    591:    and check its validity for a certain class.
                    592:    We have two alternate definitions for each of them.
                    593:    The usual definition accepts all pseudo regs; the other rejects
                    594:    them unless they have been allocated suitable hard regs.
                    595:    The symbol REG_OK_STRICT causes the latter definition to be used.
                    596: 
                    597:    Most source files want to accept pseudo regs in the hope that
                    598:    they will get allocated to the class that the insn wants them to be in.
                    599:    Source files for reload pass need to be strict.
                    600:    After reload, it makes no difference, since pseudo regs have
                    601:    been eliminated by then.  */
                    602: 
                    603: #ifndef REG_OK_STRICT
                    604: 
                    605: /* Nonzero if X is a hard reg that can be used as an index
                    606:    or if it is a pseudo reg.  */
                    607: #define REG_OK_FOR_INDEX_P(X) 1
                    608: /* Nonzero if X is a hard reg that can be used as a base reg
                    609:    or if it is a pseudo reg.  */
                    610: #define REG_OK_FOR_BASE_P(X) 1
                    611: 
                    612: #else
                    613: 
                    614: /* Nonzero if X is a hard reg that can be used as an index.  */
                    615: #define REG_OK_FOR_INDEX_P(X) REGNO_OK_FOR_INDEX_P (REGNO (X))
                    616: /* Nonzero if X is a hard reg that can be used as a base reg.  */
                    617: #define REG_OK_FOR_BASE_P(X) REGNO_OK_FOR_BASE_P (REGNO (X))
                    618: 
                    619: #endif
                    620: 
                    621: /* GO_IF_LEGITIMATE_ADDRESS recognizes an RTL expression
                    622:    that is a valid memory address for an instruction.
                    623:    The MODE argument is the machine mode for the MEM expression
                    624:    that wants to use this address.
                    625: 
                    626:    The other macros defined here are used only in GO_IF_LEGITIMATE_ADDRESS,
                    627:    except for CONSTANT_ADDRESS_P which is actually machine-independent.  */
                    628: 
                    629: #ifdef NO_EXTERNAL_INDIRECT_ADDRESS
                    630: 
                    631: /* Zero if this contains a (CONST (PLUS (SYMBOL_REF) (...))) and the
                    632:    symbol in the SYMBOL_REF is an external symbol.  */
                    633: 
                    634: #define INDIRECTABLE_CONSTANT_P(X) \
                    635:  (! (GET_CODE ((X)) == CONST                                   \
                    636:      && GET_CODE (XEXP ((X), 0)) == PLUS                       \
                    637:      && GET_CODE (XEXP (XEXP ((X), 0), 0)) == SYMBOL_REF       \
                    638:      && SYMBOL_REF_FLAG (XEXP (XEXP ((X), 0), 0))))
                    639: 
                    640: /* Re-definition of CONSTANT_ADDRESS_P, which is true only when there
                    641:    are no SYMBOL_REFs for external symbols present.  */
                    642: 
                    643: #define INDIRECTABLE_CONSTANT_ADDRESS_P(X)                             \
                    644:   (GET_CODE (X) == LABEL_REF                                           \
                    645:    || (GET_CODE (X) == SYMBOL_REF && !SYMBOL_REF_FLAG (X))             \
                    646:    || (GET_CODE (X) == CONST && INDIRECTABLE_CONSTANT_P(X))            \
                    647:    || GET_CODE (X) == CONST_INT)
                    648: 
                    649: 
                    650: /* Non-zero if X is an address which can be indirected.  External symbols
                    651:    could be in a sharable image library, so we disallow those.  */
                    652: 
                    653: #define INDIRECTABLE_ADDRESS_P(X)  \
                    654:   (INDIRECTABLE_CONSTANT_ADDRESS_P (X)                                         \
                    655:    || (GET_CODE (X) == REG && REG_OK_FOR_BASE_P (X))                   \
                    656:    || (GET_CODE (X) == PLUS                                            \
                    657:        && GET_CODE (XEXP (X, 0)) == REG                                        \
                    658:        && REG_OK_FOR_BASE_P (XEXP (X, 0))                              \
                    659:        && INDIRECTABLE_CONSTANT_ADDRESS_P (XEXP (X, 1))))
                    660: 
                    661: #else /* not NO_EXTERNAL_INDIRECT_ADDRESS */
                    662: 
                    663: #define INDIRECTABLE_CONSTANT_ADDRESS_P(X) CONSTANT_ADDRESS_P(X)
                    664: 
                    665: /* Non-zero if X is an address which can be indirected.  */
                    666: #define INDIRECTABLE_ADDRESS_P(X)  \
                    667:   (CONSTANT_ADDRESS_P (X)                                              \
                    668:    || (GET_CODE (X) == REG && REG_OK_FOR_BASE_P (X))                   \
                    669:    || (GET_CODE (X) == PLUS                                            \
                    670:        && GET_CODE (XEXP (X, 0)) == REG                                        \
                    671:        && REG_OK_FOR_BASE_P (XEXP (X, 0))                              \
                    672:        && CONSTANT_ADDRESS_P (XEXP (X, 1))))
                    673: 
                    674: #endif /* not NO_EXTERNAL_INDIRECT_ADDRESS */
                    675: 
                    676: /* Go to ADDR if X is a valid address not using indexing.
                    677:    (This much is the easy part.)  */
                    678: #define GO_IF_NONINDEXED_ADDRESS(X, ADDR)  \
                    679: { register rtx xfoob = (X);                                            \
                    680:   if (GET_CODE (xfoob) == REG)                                         \
                    681:     {                                                                  \
                    682:       extern rtx *reg_equiv_mem;                                       \
                    683:       if (! reload_in_progress                                         \
                    684:          || reg_equiv_mem[REGNO (xfoob)] == 0                          \
                    685:          || INDIRECTABLE_ADDRESS_P (reg_equiv_mem[REGNO (xfoob)]))     \
                    686:        goto ADDR;                                                      \
                    687:     }                                                                  \
                    688:   if (CONSTANT_ADDRESS_P (xfoob)) goto ADDR;                           \
                    689:   if (INDIRECTABLE_ADDRESS_P (xfoob)) goto ADDR;                       \
                    690:   xfoob = XEXP (X, 0);                                                 \
                    691:   if (GET_CODE (X) == MEM && INDIRECTABLE_ADDRESS_P (xfoob))           \
                    692:     goto ADDR;                                                         \
                    693:   if ((GET_CODE (X) == PRE_DEC || GET_CODE (X) == POST_INC)            \
                    694:       && GET_CODE (xfoob) == REG && REG_OK_FOR_BASE_P (xfoob))         \
                    695:     goto ADDR; }
                    696: 
                    697: /* 1 if PROD is either a reg times size of mode MODE
                    698:    or just a reg, if MODE is just one byte.
                    699:    This macro's expansion uses the temporary variables xfoo0 and xfoo1
                    700:    that must be declared in the surrounding context.  */
                    701: #define INDEX_TERM_P(PROD, MODE)   \
                    702: (GET_MODE_SIZE (MODE) == 1                                             \
                    703:  ? (GET_CODE (PROD) == REG && REG_OK_FOR_BASE_P (PROD))                        \
                    704:  : (GET_CODE (PROD) == MULT                                            \
                    705:     &&                                                                 \
                    706:     (xfoo0 = XEXP (PROD, 0), xfoo1 = XEXP (PROD, 1),                   \
                    707:      ((GET_CODE (xfoo0) == CONST_INT                                   \
                    708:        && INTVAL (xfoo0) == GET_MODE_SIZE (MODE)                       \
                    709:        && GET_CODE (xfoo1) == REG                                      \
                    710:        && REG_OK_FOR_INDEX_P (xfoo1))                                  \
                    711:       ||                                                               \
                    712:       (GET_CODE (xfoo1) == CONST_INT                                   \
                    713:        && INTVAL (xfoo1) == GET_MODE_SIZE (MODE)                       \
                    714:        && GET_CODE (xfoo0) == REG                                      \
                    715:        && REG_OK_FOR_INDEX_P (xfoo0))))))
                    716: 
                    717: /* Go to ADDR if X is the sum of a register
                    718:    and a valid index term for mode MODE.  */
                    719: #define GO_IF_REG_PLUS_INDEX(X, MODE, ADDR)    \
                    720: { register rtx xfooa;                                                  \
                    721:   if (GET_CODE (X) == PLUS)                                            \
                    722:     { if (GET_CODE (XEXP (X, 0)) == REG                                        \
                    723:          && REG_OK_FOR_BASE_P (XEXP (X, 0))                            \
                    724:          && (xfooa = XEXP (X, 1),                                      \
                    725:              INDEX_TERM_P (xfooa, MODE)))                              \
                    726:        goto ADDR;                                                      \
                    727:       if (GET_CODE (XEXP (X, 1)) == REG                                        \
                    728:          && REG_OK_FOR_BASE_P (XEXP (X, 1))                            \
                    729:          && (xfooa = XEXP (X, 0),                                      \
                    730:              INDEX_TERM_P (xfooa, MODE)))                              \
                    731:        goto ADDR; } }
                    732: 
                    733: #define GO_IF_LEGITIMATE_ADDRESS(MODE, X, ADDR)  \
                    734: { register rtx xfoo, xfoo0, xfoo1;                                     \
                    735:   GO_IF_NONINDEXED_ADDRESS (X, ADDR);                                  \
                    736:   if (GET_CODE (X) == PLUS)                                            \
                    737:     { /* Handle <address>[index] represented with index-sum outermost */\
                    738:       xfoo = XEXP (X, 0);                                              \
                    739:       if (INDEX_TERM_P (xfoo, MODE))                                   \
                    740:        { GO_IF_NONINDEXED_ADDRESS (XEXP (X, 1), ADDR); }               \
                    741:       xfoo = XEXP (X, 1);                                              \
                    742:       if (INDEX_TERM_P (xfoo, MODE))                                   \
                    743:        { GO_IF_NONINDEXED_ADDRESS (XEXP (X, 0), ADDR); }               \
                    744:       /* Handle offset(reg)[index] with offset added outermost */      \
                    745:       if (INDIRECTABLE_CONSTANT_ADDRESS_P (XEXP (X, 0)))               \
                    746:        { if (GET_CODE (XEXP (X, 1)) == REG                             \
                    747:              && REG_OK_FOR_BASE_P (XEXP (X, 1)))                       \
                    748:            goto ADDR;                                                  \
                    749:          GO_IF_REG_PLUS_INDEX (XEXP (X, 1), MODE, ADDR); }             \
                    750:       if (INDIRECTABLE_CONSTANT_ADDRESS_P (XEXP (X, 1)))               \
                    751:        { if (GET_CODE (XEXP (X, 0)) == REG                             \
                    752:              && REG_OK_FOR_BASE_P (XEXP (X, 0)))                       \
                    753:            goto ADDR;                                                  \
                    754:          GO_IF_REG_PLUS_INDEX (XEXP (X, 0), MODE, ADDR); } } }
                    755: 
                    756: /* Try machine-dependent ways of modifying an illegitimate address
                    757:    to be legitimate.  If we find one, return the new, valid address.
                    758:    This macro is used in only one place: `memory_address' in explow.c.
                    759: 
                    760:    OLDX is the address as it was before break_out_memory_refs was called.
                    761:    In some cases it is useful to look at this to decide what needs to be done.
                    762: 
                    763:    MODE and WIN are passed so that this macro can use
                    764:    GO_IF_LEGITIMATE_ADDRESS.
                    765: 
                    766:    It is always safe for this macro to do nothing.  It exists to recognize
                    767:    opportunities to optimize the output.
                    768: 
                    769:    For the vax, nothing needs to be done.  */
                    770: 
                    771: #define LEGITIMIZE_ADDRESS(X,OLDX,MODE,WIN)  {}
                    772: 
                    773: /* Go to LABEL if ADDR (a legitimate address expression)
                    774:    has an effect that depends on the machine mode it is used for.
                    775:    On the VAX, the predecrement and postincrement address depend thus
                    776:    (the amount of decrement or increment being the length of the operand)
                    777:    and all indexed address depend thus (because the index scale factor
                    778:    is the length of the operand).  */
                    779: #define GO_IF_MODE_DEPENDENT_ADDRESS(ADDR,LABEL)       \
                    780:  { if (GET_CODE (ADDR) == POST_INC || GET_CODE (ADDR) == PRE_DEC)      \
                    781:      goto LABEL;                                                       \
                    782:    if (GET_CODE (ADDR) == PLUS)                                                \
                    783:      { if (CONSTANT_ADDRESS_P (XEXP (ADDR, 0))                         \
                    784:           && GET_CODE (XEXP (ADDR, 1)) == REG);                        \
                    785:        else if (CONSTANT_ADDRESS_P (XEXP (ADDR, 1))                    \
                    786:                && GET_CODE (XEXP (ADDR, 0)) == REG);                   \
                    787:        else goto LABEL; }}
                    788: 
                    789: /* Specify the machine mode that this machine uses
                    790:    for the index in the tablejump instruction.  */
                    791: #define CASE_VECTOR_MODE HImode
                    792: 
                    793: /* Define this if the case instruction expects the table
                    794:    to contain offsets from the address of the table.
                    795:    Do not define this if the table should contain absolute addresses.  */
                    796: #define CASE_VECTOR_PC_RELATIVE
                    797: 
                    798: /* Define this if the case instruction drops through after the table
                    799:    when the index is out of range.  Don't define it if the case insn
                    800:    jumps to the default label instead.  */
                    801: #define CASE_DROPS_THROUGH
                    802: 
                    803: /* Specify the tree operation to be used to convert reals to integers.  */
                    804: #define IMPLICIT_FIX_EXPR FIX_ROUND_EXPR
                    805: 
                    806: /* This is the kind of divide that is easiest to do in the general case.  */
                    807: #define EASY_DIV_EXPR TRUNC_DIV_EXPR
                    808: 
                    809: /* Define this as 1 if `char' should by default be signed; else as 0.  */
                    810: #define DEFAULT_SIGNED_CHAR 1
                    811: 
                    812: /* This flag, if defined, says the same insns that convert to a signed fixnum
                    813:    also convert validly to an unsigned one.  */
                    814: #define FIXUNS_TRUNC_LIKE_FIX_TRUNC
                    815: 
                    816: /* Max number of bytes we can move from memory to memory
                    817:    in one reasonably fast instruction.  */
                    818: #define MOVE_MAX 8
                    819: 
                    820: /* Define this if zero-extension is slow (more than one real instruction).  */
                    821: /* #define SLOW_ZERO_EXTEND */
                    822: 
                    823: /* Nonzero if access to memory by bytes is slow and undesirable.  */
                    824: #define SLOW_BYTE_ACCESS 0
                    825: 
                    826: /* Define if shifts truncate the shift count
                    827:    which implies one can omit a sign-extension or zero-extension
                    828:    of a shift count.  */
                    829: /* #define SHIFT_COUNT_TRUNCATED */
                    830: 
                    831: /* Value is 1 if truncating an integer of INPREC bits to OUTPREC bits
                    832:    is done just by pretending it is already truncated.  */
                    833: #define TRULY_NOOP_TRUNCATION(OUTPREC, INPREC) 1
                    834: 
                    835: /* Specify the machine mode that pointers have.
                    836:    After generation of rtl, the compiler makes no further distinction
                    837:    between pointers and any other objects of this machine mode.  */
                    838: #define Pmode SImode
                    839: 
                    840: /* A function address in a call instruction
                    841:    is a byte address (for indexing purposes)
                    842:    so give the MEM rtx a byte's mode.  */
                    843: #define FUNCTION_MODE QImode
                    844: 
                    845: /* This machine doesn't use IEEE floats.  */
                    846: 
                    847: #define TARGET_FLOAT_FORMAT VAX_FLOAT_FORMAT
                    848: 
                    849: /* Compute the cost of computing a constant rtl expression RTX
                    850:    whose rtx-code is CODE.  The body of this macro is a portion
                    851:    of a switch statement.  If the code is computed here,
                    852:    return it with a return statement.  Otherwise, break from the switch.  */
                    853: 
                    854: /* On a VAX, constants from 0..63 are cheap because they can use the
                    855:    1 byte literal constant format.  compare to -1 should be made cheap
                    856:    so that decrement-and-branch insns can be formed more easily (if
                    857:    the value -1 is copied to a register some decrement-and-branch patterns
                    858:    will not match).  */
                    859: 
                    860: #define CONST_COSTS(RTX,CODE,OUTER_CODE) \
                    861:   case CONST_INT:                                              \
                    862:     if (INTVAL (RTX) == 0) return 0;                           \
                    863:     if ((OUTER_CODE) == AND)                                   \
                    864:       return ((unsigned) ~INTVAL (RTX) <= 077) ? 1 : 2;                \
                    865:     if ((unsigned) INTVAL (RTX) <= 077) return 1;              \
                    866:     if ((OUTER_CODE) == COMPARE && INTVAL (RTX) == -1)         \
                    867:       return 1;                                                        \
                    868:     if ((OUTER_CODE) == PLUS && (unsigned) -INTVAL (RTX) <= 077)\
                    869:       return 1;                                                        \
                    870:   case CONST:                                                  \
                    871:   case LABEL_REF:                                              \
                    872:   case SYMBOL_REF:                                             \
                    873:     return 3;                                                  \
                    874:   case CONST_DOUBLE:                                           \
                    875:     if (GET_MODE_CLASS (GET_MODE (RTX)) == MODE_FLOAT)         \
                    876:       return vax_float_literal (RTX) ? 5 : 8;                  \
                    877:     else                                                       \
                    878:       return (((CONST_DOUBLE_HIGH (RTX) == 0                   \
                    879:                && (unsigned) CONST_DOUBLE_LOW (RTX) < 64)      \
                    880:               || ((OUTER_CODE) == PLUS                         \
                    881:                   && CONST_DOUBLE_HIGH (RTX) == -1             \
                    882:                   && (unsigned)-CONST_DOUBLE_LOW (RTX) < 64))  \
                    883:              ? 2 : 5);
                    884: 
                    885: #define RTX_COSTS(RTX,CODE,OUTER_CODE) case FIX: case FLOAT:   \
                    886:  case MULT: case DIV: case UDIV: case MOD: case UMOD:          \
                    887:  case LSHIFT: case ASHIFT: case LSHIFTRT: case ASHIFTRT:       \
                    888:  case ROTATE: case ROTATERT: case PLUS: case MINUS: case IOR:  \
                    889:  case XOR: case AND: case NEG: case NOT: case ZERO_EXTRACT:    \
                    890:  case SIGN_EXTRACT: case MEM: return vax_rtx_cost(RTX)
                    891: 
                    892: #define        ADDRESS_COST(RTX) (1 + (GET_CODE (RTX) == REG ? 0 : vax_address_cost(RTX)))
                    893: 
                    894: /* Specify the cost of a branch insn; roughly the number of extra insns that
                    895:    should be added to avoid a branch.
                    896: 
                    897:    Branches are extremely cheap on the VAX while the shift insns often
                    898:    used to replace branches can be expensive.  */
                    899: 
                    900: #define BRANCH_COST 0
                    901: 
                    902: /*
                    903:  * We can use the BSD C library routines for the libgcc calls that are
                    904:  * still generated, since that's what they boil down to anyways.
                    905:  */
                    906: 
                    907: #define UDIVSI3_LIBCALL "*udiv"
                    908: #define UMODSI3_LIBCALL "*urem"
                    909: 
                    910: /* Check a `double' value for validity for a particular machine mode.  */
                    911: 
                    912: /* note that it is very hard to accidentally create a number that fits in a
                    913:    double but not in a float, since their ranges are almost the same */
                    914: 
                    915: #define CHECK_FLOAT_VALUE(mode, d) (check_float_value (mode, &d))
                    916: 
                    917: /* For future reference:
                    918:    D Float: 9 bit, sign magnitude, excess 128 binary exponent
                    919:             normalized 56 bit fraction, redundant bit not represented
                    920:             approximately 16 decimal digits of precision
                    921: 
                    922:    The values to use if we trust decimal to binary conversions:
                    923: #define MAX_D_FLOAT 1.7014118346046923e+38
                    924: #define MIN_D_FLOAT .29387358770557188e-38
                    925: 
                    926:    G float: 12 bit, sign magnitude, excess 1024 binary exponent
                    927:             normalized 53 bit fraction, redundant bit not represented
                    928:             approximately 15 decimal digits precision
                    929: 
                    930:    The values to use if we trust decimal to binary conversions:
                    931: #define MAX_G_FLOAT .898846567431157e+308
                    932: #define MIN_G_FLOAT .556268464626800e-308
                    933: */
                    934: 
                    935: /* Tell final.c how to eliminate redundant test instructions.  */
                    936: 
                    937: /* Here we define machine-dependent flags and fields in cc_status
                    938:    (see `conditions.h').  No extra ones are needed for the vax.  */
                    939: 
                    940: /* Store in cc_status the expressions
                    941:    that the condition codes will describe
                    942:    after execution of an instruction whose pattern is EXP.
                    943:    Do not alter them if the instruction would not alter the cc's.  */
                    944: 
                    945: #define NOTICE_UPDATE_CC(EXP, INSN) \
                    946: { if (GET_CODE (EXP) == SET)                                   \
                    947:     { if (GET_CODE (SET_SRC (EXP)) == CALL)                    \
                    948:        CC_STATUS_INIT;                                         \
                    949:       else if (GET_CODE (SET_DEST (EXP)) != PC)                        \
                    950:        { cc_status.flags = 0;                                  \
                    951:          cc_status.value1 = SET_DEST (EXP);                    \
                    952:          cc_status.value2 = SET_SRC (EXP); } }                 \
                    953:   else if (GET_CODE (EXP) == PARALLEL                          \
                    954:           && GET_CODE (XVECEXP (EXP, 0, 0)) == SET)            \
                    955:     {                                                          \
                    956:       if (GET_CODE (SET_SRC (XVECEXP (EXP, 0, 0))) == CALL)    \
                    957:        CC_STATUS_INIT;                                         \
                    958:       else if (GET_CODE (SET_DEST (XVECEXP (EXP, 0, 0))) != PC) \
                    959:        { cc_status.flags = 0;                                  \
                    960:          cc_status.value1 = SET_DEST (XVECEXP (EXP, 0, 0));    \
                    961:          cc_status.value2 = SET_SRC (XVECEXP (EXP, 0, 0)); } } \
                    962:   /* PARALLELs whose first element sets the PC are aob, sob insns.     \
                    963:      They do change the cc's.  So drop through and forget the cc's.  */ \
                    964:   else CC_STATUS_INIT;                                         \
                    965:   if (cc_status.value1 && GET_CODE (cc_status.value1) == REG   \
                    966:       && cc_status.value2                                      \
                    967:       && reg_overlap_mentioned_p (cc_status.value1, cc_status.value2)) \
                    968:     cc_status.value2 = 0;                                      \
                    969:   if (cc_status.value1 && GET_CODE (cc_status.value1) == MEM   \
                    970:       && cc_status.value2                                      \
                    971:       && GET_CODE (cc_status.value2) == MEM)                   \
                    972:     cc_status.value2 = 0; }
                    973: /* Actual condition, one line up, should be that value2's address
                    974:    depends on value1, but that is too much of a pain.  */
                    975: 
                    976: #define OUTPUT_JUMP(NORMAL, FLOAT, NO_OV)  \
                    977: { if (cc_status.flags & CC_NO_OVERFLOW)                                \
                    978:     return NO_OV;                                              \
                    979:   return NORMAL; }
                    980: 
                    981: /* Control the assembler format that we output.  */
                    982: 
                    983: /* Output at beginning of assembler file.  */
                    984: 
                    985: #define ASM_FILE_START(FILE) fprintf (FILE, "#NO_APP\n");
                    986: 
                    987: /* Output to assembler file text saying following lines
                    988:    may contain character constants, extra white space, comments, etc.  */
                    989: 
                    990: #define ASM_APP_ON "#APP\n"
                    991: 
                    992: /* Output to assembler file text saying following lines
                    993:    no longer contain unusual constructs.  */
                    994: 
                    995: #define ASM_APP_OFF "#NO_APP\n"
                    996: 
                    997: /* Output before read-only data.  */
                    998: 
                    999: #define TEXT_SECTION_ASM_OP ".text"
                   1000: 
                   1001: /* Output before writable data.  */
                   1002: 
                   1003: #define DATA_SECTION_ASM_OP ".data"
                   1004: 
                   1005: /* How to refer to registers in assembler output.
                   1006:    This sequence is indexed by compiler's hard-register-number (see above).  */
                   1007: 
                   1008: #define REGISTER_NAMES \
                   1009: {"r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7", "r8", \
                   1010:  "r9", "r10", "r11", "ap", "fp", "sp", "pc"}
                   1011: 
                   1012: /* This is BSD, so it wants DBX format.  */
                   1013: 
                   1014: #define DBX_DEBUGGING_INFO
                   1015: 
                   1016: /* How to renumber registers for dbx and gdb.
                   1017:    Vax needs no change in the numeration.  */
                   1018: 
                   1019: #define DBX_REGISTER_NUMBER(REGNO) (REGNO)
                   1020: 
                   1021: /* Do not break .stabs pseudos into continuations.  */
                   1022: 
                   1023: #define DBX_CONTIN_LENGTH 0
                   1024: 
                   1025: /* This is the char to use for continuation (in case we need to turn
                   1026:    continuation back on).  */
                   1027: 
                   1028: #define DBX_CONTIN_CHAR '?'
                   1029: 
                   1030: /* Don't use the `xsfoo;' construct in DBX output; this system
                   1031:    doesn't support it.  */
                   1032: 
                   1033: #define DBX_NO_XREFS
                   1034: 
                   1035: /* Output the .stabs for a C `static' variable in the data section.  */
                   1036: #define DBX_STATIC_STAB_DATA_SECTION
                   1037: 
                   1038: /* Vax specific: which type character is used for type double?  */
                   1039: 
                   1040: #define ASM_DOUBLE_CHAR (TARGET_G_FLOAT ? 'g' : 'd')
                   1041: 
                   1042: /* This is how to output the definition of a user-level label named NAME,
                   1043:    such as the label on a static function or variable NAME.  */
                   1044: 
                   1045: #define ASM_OUTPUT_LABEL(FILE,NAME)    \
                   1046:   do { assemble_name (FILE, NAME); fputs (":\n", FILE); } while (0)
                   1047: 
                   1048: /* This is how to output a command to make the user-level label named NAME
                   1049:    defined for reference from other files.  */
                   1050: 
                   1051: #define ASM_GLOBALIZE_LABEL(FILE,NAME) \
                   1052:   do { fputs (".globl ", FILE); assemble_name (FILE, NAME); fputs ("\n", FILE);} while (0)
                   1053: 
                   1054: /* This is how to output a reference to a user-level label named NAME.  */
                   1055: 
                   1056: #define ASM_OUTPUT_LABELREF(FILE,NAME) \
                   1057:   fprintf (FILE, "_%s", NAME)
                   1058: 
                   1059: /* This is how to output an internal numbered label where
                   1060:    PREFIX is the class of label and NUM is the number within the class.  */
                   1061: 
                   1062: #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM)     \
                   1063:   fprintf (FILE, "%s%d:\n", PREFIX, NUM)
                   1064: 
                   1065: /* This is how to store into the string LABEL
                   1066:    the symbol_ref name of an internal numbered label where
                   1067:    PREFIX is the class of label and NUM is the number within the class.
                   1068:    This is suitable for output with `assemble_name'.  */
                   1069: 
                   1070: #define ASM_GENERATE_INTERNAL_LABEL(LABEL,PREFIX,NUM)  \
                   1071:   sprintf (LABEL, "*%s%d", PREFIX, NUM)
                   1072: 
                   1073: /* This is how to output an assembler line defining a `double' constant.
                   1074:    It is .dfloat or .gfloat, depending.  */
                   1075: 
                   1076: #define ASM_OUTPUT_DOUBLE(FILE,VALUE)  \
                   1077: do { char dstr[30];                                                    \
                   1078:      REAL_VALUE_TO_DECIMAL (VALUE, "%.20e", dstr);                     \
                   1079:      fprintf (FILE, "\t.%cfloat 0%c%s\n", ASM_DOUBLE_CHAR,             \
                   1080:                                          ASM_DOUBLE_CHAR, dstr);       \
                   1081:    } while (0);
                   1082: 
                   1083: /* This is how to output an assembler line defining a `float' constant.  */
                   1084: 
                   1085: #define ASM_OUTPUT_FLOAT(FILE,VALUE)  \
                   1086:   do { char dstr[30];                                          \
                   1087:        REAL_VALUE_TO_DECIMAL (VALUE, "%.20e", dstr);           \
                   1088:        fprintf (FILE, "\t.float 0f%s\n", dstr); } while (0);
                   1089: 
                   1090: /* This is how to output an assembler line defining an `int' constant.  */
                   1091: 
                   1092: #define ASM_OUTPUT_INT(FILE,VALUE)  \
                   1093: ( fprintf (FILE, "\t.long "),                  \
                   1094:   output_addr_const (FILE, (VALUE)),           \
                   1095:   fprintf (FILE, "\n"))
                   1096: 
                   1097: /* Likewise for `char' and `short' constants.  */
                   1098: 
                   1099: #define ASM_OUTPUT_SHORT(FILE,VALUE)  \
                   1100: ( fprintf (FILE, "\t.word "),                  \
                   1101:   output_addr_const (FILE, (VALUE)),           \
                   1102:   fprintf (FILE, "\n"))
                   1103: 
                   1104: #define ASM_OUTPUT_CHAR(FILE,VALUE)  \
                   1105: ( fprintf (FILE, "\t.byte "),                  \
                   1106:   output_addr_const (FILE, (VALUE)),           \
                   1107:   fprintf (FILE, "\n"))
                   1108: 
                   1109: /* This is how to output an assembler line for a numeric constant byte.  */
                   1110: 
                   1111: #define ASM_OUTPUT_BYTE(FILE,VALUE)  \
                   1112:   fprintf (FILE, "\t.byte 0x%x\n", (VALUE))
                   1113: 
                   1114: /* This is how to output an insn to push a register on the stack.
                   1115:    It need not be very fast code.  */
                   1116: 
                   1117: #define ASM_OUTPUT_REG_PUSH(FILE,REGNO)  \
                   1118:   fprintf (FILE, "\tpushl %s\n", reg_names[REGNO])
                   1119: 
                   1120: /* This is how to output an insn to pop a register from the stack.
                   1121:    It need not be very fast code.  */
                   1122: 
                   1123: #define ASM_OUTPUT_REG_POP(FILE,REGNO)  \
                   1124:   fprintf (FILE, "\tmovl (sp)+,%s\n", reg_names[REGNO])
                   1125: 
                   1126: /* This is how to output an element of a case-vector that is absolute.
                   1127:    (The Vax does not use such vectors,
                   1128:    but we must define this macro anyway.)  */
                   1129: 
                   1130: #define ASM_OUTPUT_ADDR_VEC_ELT(FILE, VALUE)  \
                   1131:   fprintf (FILE, "\t.long L%d\n", VALUE)
                   1132: 
                   1133: /* This is how to output an element of a case-vector that is relative.  */
                   1134: 
                   1135: #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL)  \
                   1136:   fprintf (FILE, "\t.word L%d-L%d\n", VALUE, REL)
                   1137: 
                   1138: /* This is how to output an assembler line
                   1139:    that says to advance the location counter
                   1140:    to a multiple of 2**LOG bytes.  */
                   1141: 
                   1142: #define ASM_OUTPUT_ALIGN(FILE,LOG)  \
                   1143:   fprintf (FILE, "\t.align %d\n", (LOG))
                   1144: 
                   1145: /* This is how to output an assembler line
                   1146:    that says to advance the location counter by SIZE bytes.  */
                   1147: 
                   1148: #define ASM_OUTPUT_SKIP(FILE,SIZE)  \
                   1149:   fprintf (FILE, "\t.space %u\n", (SIZE))
                   1150: 
                   1151: /* This says how to output an assembler line
                   1152:    to define a global common symbol.  */
                   1153: 
                   1154: #define ASM_OUTPUT_COMMON(FILE, NAME, SIZE, ROUNDED)  \
                   1155: ( fputs (".comm ", (FILE)),                    \
                   1156:   assemble_name ((FILE), (NAME)),              \
                   1157:   fprintf ((FILE), ",%u\n", (ROUNDED)))
                   1158: 
                   1159: /* This says how to output an assembler line
                   1160:    to define a local common symbol.  */
                   1161: 
                   1162: #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE, ROUNDED)  \
                   1163: ( fputs (".lcomm ", (FILE)),                   \
                   1164:   assemble_name ((FILE), (NAME)),              \
                   1165:   fprintf ((FILE), ",%u\n", (ROUNDED)))
                   1166: 
                   1167: /* Store in OUTPUT a string (made with alloca) containing
                   1168:    an assembler-name for a local static variable named NAME.
                   1169:    LABELNO is an integer which is different for each call.  */
                   1170: 
                   1171: #define ASM_FORMAT_PRIVATE_NAME(OUTPUT, NAME, LABELNO) \
                   1172: ( (OUTPUT) = (char *) alloca (strlen ((NAME)) + 10),   \
                   1173:   sprintf ((OUTPUT), "%s.%d", (NAME), (LABELNO)))
                   1174: 
                   1175: /* Define the parentheses used to group arithmetic operations
                   1176:    in assembler code.  */
                   1177: 
                   1178: #define ASM_OPEN_PAREN "("
                   1179: #define ASM_CLOSE_PAREN ")"
                   1180: 
                   1181: /* Define results of standard character escape sequences.  */
                   1182: #define TARGET_BELL 007
                   1183: #define TARGET_BS 010
                   1184: #define TARGET_TAB 011
                   1185: #define TARGET_NEWLINE 012
                   1186: #define TARGET_VT 013
                   1187: #define TARGET_FF 014
                   1188: #define TARGET_CR 015
                   1189: 
                   1190: /* Print an instruction operand X on file FILE.
                   1191:    CODE is the code from the %-spec that requested printing this operand;
                   1192:    if `%z3' was used to print operand 3, then CODE is 'z'.
                   1193: 
                   1194: VAX operand formatting codes:
                   1195: 
                   1196:  letter           print
                   1197:    C   reverse branch condition
                   1198:    D   64-bit immediate operand
                   1199:    B   the low 8 bits of the complement of a constant operand
                   1200:    H   the low 16 bits of the complement of a constant operand
                   1201:    M   a mask for the N highest bits of a word
                   1202:    N   the complement of a constant integer operand
                   1203:    P   constant operand plus 1
                   1204:    R   32 - constant operand
                   1205:    b   the low 8 bits of a negated constant operand
                   1206:    h   the low 16 bits of a negated constant operand
                   1207:    #   'd' or 'g' depending on whether dfloat or gfloat is used  */
                   1208: 
                   1209: /* The purpose of D is to get around a quirk or bug in vax assembler
                   1210:    whereby -1 in a 64-bit immediate operand means 0x00000000ffffffff,
                   1211:    which is not a 64-bit minus one.  */
                   1212: 
                   1213: #define PRINT_OPERAND_PUNCT_VALID_P(CODE)                              \
                   1214:   ((CODE) == '#')
                   1215: 
                   1216: #define PRINT_OPERAND(FILE, X, CODE)  \
                   1217: { extern char *rev_cond_name ();                                       \
                   1218:   if (CODE == '#') fputc (ASM_DOUBLE_CHAR, FILE);                      \
                   1219:   else if (CODE == 'C')                                                        \
                   1220:     fputs (rev_cond_name (X), FILE);                                   \
                   1221:   else if (CODE == 'D' && GET_CODE (X) == CONST_INT && INTVAL (X) < 0) \
                   1222:     fprintf (FILE, "$0xffffffff%08x", INTVAL (X));                     \
                   1223:   else if (CODE == 'P' && GET_CODE (X) == CONST_INT)                   \
                   1224:     fprintf (FILE, "$%d", INTVAL (X) + 1);                             \
                   1225:   else if (CODE == 'N' && GET_CODE (X) == CONST_INT)                   \
                   1226:     fprintf (FILE, "$%d", ~ INTVAL (X));                               \
                   1227:   /* rotl instruction cannot deal with negative arguments.  */         \
                   1228:   else if (CODE == 'R' && GET_CODE (X) == CONST_INT)                   \
                   1229:     fprintf (FILE, "$%d", 32 - INTVAL (X));                            \
                   1230:   else if (CODE == 'H' && GET_CODE (X) == CONST_INT)                   \
                   1231:     fprintf (FILE, "$%d", 0xffff & ~ INTVAL (X));                      \
                   1232:   else if (CODE == 'h' && GET_CODE (X) == CONST_INT)                   \
                   1233:     fprintf (FILE, "$%d", (short) - INTVAL (x));                       \
                   1234:   else if (CODE == 'B' && GET_CODE (X) == CONST_INT)                   \
                   1235:     fprintf (FILE, "$%d", 0xff & ~ INTVAL (X));                                \
                   1236:   else if (CODE == 'b' && GET_CODE (X) == CONST_INT)                   \
                   1237:     fprintf (FILE, "$%d", 0xff & - INTVAL (X));                                \
                   1238:   else if (CODE == 'M' && GET_CODE (X) == CONST_INT)                   \
                   1239:     fprintf (FILE, "$%d", ~((1 << INTVAL (x)) - 1));                   \
                   1240:   else if (GET_CODE (X) == REG)                                                \
                   1241:     fprintf (FILE, "%s", reg_names[REGNO (X)]);                                \
                   1242:   else if (GET_CODE (X) == MEM)                                                \
                   1243:     output_address (XEXP (X, 0));                                      \
                   1244:   else if (GET_CODE (X) == CONST_DOUBLE && GET_MODE (X) == SFmode)     \
                   1245:     { REAL_VALUE_TYPE r; char dstr[30];                                        \
                   1246:       REAL_VALUE_FROM_CONST_DOUBLE (r, X);                             \
                   1247:       REAL_VALUE_TO_DECIMAL (r, "%.20e", dstr);                                \
                   1248:       fprintf (FILE, "$0f%s", dstr); }                                 \
                   1249:   else if (GET_CODE (X) == CONST_DOUBLE && GET_MODE (X) == DFmode)     \
                   1250:     { REAL_VALUE_TYPE r; char dstr[30];                                        \
                   1251:       REAL_VALUE_FROM_CONST_DOUBLE (r, X);                             \
                   1252:       REAL_VALUE_TO_DECIMAL (r, "%.20e", dstr);                                \
                   1253:       fprintf (FILE, "$0%c%s", ASM_DOUBLE_CHAR, dstr); }               \
                   1254:   else { putc ('$', FILE); output_addr_const (FILE, X); }}
                   1255: 
                   1256: /* Print a memory operand whose address is X, on file FILE.
                   1257:    This uses a function in output-vax.c.  */
                   1258: 
                   1259: #define PRINT_OPERAND_ADDRESS(FILE, ADDR)  \
                   1260:  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.