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

1.1       root        1: /* svr3.h  --  operating system specific defines to be used when
                      2:    targeting GCC for some generic System V Release 3 system.
                      3:    Copyright (C) 1991 Free Software Foundation, Inc.
                      4: 
                      5:    Written by Ron Guilmette ([email protected]).
                      6: 
                      7: This file is part of GNU CC.
                      8: 
                      9: GNU CC is free software; you can redistribute it and/or modify
                     10: it under the terms of the GNU General Public License as published by
                     11: the Free Software Foundation; either version 2, or (at your option)
                     12: any later version.
                     13: 
                     14: GNU CC is distributed in the hope that it will be useful,
                     15: but WITHOUT ANY WARRANTY; without even the implied warranty of
                     16: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     17: GNU General Public License for more details.
                     18: 
                     19: You should have received a copy of the GNU General Public License
                     20: along with GNU CC; see the file COPYING.  If not, write to
                     21: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
                     22: 
                     23:    To use this file, make up a file with a name like:
                     24: 
                     25:        ?????svr3.h
                     26: 
                     27:    where ????? is replaced by the name of the basic hardware that you
                     28:    are targeting for.  Then, in the file ?????svr3.h, put something
                     29:    like:
                     30: 
                     31:        #include "?????.h"
                     32:        #include "svr3.h"
                     33: 
                     34:    followed by any really system-specific defines (or overrides of
                     35:    defines) which you find that you need.  For example, CPP_PREDEFINES
                     36:    is defined here with only the defined -Dunix and -DSVR3.  You should
                     37:    probably override that in your target-specific ?????svr3.h file
                     38:    with a set of defines that includes these, but also contains an
                     39:    appropriate define for the type of hardware that you are targeting.
                     40: */
                     41: 
                     42: /* Define a symbol indicating that we are using svr3.h.  */
                     43: #define USING_SVR3_H
                     44: 
                     45: /* Define a symbol so that libgcc* can know what sort of operating
                     46:    environment and assembler syntax we are targeting for.  */
                     47: #define SVR3_target
                     48: 
                     49: /* Cpp, assembler, linker, library, and startfile spec's.  */
                     50: 
                     51: /* You should redefine CPP_PREDEFINES in any file which includes this one.
                     52:    The definition should be appropriate for the type of target system
                     53:    involved, and it should include any -A (assertion) options which are
                     54:    appropriate for the given target system.  */
                     55: 
                     56: #undef CPP_PREDEFINES
                     57: 
                     58: /* Output at beginning of assembler file.  */
                     59: /* The .file command should always begin the output.  */
                     60: 
                     61: #undef ASM_FILE_START
                     62: #define ASM_FILE_START(FILE)                                   \
                     63:   do { output_file_directive ((FILE), main_input_filename);    \
                     64:        if (optimize) ASM_FILE_START_1 (FILE);                  \
                     65:      } while (0)
                     66: 
                     67: /* By default, do nothing: a few machines support .optim, but not most.  */
                     68: #undef ASM_FILE_START_1
                     69: #define ASM_FILE_START_1(FILE)
                     70: 
                     71: /* This says how to output an assembler line
                     72:    to define a global common symbol.  */
                     73: /* We don't use ROUNDED because the standard compiler doesn't,
                     74:    and the linker gives error messages if a common symbol
                     75:    has more than one length value.  */
                     76: 
                     77: #undef ASM_OUTPUT_COMMON
                     78: #define ASM_OUTPUT_COMMON(FILE, NAME, SIZE, ROUNDED)  \
                     79: ( fputs (".comm ", (FILE)),                    \
                     80:   assemble_name ((FILE), (NAME)),              \
                     81:   fprintf ((FILE), ",%u\n", (SIZE)))
                     82: 
                     83: /* This says how to output an assembler line
                     84:    to define a local common symbol.  */
                     85: 
                     86: /* Note that using bss_section here caused errors
                     87:    in building shared libraries on system V.3.  */
                     88: #undef ASM_OUTPUT_LOCAL
                     89: #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE, ROUNDED)    \
                     90:   do {                                                 \
                     91:     int align = exact_log2 (ROUNDED);                  \
                     92:     if (align > 2) align = 2;                          \
                     93:     data_section ();                                   \
                     94:     ASM_OUTPUT_ALIGN ((FILE), align == -1 ? 2 : align);        \
                     95:     ASM_OUTPUT_LABEL ((FILE), (NAME));                 \
                     96:     fprintf ((FILE), "\t.set .,.+%u\n", (ROUNDED));    \
                     97:   } while (0)
                     98: 
                     99: #if 0 /* For now, let's leave these machine-specific.  */
                    100: /* Use crt1.o as a startup file and crtn.o as a closing file.  */
                    101: 
                    102: #define STARTFILE_SPEC  \
                    103:   "%{pg:gcrt1.o%s}%{!pg:%{p:mcrt1.o%s}%{!p:crt1.o%s}}"
                    104: 
                    105: #define LIB_SPEC "%{p:-L/usr/lib/libp}%{pg:-L/usr/lib/libp} -lc crtn.o%s"
                    106: 
                    107: /* Special flags for the linker.  I don't know what they do.  */
                    108: 
                    109: #define LINK_SPEC "%{T*} %{z:-lm}"
                    110: #endif
                    111: 
                    112: /* Allow #sccs in preprocessor.  */
                    113: 
                    114: #define SCCS_DIRECTIVE
                    115: 
                    116: /* Output #ident as a .ident.  */
                    117: 
                    118: #define ASM_OUTPUT_IDENT(FILE, NAME) \
                    119:   fprintf (FILE, "\t.ident \"%s\"\n", NAME);
                    120: 
                    121: /* Use periods rather than dollar signs in special g++ assembler names.  */
                    122: 
                    123: #define NO_DOLLAR_IN_LABEL
                    124: 
                    125: /* Implicit library calls should use memcpy, not bcopy, etc.  */
                    126: 
                    127: #define TARGET_MEM_FUNCTIONS
                    128: 
                    129: /* System V Release 3 uses COFF debugging info.  */
                    130: 
                    131: #define SDB_DEBUGGING_INFO
                    132: 
                    133: /* We don't want to output DBX debugging information.  */
                    134: 
                    135: #undef DBX_DEBUGGING_INFO
                    136: 
                    137: /* Define the actual types of some ANSI-mandated types.  These
                    138:    definitions should work for most SVR3 systems.  */
                    139: 
                    140: #undef SIZE_TYPE
                    141: #define SIZE_TYPE "unsigned int"
                    142: 
                    143: #undef PTRDIFF_TYPE
                    144: #define PTRDIFF_TYPE "int"
                    145: 
                    146: #undef WCHAR_TYPE
                    147: #define WCHAR_TYPE "long int"
                    148: 
                    149: #undef WCHAR_TYPE_SIZE
                    150: #define WCHAR_TYPE_SIZE BITS_PER_WORD
                    151: 
                    152: /* Assembler pseudos to introduce constants of various size.  These
                    153:    definitions hsould work for most svr3 systems.  */
                    154: 
                    155: #undef ASM_BYTE_OP
                    156: #define ASM_BYTE_OP "\t.byte"
                    157: 
                    158: /* This is how to output a reference to a user-level label named NAME.
                    159:    `assemble_name' uses this.
                    160: 
                    161:    For System V Release 3 the convention is to prepend a leading
                    162:    underscore onto user-level symbol names.  */
                    163: 
                    164: #undef ASM_OUTPUT_LABELREF
                    165: #define ASM_OUTPUT_LABELREF(FILE,NAME) fprintf (FILE, "_%s", NAME)
                    166: 
                    167: /* This is how to output an internal numbered label where
                    168:    PREFIX is the class of label and NUM is the number within the class.
                    169: 
                    170:    For most svr3 systems, the convention is that any symbol which begins
                    171:    with a period is not put into the linker symbol table by the assembler.  */
                    172: 
                    173: #undef ASM_OUTPUT_INTERNAL_LABEL
                    174: #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM)     \
                    175:   asm_fprintf (FILE, "%0L%s%d:\n", PREFIX, NUM)
                    176: 
                    177: /* This is how to store into the string LABEL
                    178:    the symbol_ref name of an internal numbered label where
                    179:    PREFIX is the class of label and NUM is the number within the class.
                    180:    This is suitable for output with `assemble_name'.
                    181: 
                    182:    For most svr3 systems, the convention is that any symbol which begins
                    183:    with a period is not put into the linker symbol table by the assembler.  */
                    184: 
                    185: #undef ASM_GENERATE_INTERNAL_LABEL
                    186: #define ASM_GENERATE_INTERNAL_LABEL(LABEL,PREFIX,NUM)  \
                    187:   sprintf (LABEL, "*%s%s%d", LOCAL_LABEL_PREFIX, PREFIX, NUM)
                    188: 
                    189: /* We want local labels to start with period if made with asm_fprintf.  */
                    190: #undef LOCAL_LABEL_PREFIX
                    191: #define LOCAL_LABEL_PREFIX "."
                    192: 
                    193: /* Support const sections and the ctors and dtors sections for g++.
                    194:    Note that there appears to be two different ways to support const
                    195:    sections at the moment.  You can either #define the symbol
                    196:    READONLY_DATA_SECTION (giving it some code which switches to the
                    197:    readonly data section) or else you can #define the symbols
                    198:    EXTRA_SECTIONS, EXTRA_SECTION_FUNCTIONS, SELECT_SECTION, and
                    199:    SELECT_RTX_SECTION.  We do both here just to be on the safe side.
                    200:    However, use of the const section is turned off by default
                    201:    unless the specific tm.h file turns it on by defining
                    202:    USE_CONST_SECTION as 1.  */
                    203: 
                    204: /* Define a few machine-specific details of the implementation of
                    205:    constructors.
                    206: 
                    207:    The __CTORS_LIST__ goes in the .init section.  Define CTOR_LIST_BEGIN
                    208:    and CTOR_LIST_END to contribute to the .init section an instruction to
                    209:    push a word containing 0 (or some equivalent of that).
                    210: 
                    211:    Define ASM_OUTPUT_CONSTRUCTOR to push the address of the constructor.  */
                    212: 
                    213: #define USE_CONST_SECTION      0
                    214: 
                    215: #define INIT_SECTION_ASM_OP     ".section\t.init"
                    216: #define FINI_SECTION_ASM_OP     ".section .fini,\"x\""
                    217: #define CONST_SECTION_ASM_OP   ".section\t.rodata, \"x\""
                    218: #define CTORS_SECTION_ASM_OP   INIT_SECTION_ASM_OP
                    219: #define DTORS_SECTION_ASM_OP    FINI_SECTION_ASM_OP
                    220: 
                    221: /* CTOR_LIST_BEGIN and CTOR_LIST_END are machine-dependent
                    222:    because they push on the stack.  */
                    223: 
                    224: #ifdef STACK_GROWS_DOWNWARD
                    225: 
                    226: /* Constructor list on stack is in reverse order.  Go to the end of the
                    227:    list and go backwards to call constructors in the right order.  */
                    228: #define DO_GLOBAL_CTORS_BODY                                   \
                    229: do {                                                           \
                    230:   func_ptr *p, *beg = alloca (0);                              \
                    231:   for (p = beg; *p; p++)                                       \
                    232:     ;                                                          \
                    233:   while (p != beg)                                             \
                    234:     (*--p) ();                                                 \
                    235: } while (0)
                    236: 
                    237: #else
                    238: 
                    239: /* Constructor list on stack is in correct order.  Just call them.  */
                    240: #define DO_GLOBAL_CTORS_BODY                                   \
                    241: do {                                                           \
                    242:   func_ptr *p, *beg = alloca (0);                              \
                    243:   for (p = beg; *p; )                                          \
                    244:     (*p++) ();                                                 \
                    245: } while (0)
                    246: 
                    247: #endif /* STACK_GROWS_DOWNWARD */
                    248: 
                    249: /* Add extra sections .init and .fini, in addition to .bss from att386.h. */
                    250: 
                    251: #undef EXTRA_SECTIONS
                    252: #define EXTRA_SECTIONS in_const, in_bss, in_init, in_fini
                    253: 
                    254: #undef EXTRA_SECTION_FUNCTIONS
                    255: #define EXTRA_SECTION_FUNCTIONS                                        \
                    256:   CONST_SECTION_FUNCTION                                       \
                    257:   BSS_SECTION_FUNCTION                                         \
                    258:   INIT_SECTION_FUNCTION                                                \
                    259:   FINI_SECTION_FUNCTION
                    260: 
                    261: #define BSS_SECTION_FUNCTION                                   \
                    262: void                                                           \
                    263: bss_section ()                                                 \
                    264: {                                                              \
                    265:   if (in_section != in_bss)                                    \
                    266:     {                                                          \
                    267:       fprintf (asm_out_file, "\t%s\n", BSS_SECTION_ASM_OP);    \
                    268:       in_section = in_bss;                                     \
                    269:     }                                                          \
                    270: }
                    271: 
                    272: #define INIT_SECTION_FUNCTION                                  \
                    273: void                                                           \
                    274: init_section ()                                                        \
                    275: {                                                              \
                    276:   if (in_section != in_init)                                   \
                    277:     {                                                          \
                    278:       fprintf (asm_out_file, "\t%s\n", INIT_SECTION_ASM_OP);   \
                    279:       in_section = in_init;                                    \
                    280:     }                                                          \
                    281: }
                    282: 
                    283: #define FINI_SECTION_FUNCTION                                  \
                    284: void                                                           \
                    285: fini_section ()                                                        \
                    286: {                                                              \
                    287:   if (in_section != in_fini)                                   \
                    288:     {                                                          \
                    289:       fprintf (asm_out_file, "\t%s\n", FINI_SECTION_ASM_OP);   \
                    290:       in_section = in_fini;                                    \
                    291:     }                                                          \
                    292: }
                    293: 
                    294: #define READONLY_DATA_SECTION() const_section ()
                    295: 
                    296: #define CONST_SECTION_FUNCTION                                         \
                    297: void                                                                   \
                    298: const_section ()                                                       \
                    299: {                                                                      \
                    300:   extern void text_section();                                          \
                    301:   if (!USE_CONST_SECTION)                                              \
                    302:     text_section();                                                    \
                    303:   else if (in_section != in_const)                                     \
                    304:     {                                                                  \
                    305:       fprintf (asm_out_file, "%s\n", CONST_SECTION_ASM_OP);            \
                    306:       in_section = in_const;                                           \
                    307:     }                                                                  \
                    308: }
                    309: 
                    310: /* The ctors and dtors sections are not normally put into use 
                    311:    by EXTRA_SECTIONS and EXTRA_SECTION_FUNCTIONS as defined in svr3.h,
                    312:    but it can't hurt to define these macros for whatever systems use them.  */
                    313: #define CTORS_SECTION_FUNCTION                                         \
                    314: void                                                                   \
                    315: ctors_section ()                                                       \
                    316: {                                                                      \
                    317:   if (in_section != in_ctors)                                          \
                    318:     {                                                                  \
                    319:       fprintf (asm_out_file, "%s\n", CTORS_SECTION_ASM_OP);            \
                    320:       in_section = in_ctors;                                           \
                    321:     }                                                                  \
                    322: }
                    323: 
                    324: #define DTORS_SECTION_FUNCTION                                         \
                    325: void                                                                   \
                    326: dtors_section ()                                                       \
                    327: {                                                                      \
                    328:   if (in_section != in_dtors)                                          \
                    329:     {                                                                  \
                    330:       fprintf (asm_out_file, "%s\n", DTORS_SECTION_ASM_OP);            \
                    331:       in_section = in_dtors;                                           \
                    332:     }                                                                  \
                    333: }
                    334: 
                    335: /* This is machine-dependent
                    336:    because it needs to push something on the stack.  */
                    337: #undef ASM_OUTPUT_CONSTRUCTOR
                    338: 
                    339: /* A C statement (sans semicolon) to output an element in the table of
                    340:    global destructors.  */
                    341: #define ASM_OUTPUT_DESTRUCTOR(FILE,NAME)                                       \
                    342:   do {                                                                 \
                    343:     fini_section ();                                                   \
                    344:     fprintf (FILE, "%s\t ", ASM_LONG);                                 \
                    345:     assemble_name (FILE, NAME);                                        \
                    346:     fprintf (FILE, "\n");                                              \
                    347:   } while (0)
                    348: 
                    349: /* A C statement or statements to switch to the appropriate
                    350:    section for output of DECL.  DECL is either a `VAR_DECL' node
                    351:    or a constant of some sort.  RELOC indicates whether forming
                    352:    the initial value of DECL requires link-time relocations.  */
                    353: 
                    354: #define SELECT_SECTION(DECL,RELOC)                                     \
                    355: {                                                                      \
                    356:   if (TREE_CODE (DECL) == STRING_CST)                                  \
                    357:     {                                                                  \
                    358:       if (! flag_writable_strings)                                     \
                    359:        const_section ();                                               \
                    360:       else                                                             \
                    361:        data_section ();                                                \
                    362:     }                                                                  \
                    363:   else if (TREE_CODE (DECL) == VAR_DECL)                               \
                    364:     {                                                                  \
                    365:       if ((0 && RELOC) /* should be (flag_pic && RELOC) */             \
                    366:          || !TREE_READONLY (DECL) || TREE_SIDE_EFFECTS (DECL))         \
                    367:        data_section ();                                                \
                    368:       else                                                             \
                    369:        const_section ();                                               \
                    370:     }                                                                  \
                    371:   else                                                                 \
                    372:     const_section ();                                                  \
                    373: }
                    374: 
                    375: /* A C statement or statements to switch to the appropriate
                    376:    section for output of RTX in mode MODE.  RTX is some kind
                    377:    of constant in RTL.  The argument MODE is redundant except
                    378:    in the case of a `const_int' rtx.  Currently, these always
                    379:    go into the const section.  */
                    380: 
                    381: #define SELECT_RTX_SECTION(MODE,RTX) const_section()

unix.superglobalmegacorp.com

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