Annotation of GNUtools/cc/config/ns32k/encore.h, revision 1.1

1.1     ! root        1: /* Definitions of target machine for GNU compiler.  ENCORE NS32000 version.
        !             2:    Copyright (C) 1988 Free Software Foundation, Inc.
        !             3:    Adapted by Robert Brown ([email protected]) from the Sequent
        !             4:      version by Michael Tiemann ([email protected]).
        !             5: 
        !             6: This file is part of GNU CC.
        !             7: 
        !             8: GNU CC is free software; you can redistribute it and/or modify
        !             9: it under the terms of the GNU General Public License as published by
        !            10: the Free Software Foundation; either version 2, or (at your option)
        !            11: any later version.
        !            12: 
        !            13: GNU CC is distributed in the hope that it will be useful,
        !            14: but WITHOUT ANY WARRANTY; without even the implied warranty of
        !            15: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
        !            16: GNU General Public License for more details.
        !            17: 
        !            18: You should have received a copy of the GNU General Public License
        !            19: along with GNU CC; see the file COPYING.  If not, write to
        !            20: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
        !            21: 
        !            22: 
        !            23: #define EXTERNAL_PREFIX '?'
        !            24: #define IMMEDIATE_PREFIX '$'
        !            25: 
        !            26: #include "ns32k/ns32k.h"
        !            27: 
        !            28: #define SDB_DEBUGGING_INFO
        !            29: #undef DBX_REGISTER_NUMBER
        !            30: #define DBX_REGISTER_NUMBER(REGNO) (REGNO)
        !            31: 
        !            32: /* Cause long-jump assembler to be used,
        !            33:    since otherwise some files fail to be assembled right.  */
        !            34: #define ASM_SPEC "-j"
        !            35: 
        !            36: #undef ASM_FILE_START
        !            37: #undef ASM_GENERATE_INTERNAL_LABEL
        !            38: #undef ASM_OUTPUT_ADDR_DIFF_ELT
        !            39: #undef ASM_OUTPUT_ALIGN
        !            40: #undef ASM_OUTPUT_ASCII
        !            41: #undef ASM_OUTPUT_DOUBLE
        !            42: #undef ASM_OUTPUT_INT
        !            43: #undef ASM_OUTPUT_INTERNAL_LABEL
        !            44: #undef ASM_OUTPUT_LOCAL
        !            45: #undef CPP_PREDEFINES
        !            46: #undef FUNCTION_BOUNDARY
        !            47: #undef PRINT_OPERAND
        !            48: #undef PRINT_OPERAND_ADDRESS
        !            49: #undef TARGET_VERSION
        !            50: #undef FUNCTION_PROFILER
        !            51: #undef ASM_OUTPUT_LABELREF_AS_INT
        !            52: 
        !            53: #define TARGET_DEFAULT 9  /* 32332 with 32081.  */
        !            54: #define TARGET_VERSION fprintf (stderr, " (32000, Encore syntax)");
        !            55: /* Note Encore does not standardly do -Dencore.  */
        !            56: /* budd: should have a -ns32332 (or -apc) switch! but no harm for now */
        !            57: #define CPP_PREDEFINES "-Dns32000 -Dn16 -Dns16000 -Dns32332 -Dunix -Asystem(unix) -Acpu(ns32k) -Amachine(ns32k)"
        !            58: 
        !            59: /* Ignore certain cpp directives used in header files on sysV.  */
        !            60: #define SCCS_DIRECTIVE
        !            61: 
        !            62: /* Output #ident as a .ident.  */
        !            63: #define ASM_OUTPUT_IDENT(FILE, NAME) fprintf (FILE, "\t.ident \"%s\"\n", NAME);
        !            64: 
        !            65: /* The .file command should always begin the output.  */
        !            66: #define ASM_FILE_START(FILE) \
        !            67: output_file_directive ((FILE), main_input_filename)
        !            68: 
        !            69: #define FUNCTION_BOUNDARY 128          /* speed optimization */
        !            70: 
        !            71: /*
        !            72:  *  The Encore assembler uses ".align 2" to align on 2-byte boundaries.
        !            73:  */
        !            74: 
        !            75: #define ASM_OUTPUT_ALIGN(FILE,LOG)                                     \
        !            76:        fprintf (FILE, "\t.align %d\n", 1 << (LOG))
        !            77: 
        !            78: /* The Encore assembler doesn't seem to accept the usual second argument
        !            79:    and warns that .align may not work in the text section if optimization
        !            80:    is on.  */
        !            81: #undef ASM_OUTPUT_ALIGN_CODE
        !            82: #define ASM_OUTPUT_ALIGN_CODE(FILE)
        !            83: 
        !            84: /*
        !            85:  *  Internal labels are prefixed with a period.
        !            86:  */
        !            87: 
        !            88: #define ASM_GENERATE_INTERNAL_LABEL(LABEL,PREFIX,NUM)                  \
        !            89:        sprintf (LABEL, "*.%s%d", PREFIX, NUM)
        !            90: #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM)                     \
        !            91:        fprintf (FILE, ".%s%d:\n", PREFIX, NUM)
        !            92: #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL)                     \
        !            93:        fprintf (FILE, "\t.double .L%d-.LI%d\n", VALUE, REL)
        !            94: 
        !            95: /*
        !            96:  *  Different syntax for integer constants, double constants, and
        !            97:  *  uninitialized locals.
        !            98:  */
        !            99: 
        !           100: #define ASM_OUTPUT_INT(FILE,VALUE)                             \
        !           101: ( fprintf (FILE, "\t.double "),                                        \
        !           102:   output_addr_const (FILE, (VALUE)),                           \
        !           103:   fprintf (FILE, "\n"))
        !           104: 
        !           105: #define ASM_OUTPUT_LABELREF_AS_INT(STREAM, NAME)                       \
        !           106: do {                                                                   \
        !           107:   fprintf (STREAM, "\t.double\t");                                     \
        !           108:   ASM_OUTPUT_LABELREF (STREAM, NAME);                                  \
        !           109:   fprintf (STREAM, "\n");                                              \
        !           110: } while (0)
        !           111: 
        !           112: 
        !           113: #define ASM_OUTPUT_DOUBLE(FILE,VALUE)                          \
        !           114:  fprintf (FILE, "\t.long 0f%.20e\n", (VALUE))
        !           115: 
        !           116: #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE, ROUNDED)            \
        !           117: ( fputs ("\t.bss ", (FILE)),                                   \
        !           118:   assemble_name ((FILE), (NAME)),                              \
        !           119:   fprintf ((FILE), ",%u,%u\n", (SIZE), (ROUNDED)))
        !           120: 
        !           121:  /*
        !           122:   *  Encore assembler can't handle huge string constants like the one in
        !           123:   *  gcc.c.  If the default routine in varasm.c were more conservative, this
        !           124:   *  code could be eliminated.  It starts a new .ascii directive every 40
        !           125:   *  characters.
        !           126:   */
        !           127: 
        !           128: #define ASM_OUTPUT_ASCII(file, p, size)                        \
        !           129: {                                                      \
        !           130:   int i;                                               \
        !           131:   for (i = 0; i < (size); i++)                         \
        !           132:     {                                                  \
        !           133:       register int c = (p)[i];                         \
        !           134:       if ((i / 40) * 40 == i)                          \
        !           135:       if (i == 0)                                      \
        !           136:         fprintf ((file), "\t.ascii \"");               \
        !           137:       else                                             \
        !           138:         fprintf ((file), "\"\n\t.ascii \"");           \
        !           139:       if (c == '\"' || c == '\\')                      \
        !           140:         putc ('\\', (file));                           \
        !           141:       if (c >= ' ' && c < 0177)                                \
        !           142:         putc (c, (file));                              \
        !           143:       else                                             \
        !           144:         {                                              \
        !           145:           fprintf ((file), "\\%o", c);                 \
        !           146:           if (i < (size) - 1                           \
        !           147:               && (p)[i + 1] >= '0' && (p)[i + 1] <= '9')\
        !           148:           fprintf ((file), "\"\n\t.ascii \"");         \
        !           149:         }                                              \
        !           150:     }                                                  \
        !           151:   fprintf ((file), "\"\n");                            \
        !           152: }
        !           153: 
        !           154: /* Modify syntax of jsr instructions.  */
        !           155: #define CALL_MEMREF_IMPLICIT
        !           156: 
        !           157: #define NO_ABSOLUTE_PREFIX_IF_SYMBOLIC
        !           158: 
        !           159: #define PRINT_OPERAND(FILE, X, CODE) print_operand(FILE, X, CODE)
        !           160: 
        !           161: #define PRINT_OPERAND_ADDRESS(FILE, ADDR)  print_operand_address(FILE, ADDR)
        !           162: 
        !           163: /* Change the way in which data is allocated and initialized on the
        !           164:    encore so that both private and shared data are supported.  Shared data
        !           165:    that is initialized must be contained in the ".shrdata" section
        !           166:    of the program.  This is accomplished by defining the SHARED_SECTION_ASM_OP
        !           167:    macro.  Share data that is simply allocated, and not initialized must
        !           168:    be prefixed with the ".shrcomm" or ".shrbss" pseudo op, for common or
        !           169:    local data respectively.  This is accomplished by redefining the
        !           170:    ASM_OUTPUT_COMMON and ASM_OUTPUT_LOCAL macros. */
        !           171:     
        !           172: /* Assembler pseudo-op for shared data segment. */
        !           173: 
        !           174: #define SHARED_SECTION_ASM_OP ".shrdata"
        !           175: 
        !           176: /* This says how to output an assembler line
        !           177:    to define a shared common symbol. */
        !           178: 
        !           179: #define ASM_OUTPUT_SHARED_COMMON(FILE, NAME, SIZE, ROUNDED) \
        !           180: ( fputs (".shrcomm ", (FILE)),                 \
        !           181:   assemble_name ((FILE), (NAME)),              \
        !           182:   fprintf ((FILE), ",%d\n", (ROUNDED)))
        !           183: 
        !           184: /* This says how to output an assembler line
        !           185:    to define a shared local symbol. */
        !           186: 
        !           187: #define ASM_OUTPUT_SHARED_LOCAL(FILE, NAME, SIZE, ROUNDED) \
        !           188: ( fputs ("\t.shrbss ", (FILE)),                                \
        !           189:   assemble_name ((FILE), (NAME)),                      \
        !           190:   fprintf ((FILE), ",%d,%d\n", (SIZE), (ROUNDED)))
        !           191: 
        !           192: #define FUNCTION_PROFILER(FILE, LABELNO)  \
        !           193:    fprintf (FILE, "\taddr .LP%d,r0\n\tjsr mcount\n", (LABELNO))
        !           194: 
        !           195: #define ENCORE_ASM

unix.superglobalmegacorp.com

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