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

1.1     ! root        1: /* Target definitions for GNU compiler for Sparc running System V.4
        !             2:    Copyright (C) 1991, 1992 Free Software Foundation, Inc.
        !             3: 
        !             4:    Written by Ron Guilmette ([email protected]).
        !             5: 
        !             6: This file is part of GNU CC.
        !             7: 
        !             8: GNU CC is free software; you can redistribute it and/or modify
        !             9: it under the terms of the GNU General Public License as published by
        !            10: the Free Software Foundation; either version 2, or (at your option)
        !            11: any later version.
        !            12: 
        !            13: GNU CC is distributed in the hope that it will be useful,
        !            14: but WITHOUT ANY WARRANTY; without even the implied warranty of
        !            15: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
        !            16: GNU General Public License for more details.
        !            17: 
        !            18: You should have received a copy of the GNU General Public License
        !            19: along with GNU CC; see the file COPYING.  If not, write to
        !            20: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
        !            21: 
        !            22: #include "sparc/sparc.h"
        !            23: 
        !            24: /* Undefine some symbols which are defined in "sparc.h" but which are
        !            25:    appropriate only for SunOS 4.x, and not for svr4.  */
        !            26: 
        !            27: #undef DBX_DEBUGGING_INFO
        !            28: #undef WORD_SWITCH_TAKES_ARG
        !            29: #undef SELECT_SECTION
        !            30: #undef ASM_DECLARE_FUNCTION_NAME
        !            31: #undef TEXT_SECTION_ASM_OP
        !            32: #undef DATA_SECTION_ASM_OP
        !            33: 
        !            34: #include "svr4.h"
        !            35: 
        !            36: /* Undefined some symbols which are defined in "svr4.h" but which are
        !            37:    appropriate only for typical svr4 systems, but not for the specific
        !            38:    case of svr4 running on a Sparc.  */
        !            39: 
        !            40: #undef CTORS_SECTION_ASM_OP
        !            41: #undef DTORS_SECTION_ASM_OP
        !            42: #undef INIT_SECTION_ASM_OP
        !            43: #undef CONST_SECTION_ASM_OP
        !            44: #undef TYPE_OPERAND_FMT
        !            45: #undef PUSHSECTION_FORMAT
        !            46: #undef STRING_ASM_OP
        !            47: #undef COMMON_ASM_OP
        !            48: #undef SKIP_ASM_OP
        !            49: #undef SET_ASM_OP      /* Has no equivalent.  See ASM_OUTPUT_DEF below.  */
        !            50: 
        !            51: /* Provide a set of pre-definitions and pre-assertions appropriate for
        !            52:    the Sparc running svr4.  __svr4__ is our extension.  */
        !            53: 
        !            54: #define CPP_PREDEFINES \
        !            55:   "-Dsparc -Dunix -D__svr4__ \
        !            56:    -Asystem(unix) -Asystem(svr4) -Acpu(sparc) -Amachine(sparc) \
        !            57:    -D__GCC_NEW_VARARGS__"
        !            58: 
        !            59: /* The specialized code which needs to appear in the .init section prior
        !            60:    to the prologue code for `__do_global_ctors' (see crtstuff.c).
        !            61: 
        !            62:    On Sparcs running svr4, the /usr/ccs/lib/crti.o file (with gets linked
        !            63:    in prior to the crtbegin.o file) has a single `save' instruction in its
        !            64:    .init section.  That `save' instruction tries to setup a stack frame for
        !            65:    the sake of any subsequent code in the .init section.  Unfortunately,
        !            66:    the size it uses for the stack frame is only a guess, and is not really
        !            67:    adequate for our purposes.  More importantly, we independently put our
        !            68:    own standard function prologue (for __do_global_ctors) into the .init
        !            69:    section and that function prologue includes its own `save' instruction!
        !            70:    Thus, unless we do something to correct the situation, we'll get *two*
        !            71:    stack frames allocated when crt0.o calls the code in the .init section,
        !            72:    and havoc will ensue.  The following macro definition prevents such woes.
        !            73: */
        !            74: 
        !            75: #define INIT_SECTION_PREAMBLE  asm ("restore")
        !            76: 
        !            77: /* This is the string used to begin an assembly language comment for the
        !            78:    Sparc/svr4 assembler.  */
        !            79: 
        !            80: #define ASM_COMMENT_START "!"
        !            81: 
        !            82: /* Define the names of various pseudo-op used by the Sparc/svr4 assembler.
        !            83:    Note that many of these are different from the typical pseudo-ops used
        !            84:    by most svr4 assemblers.  That is probably due to a (misguided?) attempt
        !            85:    to keep the Sparc/svr4 assembler somewhat compatible with the Sparc/SunOS
        !            86:    assembler.  */
        !            87: 
        !            88: #define STRING_ASM_OP          ".asciz"
        !            89: #define COMMON_ASM_OP          ".common"
        !            90: #define SKIP_ASM_OP            ".skip"
        !            91: #define UNALIGNED_INT_ASM_OP   ".uaword"
        !            92: #define UNALIGNED_SHORT_ASM_OP ".uahalf"
        !            93: #define PUSHSECTION_ASM_OP     ".pushsection"
        !            94: #define POPSECTION_ASM_OP      ".popsection"
        !            95: 
        !            96: /* This is the format used to print the second operand of a .type pseudo-op
        !            97:    for the Sparc/svr4 assembler.  */
        !            98: 
        !            99: #define TYPE_OPERAND_FMT      "#%s"
        !           100: 
        !           101: /* This is the format used to print a .pushsection pseudo-op (and its operand)
        !           102:    for the Sparc/svr4 assembler.  */
        !           103: 
        !           104: #define PUSHSECTION_FORMAT     "\t%s\t\"%s\"\n"
        !           105: 
        !           106: #undef ASM_OUTPUT_CASE_LABEL
        !           107: #define ASM_OUTPUT_CASE_LABEL(FILE, PREFIX, NUM, JUMPTABLE)            \
        !           108: do { ASM_OUTPUT_ALIGN ((FILE), 2);                                     \
        !           109:      ASM_OUTPUT_INTERNAL_LABEL ((FILE), PREFIX, NUM);                  \
        !           110:    } while (0)
        !           111: 
        !           112: /* This is how to equate one symbol to another symbol.  The syntax used is
        !           113:    `SYM1=SYM2'.  Note that this is different from the way equates are done
        !           114:    with most svr4 assemblers, where the syntax is `.set SYM1,SYM2'.  */
        !           115: 
        !           116: #define ASM_OUTPUT_DEF(FILE,LABEL1,LABEL2)                             \
        !           117:  do {  fprintf ((FILE), "\t");                                         \
        !           118:        assemble_name (FILE, LABEL1);                                   \
        !           119:        fprintf (FILE, " = ");                                          \
        !           120:        assemble_name (FILE, LABEL2);                                   \
        !           121:        fprintf (FILE, "\n");                                           \
        !           122:   } while (0)
        !           123: 
        !           124: /* Define how the Sparc registers should be numbered for Dwarf output.
        !           125:    The numbering provided here should be compatible with the native
        !           126:    svr4 SDB debugger in the Sparc/svr4 reference port.  The numbering
        !           127:    is as follows:
        !           128: 
        !           129:    Assembly name       gcc internal regno      Dwarf regno
        !           130:    ----------------------------------------------------------
        !           131:    g0-g7               0-7                     0-7
        !           132:    o0-o7               8-15                    8-15
        !           133:    l0-l7               16-23                   16-23
        !           134:    i0-i7               24-31                   24-31
        !           135:    f0-f31              32-63                   40-71
        !           136: */
        !           137: 
        !           138: #define DBX_REGISTER_NUMBER(REGNO)                                     \
        !           139:   (((REGNO) < 32) ? (REGNO)                                            \
        !           140:    : ((REGNO) < 63) ? ((REGNO) + 8)                                    \
        !           141:    : (abort (), 0))
        !           142: 
        !           143: /* A set of symbol definitions for assembly pseudo-ops which will
        !           144:    get us switched to various sections of interest.  These are used
        !           145:    in all places where we simply want to switch to a section, and
        !           146:    *not* to push the previous section name onto the assembler's
        !           147:    section names stack (as we do often in dwarfout.c).  */
        !           148: 
        !           149: #define TEXT_SECTION_ASM_OP    ".section\t\".text\""
        !           150: #define DATA_SECTION_ASM_OP    ".section\t\".data\""
        !           151: #define BSS_SECTION_ASM_OP     ".section\t\".bss\""
        !           152: #define CONST_SECTION_ASM_OP   ".section\t\".rodata\""
        !           153: #define INIT_SECTION_ASM_OP    ".section\t\".init\",#alloc"
        !           154: #define CTORS_SECTION_ASM_OP    ".section\t\".ctors\",#alloc"
        !           155: #define DTORS_SECTION_ASM_OP    ".section\t\".dtors\",#alloc"
        !           156: 
        !           157: /* If the host and target formats match, output the floats as hex.  */
        !           158: #if HOST_FLOAT_FORMAT == TARGET_FLOAT_FORMAT
        !           159: #if defined (HOST_WORDS_BIG_ENDIAN) == WORDS_BIG_ENDIAN
        !           160: 
        !           161: /* This is how to output assembly code to define a `float' constant.
        !           162:    We always have to use a .long pseudo-op to do this because the native
        !           163:    SVR4 ELF assembler is buggy and it generates incorrect values when we
        !           164:    try to use the .float pseudo-op instead.  */
        !           165: 
        !           166: #undef ASM_OUTPUT_FLOAT
        !           167: #define ASM_OUTPUT_FLOAT(FILE,VALUE)                                   \
        !           168: do { long value;                                                       \
        !           169:      REAL_VALUE_TO_TARGET_SINGLE ((VALUE), value);                     \
        !           170:      fprintf((FILE), "\t.long\t0x%x\n", value);                                \
        !           171:    } while (0)
        !           172: 
        !           173: /* This is how to output assembly code to define a `double' constant.
        !           174:    We always have to use a pair of .long pseudo-ops to do this because
        !           175:    the native SVR4 ELF assembler is buggy and it generates incorrect
        !           176:    values when we try to use the the .double pseudo-op instead.  */
        !           177: 
        !           178: #undef ASM_OUTPUT_DOUBLE
        !           179: #define ASM_OUTPUT_DOUBLE(FILE,VALUE)                                  \
        !           180: do { long value[2];                                                    \
        !           181:      REAL_VALUE_TO_TARGET_DOUBLE ((VALUE), value);                     \
        !           182:      fprintf((FILE), "\t.long\t0x%x\n", value[0]);                     \
        !           183:      fprintf((FILE), "\t.long\t0x%x\n", value[1]);                     \
        !           184:    } while (0)
        !           185: 
        !           186: #endif /* word order matches */
        !           187: #endif /* HOST_FLOAT_FORMAT == TARGET_FLOAT_FORMAT */
        !           188: 
        !           189: /* This is how to output an assembler line defining a `long double'
        !           190:    constant.  */
        !           191: 
        !           192: #undef ASM_OUTPUT_LONG_DOUBLE
        !           193: #define ASM_OUTPUT_LONG_DOUBLE(FILE,VALUE)                             \
        !           194: do { long value[4];                                                    \
        !           195:      REAL_VALUE_TO_TARGET_LONG_DOUBLE ((VALUE), value);                        \
        !           196:      fprintf((FILE), "\t.long\t0x%x\n", value[0]);                     \
        !           197:      fprintf((FILE), "\t.long\t0x%x\n", value[1]);                     \
        !           198:      fprintf((FILE), "\t.long\t0x%x\n", value[2]);                     \
        !           199:      fprintf((FILE), "\t.long\t0x%x\n", value[3]);                     \
        !           200:    } while (0)

unix.superglobalmegacorp.com

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