Annotation of GNUtools/cc/config/m68k/3b1.h, revision 1.1

1.1     ! root        1: /* Definitions of target machine for GNU compiler.
        !             2:    AT&T UNIX PC version (pc7300, 3b1)
        !             3: 
        !             4:    Written by Alex Crain
        !             5:    bug reports to [email protected]
        !             6: 
        !             7:    Copyright (C) 1987 Free Software Foundation, Inc.
        !             8: 
        !             9: This file is part of GNU CC.
        !            10: 
        !            11: GNU CC is free software; you can redistribute it and/or modify
        !            12: it under the terms of the GNU General Public License as published by
        !            13: the Free Software Foundation; either version 2, or (at your option)
        !            14: any later version.
        !            15: 
        !            16: GNU CC is distributed in the hope that it will be useful,
        !            17: but WITHOUT ANY WARRANTY; without even the implied warranty of
        !            18: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
        !            19: GNU General Public License for more details.
        !            20: 
        !            21: You should have received a copy of the GNU General Public License
        !            22: along with GNU CC; see the file COPYING.  If not, write to
        !            23: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
        !            24: 
        !            25: #define SGS_SWITCH_TABLES      /* Different switch table handling */
        !            26: 
        !            27: #include "m68k/hp320.h"
        !            28: 
        !            29: /* See m68k.h.  0 means 680[01]0 with no 68881.  */
        !            30: 
        !            31: #undef TARGET_DEFAULT
        !            32: #define        TARGET_DEFAULT 0
        !            33: 
        !            34: /* Don't try using XFmode.  */
        !            35: #undef LONG_DOUBLE_TYPE_SIZE
        !            36: #define LONG_DOUBLE_TYPE_SIZE 64
        !            37: 
        !            38: /* -m68020 requires special flags to the assembler.  */
        !            39: 
        !            40: #undef ASM_SPEC
        !            41: #define ASM_SPEC "%{m68020:-68020}%{!m68020:-68010} %{m68881:-68881}"
        !            42: 
        !            43: /* we use /lib/libp/lib*  when profiling */
        !            44: 
        !            45: #undef LIB_SPEC
        !            46: #define LIB_SPEC "%{!shlib:%{p:-L/lib/libp} %{pg:-L/lib/libp} -lc}"
        !            47: 
        !            48: /* shared libraries need to use crt0s.o  */
        !            49: 
        !            50: #undef STARTFILE_SPEC
        !            51: #define STARTFILE_SPEC \
        !            52:   "%{!shlib:%{pg:mcrt0.o%s}%{!pg:%{p:mcrt0.o%s}%{!p:crt0.o%s}}}\
        !            53:    %{shlib:crt0s.o%s shlib.ifile%s} "
        !            54: 
        !            55: /* cpp has to support a #sccs directive for the /usr/include files */
        !            56: 
        !            57: #define SCCS_DIRECTIVE
        !            58: 
        !            59: /* Make output for SDB.  */
        !            60: 
        !            61: #define SDB_DEBUGGING_INFO
        !            62: 
        !            63: /* The .file command should always begin the output.  */
        !            64: 
        !            65: #undef ASM_FILE_START
        !            66: #define ASM_FILE_START(FILE) \
        !            67: output_file_directive ((FILE), main_input_filename)
        !            68: 
        !            69: /* Don't try to define `gcc_compiled.' since the assembler might not
        !            70:    accept symbols with periods and GDB doesn't run on this machine anyway.  */
        !            71: #define ASM_IDENTIFY_GCC(FILE)
        !            72: 
        !            73: /* Define __HAVE_68881__ in preprocessor if -m68881 is specified.
        !            74:    This will control the use of inline 68881 insns in certain macros.  */
        !            75: 
        !            76: #undef CPP_SPEC
        !            77: #define CPP_SPEC "%{m68881:-D__HAVE_68881__}"
        !            78: 
        !            79: /* Names to predefine in the preprocessor for this target machine.  */
        !            80: /* [email protected] says mc68000 and m68k should not be here.  */
        !            81: 
        !            82: #undef CPP_PREDEFINES
        !            83: #define CPP_PREDEFINES "-Dmc68k -Dunix -Dunixpc -D__motorola__ -Asystem(unix)  -Asystem(svr3) -Acpu(m68k) -Amachine(m68k)"
        !            84: 
        !            85: #undef REGISTER_NAMES
        !            86: #define REGISTER_NAMES \
        !            87: {"%d0", "%d1", "%d2", "%d3", "%d4", "%d5", "%d6", "%d7",       \
        !            88:  "%a0", "%a1", "%a2", "%a3", "%a4", "%a5", "%fp", "%sp",       \
        !            89:  "%f0", "%f1", "%f2", "%f3", "%f4", "%f5", "%f6", "%f7"}
        !            90: 
        !            91: /* Specify how to pad function arguments.
        !            92:    Value should be `upward', `downward' or `none'.
        !            93:    Same as the default, except no padding for large or variable-size args.  */
        !            94: 
        !            95: #define FUNCTION_ARG_PADDING(MODE, TYPE)                               \
        !            96:   (((MODE) == BLKmode                                                  \
        !            97:     ? ((TYPE) && TREE_CODE (TYPE_SIZE (TYPE)) == INTEGER_CST           \
        !            98:        && int_size_in_bytes (TYPE) < PARM_BOUNDARY / BITS_PER_UNIT)    \
        !            99:     : GET_MODE_BITSIZE (MODE) < PARM_BOUNDARY)                         \
        !           100:    ? downward : none)
        !           101: 
        !           102: /* Override part of the obstack macros.  */
        !           103: 
        !           104: #define __PTR_TO_INT(P) ((int)(P))
        !           105: #define __INT_TO_PTR(P) ((char *)(P))
        !           106: 
        !           107: /* The 3b1 does not have `atexit'.  */
        !           108: 
        !           109: #undef HAVE_ATEXIT
        !           110: 
        !           111: /* Override parts of m68k.h to fit the SGS-3b1 assembler.  */
        !           112: 
        !           113: #undef TARGET_VERSION
        !           114: #undef ASM_FORMAT_PRIVATE_NAME
        !           115: #undef ASM_OUTPUT_DOUBLE
        !           116: #undef ASM_OUTPUT_FLOAT
        !           117: #undef ASM_OUTPUT_ALIGN
        !           118: #undef ASM_OUTPUT_SOURCE_FILENAME
        !           119: #undef ASM_OUTPUT_SOURCE_LINE
        !           120: #undef PRINT_OPERAND_ADDRESS
        !           121: #undef ASM_GENERATE_INTERNAL_LABEL
        !           122: #undef FUNCTION_PROFILER
        !           123: #undef ASM_OUTPUT_ADDR_VEC_ELT
        !           124: #undef ASM_OUTPUT_ADDR_DIFF_ELT
        !           125: #undef ASM_OUTPUT_INTERNAL_LABEL
        !           126: #undef ASM_OUTPUT_OPCODE
        !           127: #undef ASM_OUTPUT_LOCAL
        !           128: #undef ASM_OUTPUT_LABELREF
        !           129: #undef ASM_OUTPUT_ASCII
        !           130: 
        !           131: #define TARGET_VERSION fprintf (stderr, " (68k, SGS/AT&T unixpc syntax)");
        !           132: 
        !           133: /* Store in OUTPUT a string (made with alloca) containing
        !           134:    an assembler-name for a local static variable named NAME.
        !           135:    LABELNO is an integer which is different for each call.  */
        !           136: 
        !           137: #define ASM_FORMAT_PRIVATE_NAME(OUTPUT, NAME, LABELNO) \
        !           138: ( (OUTPUT) = (char *) alloca (strlen ((NAME)) + 12),   \
        !           139:   sprintf ((OUTPUT), "%s_%%%d", (NAME), (LABELNO)))
        !           140: 
        !           141: /* The unixpc doesn't know about double's and float's */
        !           142: 
        !           143: #define ASM_OUTPUT_DOUBLE(FILE,VALUE)  \
        !           144: do { long l[2];                                                \
        !           145:      REAL_VALUE_TO_TARGET_DOUBLE (VALUE, l);           \
        !           146:      fprintf (FILE, "\tlong 0x%x,0x%x\n", l[0], l[1]); \
        !           147:    } while (0)
        !           148: 
        !           149: #undef ASM_OUTPUT_LONG_DOUBLE
        !           150: #define ASM_OUTPUT_LONG_DOUBLE(FILE,VALUE)                             \
        !           151: do { long l[3];                                                                \
        !           152:      REAL_VALUE_TO_TARGET_LONG_DOUBLE (VALUE, l);                      \
        !           153:      fprintf (FILE, "\tlong 0x%x,0x%x,0x%x\n", l[0], l[1], l[2]);      \
        !           154:    } while (0)
        !           155: 
        !           156: /* This is how to output an assembler line defining a `float' constant.  */
        !           157: 
        !           158: #define ASM_OUTPUT_FLOAT(FILE,VALUE)  \
        !           159: do { long l;                                   \
        !           160:      REAL_VALUE_TO_TARGET_SINGLE (VALUE, l);   \
        !           161:      fprintf ((FILE), "\tlong 0x%x\n", l);     \
        !           162:    } while (0)
        !           163: 
        !           164: #define ASM_OUTPUT_ALIGN(FILE,LOG)     \
        !           165:   if ((LOG) == 1)                      \
        !           166:     fprintf (FILE, "\teven\n");        \
        !           167:   else if ((LOG) != 0)                 \
        !           168:     abort ();
        !           169: 
        !           170: /* This is how to output an assembler line
        !           171:    that says to advance the location counter by SIZE bytes.  */
        !           172: 
        !           173: #undef ASM_OUTPUT_SKIP
        !           174: #define ASM_OUTPUT_SKIP(FILE,SIZE)  \
        !           175:   fprintf (FILE, "\tspace %d\n", (SIZE))
        !           176: 
        !           177: /* Can't use ASM_OUTPUT_SKIP in text section; it doesn't leave 0s.  */
        !           178: 
        !           179: #define ASM_NO_SKIP_IN_TEXT 1
        !           180: 
        !           181: /* The beginnings of sdb support... */
        !           182: 
        !           183: #define ASM_OUTPUT_SOURCE_FILENAME(FILE, FILENAME) \
        !           184:   do { fprintf (FILE, "\tfile\t");             \
        !           185:        output_quoted_string (FILE, FILENAME);  \
        !           186:        fprintf (FILE, "\n");                   \
        !           187:   } while (0)
        !           188: 
        !           189: #define ASM_OUTPUT_SOURCE_LINE(FILE, LINENO)   \
        !           190:   fprintf (FILE, "\tln\t%d\n",                 \
        !           191:           (sdb_begin_function_line             \
        !           192:            ? last_linenum - sdb_begin_function_line : 1))
        !           193: 
        !           194: /* Yet another null terminated string format. */
        !           195: 
        !           196: #define ASM_OUTPUT_ASCII(FILE,PTR,LEN) \
        !           197:   { register int sp = 0, lp = 0; \
        !           198:     fprintf ((FILE), "\tbyte\t"); \
        !           199:   loop: \
        !           200:     if ((PTR)[sp] > ' ' && ! ((PTR)[sp] & 0x80) && (PTR)[sp] != '\\') \
        !           201:       { lp += 3; \
        !           202:        fprintf ((FILE), "'%c", (PTR)[sp]); } \
        !           203:     else \
        !           204:       { lp += 5; \
        !           205:        fprintf ((FILE), "0x%x", (PTR)[sp]); } \
        !           206:     if (++sp < (LEN)) \
        !           207:       {        if (lp > 60) \
        !           208:          { lp = 0; \
        !           209:            fprintf ((FILE), "\n\t%s ", ASCII_DATA_ASM_OP); }   \
        !           210:        else \
        !           211:          putc (',', (FILE)); \
        !           212:        goto loop; } \
        !           213:     putc ('\n', (FILE)); }
        !           214: 
        !           215: /* Note that in the case of the movhi which fetches an element of
        !           216:    an ADDR_DIFF_VEC the offset output is too large by 2.
        !           217:    This is because the 3b1 assembler refuses to subtract 2.
        !           218:    ASM_OUTPUT_CASE_LABEL, below, compensates for this.  */
        !           219: 
        !           220: #define PRINT_OPERAND_ADDRESS(FILE, ADDR)  \
        !           221: { register rtx reg1, reg2, breg, ireg;                                 \
        !           222:   register rtx addr = ADDR;                                            \
        !           223:   rtx offset;                                                          \
        !           224:   switch (GET_CODE (addr))                                             \
        !           225:     {                                                                  \
        !           226:     case REG:                                                          \
        !           227:       fprintf (FILE, "(%s)", reg_names[REGNO (addr)]);                 \
        !           228:       break;                                                           \
        !           229:     case PRE_DEC:                                                      \
        !           230:       fprintf (FILE, "-(%s)", reg_names[REGNO (XEXP (addr, 0))]);      \
        !           231:       break;                                                           \
        !           232:     case POST_INC:                                                     \
        !           233:       fprintf (FILE, "(%s)+", reg_names[REGNO (XEXP (addr, 0))]);      \
        !           234:       break;                                                           \
        !           235:     case PLUS:                                                         \
        !           236:       reg1 = 0;        reg2 = 0;                                               \
        !           237:       ireg = 0;        breg = 0;                                               \
        !           238:       offset = 0;                                                      \
        !           239:       if (CONSTANT_ADDRESS_P (XEXP (addr, 0)))                         \
        !           240:        {                                                               \
        !           241:          offset = XEXP (addr, 0);                                      \
        !           242:          addr = XEXP (addr, 1);                                        \
        !           243:        }                                                               \
        !           244:       else if (CONSTANT_ADDRESS_P (XEXP (addr, 1)))                    \
        !           245:        {                                                               \
        !           246:          offset = XEXP (addr, 1);                                      \
        !           247:          addr = XEXP (addr, 0);                                        \
        !           248:        }                                                               \
        !           249:       if (GET_CODE (addr) != PLUS) ;                                   \
        !           250:       else if (GET_CODE (XEXP (addr, 0)) == SIGN_EXTEND)               \
        !           251:        {                                                               \
        !           252:          reg1 = XEXP (addr, 0);                                        \
        !           253:          addr = XEXP (addr, 1);                                        \
        !           254:        }                                                               \
        !           255:       else if (GET_CODE (XEXP (addr, 1)) == SIGN_EXTEND)               \
        !           256:        {                                                               \
        !           257:          reg1 = XEXP (addr, 1);                                        \
        !           258:          addr = XEXP (addr, 0);                                        \
        !           259:        }                                                               \
        !           260:       else if (GET_CODE (XEXP (addr, 0)) == MULT)                      \
        !           261:        {                                                               \
        !           262:          reg1 = XEXP (addr, 0);                                        \
        !           263:          addr = XEXP (addr, 1);                                        \
        !           264:        }                                                               \
        !           265:       else if (GET_CODE (XEXP (addr, 1)) == MULT)                      \
        !           266:        {                                                               \
        !           267:          reg1 = XEXP (addr, 1);                                        \
        !           268:          addr = XEXP (addr, 0);                                        \
        !           269:        }                                                               \
        !           270:       else if (GET_CODE (XEXP (addr, 0)) == REG)                       \
        !           271:        {                                                               \
        !           272:          reg1 = XEXP (addr, 0);                                        \
        !           273:          addr = XEXP (addr, 1);                                        \
        !           274:        }                                                               \
        !           275:       else if (GET_CODE (XEXP (addr, 1)) == REG)                       \
        !           276:        {                                                               \
        !           277:          reg1 = XEXP (addr, 1);                                        \
        !           278:          addr = XEXP (addr, 0);                                        \
        !           279:        }                                                               \
        !           280:       if (GET_CODE (addr) == REG || GET_CODE (addr) == MULT            \
        !           281:          || GET_CODE (addr) == SIGN_EXTEND)                            \
        !           282:        { if (reg1 == 0) reg1 = addr; else reg2 = addr; addr = 0; }     \
        !           283: /*  for OLD_INDEXING                                                   \
        !           284:       else if (GET_CODE (addr) == PLUS)                                        \
        !           285:        {                                                               \
        !           286:          if (GET_CODE (XEXP (addr, 0)) == REG)                         \
        !           287:            {                                                           \
        !           288:              reg2 = XEXP (addr, 0);                                    \
        !           289:              addr = XEXP (addr, 1);                                    \
        !           290:            }                                                           \
        !           291:          else if (GET_CODE (XEXP (addr, 1)) == REG)                    \
        !           292:            {                                                           \
        !           293:              reg2 = XEXP (addr, 1);                                    \
        !           294:              addr = XEXP (addr, 0);                                    \
        !           295:            }                                                           \
        !           296:        }                                                               \
        !           297:   */                                                                   \
        !           298:       if (offset != 0) { if (addr != 0) abort (); addr = offset; }     \
        !           299:       if ((reg1 && (GET_CODE (reg1) == SIGN_EXTEND                     \
        !           300:                    || GET_CODE (reg1) == MULT))                        \
        !           301:          || (reg2 != 0 && REGNO_OK_FOR_BASE_P (REGNO (reg2))))         \
        !           302:        { breg = reg2; ireg = reg1; }                                   \
        !           303:       else if (reg1 != 0 && REGNO_OK_FOR_BASE_P (REGNO (reg1)))                \
        !           304:        { breg = reg1; ireg = reg2; }                                   \
        !           305:       if (ireg != 0 && breg == 0 && GET_CODE (addr) == LABEL_REF)      \
        !           306:         { int scale = 1;                                               \
        !           307:          if (GET_CODE (ireg) == MULT)                                  \
        !           308:            { scale = INTVAL (XEXP (ireg, 1));                          \
        !           309:              ireg = XEXP (ireg, 0); }                                  \
        !           310:          if (GET_CODE (ireg) == SIGN_EXTEND)                           \
        !           311:            fprintf (FILE, "LD%%%d(%%pc,%s.w",                          \
        !           312:                     CODE_LABEL_NUMBER (XEXP (addr, 0)),                \
        !           313:                     reg_names[REGNO (XEXP (ireg, 0))]);                \
        !           314:          else                                                          \
        !           315:            fprintf (FILE, "LD%%%d(%%pc,%s.l",                          \
        !           316:                     CODE_LABEL_NUMBER (XEXP (addr, 0)),                \
        !           317:                     reg_names[REGNO (ireg)]);                          \
        !           318:          if (scale != 1) fprintf (FILE, "*%d", scale);                 \
        !           319:          fprintf (FILE, ")");                                          \
        !           320:          break; }                                                      \
        !           321:       if (breg != 0 && ireg == 0 && GET_CODE (addr) == LABEL_REF)      \
        !           322:         { fprintf (FILE, "LD%%%d(%%pc,%s.l",                           \
        !           323:                   CODE_LABEL_NUMBER (XEXP (addr, 0)),                  \
        !           324:                   reg_names[REGNO (breg)]);                            \
        !           325:          putc (')', FILE);                                             \
        !           326:          break; }                                                      \
        !           327:       if (ireg != 0 || breg != 0)                                      \
        !           328:        { int scale = 1;                                                \
        !           329:          if (breg == 0)                                                \
        !           330:            abort ();                                                   \
        !           331:          if (addr != 0)                                                \
        !           332:            output_addr_const (FILE, addr);                             \
        !           333:          fprintf (FILE, "(%s", reg_names[REGNO (breg)]);               \
        !           334:          if (ireg != 0)                                                \
        !           335:            putc (',', FILE);                                           \
        !           336:          if (ireg != 0 && GET_CODE (ireg) == MULT)                     \
        !           337:            { scale = INTVAL (XEXP (ireg, 1));                          \
        !           338:              ireg = XEXP (ireg, 0); }                                  \
        !           339:          if (ireg != 0 && GET_CODE (ireg) == SIGN_EXTEND)              \
        !           340:            fprintf (FILE, "%s.w", reg_names[REGNO (XEXP (ireg, 0))]);  \
        !           341:          else if (ireg != 0)                                           \
        !           342:            fprintf (FILE, "%s.l", reg_names[REGNO (ireg)]);            \
        !           343:          if (scale != 1) fprintf (FILE, "*%d", scale);                 \
        !           344:          putc (')', FILE);                                             \
        !           345:          break;                                                        \
        !           346:        }                                                               \
        !           347:       else if (reg1 != 0 && GET_CODE (addr) == LABEL_REF)              \
        !           348:        { fprintf (FILE, "LD%%%d(%%pc,%s.w)",                           \
        !           349:                   CODE_LABEL_NUMBER (XEXP (addr, 0)),                  \
        !           350:                   reg_names[REGNO (reg1)]);                            \
        !           351:          break; }                                                      \
        !           352:     default:                                                           \
        !           353:       if (GET_CODE (addr) == CONST_INT                                 \
        !           354:          && INTVAL (addr) < 0x8000                                     \
        !           355:          && INTVAL (addr) >= -0x8000)                                  \
        !           356:        fprintf (FILE, "%d", INTVAL (addr));                            \
        !           357:       else                                                             \
        !           358:         output_addr_const (FILE, addr);                                        \
        !           359:     }}
        !           360: 
        !           361: #define ASM_GENERATE_INTERNAL_LABEL(LABEL, PREFIX, NUM)        \
        !           362:   sprintf ((LABEL), "%s%%%d", (PREFIX), (NUM))
        !           363: 
        !           364: #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM)     \
        !           365:     fprintf (FILE, "%s%%%d:\n", PREFIX, NUM)
        !           366: 
        !           367: /* Must put address in  %a0 , not  %d0 . -- LGM, 7/15/88 */
        !           368: #define FUNCTION_PROFILER(FILE, LABEL_NO)      \
        !           369:     fprintf (FILE, "\tmov.l &LP%%%d,%%a0\n\tjsr mcount\n", (LABEL_NO))
        !           370: 
        !           371: #define ASM_OUTPUT_ADDR_VEC_ELT(FILE, VALUE)   \
        !           372:     fprintf (FILE, "\tlong L%%%d\n", (VALUE))
        !           373: 
        !           374: #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL)     \
        !           375:     fprintf (FILE, "\tshort L%%%d-L%%%d\n", (VALUE), (REL))
        !           376: 
        !           377: /* ihnp4!lmayk!lgm says that `short 0' triggers assembler bug;
        !           378:    `short L%nn-L%nn' supposedly works.  */
        !           379: #define ASM_OUTPUT_CASE_LABEL(FILE,PREFIX,NUM,TABLE)                   \
        !           380:   if (! RTX_INTEGRATED_P (TABLE))                                      \
        !           381:     fprintf (FILE, "\tswbeg &%d\n%s%%%d:\n",                           \
        !           382:             XVECLEN (PATTERN (TABLE), 1), (PREFIX), (NUM));            \
        !           383:   else                                                                 \
        !           384:     fprintf (FILE, "\tswbeg &%d\n%s%%%d:\n\tshort %s%%%d-%s%%%d\n",    \
        !           385:             XVECLEN (PATTERN (TABLE), 1) + 1, (PREFIX), (NUM),         \
        !           386:             (PREFIX), (NUM), (PREFIX), (NUM))
        !           387: 
        !           388: /* At end of a switch table, define LDnnn iff the symbol LInnn was defined.
        !           389:    Some SGS assemblers have a bug such that "Lnnn-LInnn-2.b(pc,d0.l*2)"
        !           390:    fails to assemble.  Luckily "LDnnn(pc,d0.l*2)" produces the results
        !           391:    we want.  This difference can be accommodated by making the assembler
        !           392:    define such "LDnnn" to be either "Lnnn-LInnn-2.b", "Lnnn", or any other
        !           393:    string, as necessary.  This is accomplished via the ASM_OUTPUT_CASE_END
        !           394:    macro. */
        !           395: 
        !           396: #define ASM_OUTPUT_CASE_END(FILE,NUM,TABLE)                            \
        !           397: { if (switch_table_difference_label_flag)                              \
        !           398:     fprintf (FILE, "\tset LD%%%d,L%%%d-LI%%%d\n", (NUM), (NUM), (NUM));        \
        !           399:   switch_table_difference_label_flag = 0; }
        !           400: 
        !           401: int switch_table_difference_label_flag;
        !           402: 
        !           403: #define ASM_OUTPUT_OPCODE(FILE, PTR)                   \
        !           404: { if ((PTR)[0] == 'j' && (PTR)[1] == 'b')              \
        !           405:     { ++(PTR);                                         \
        !           406:       while (*(PTR) != ' ')                            \
        !           407:        { putc (*(PTR), (FILE)); ++(PTR); }             \
        !           408:       fprintf ((FILE), ".w"); }                                \
        !           409:   else if ((PTR)[0] == 's')                            \
        !           410:     {                                                  \
        !           411:       if (!strncmp ((PTR), "swap", 4))                 \
        !           412:        { fprintf ((FILE), "swap.w"); (PTR) += 4; }     \
        !           413:     }                                                  \
        !           414:   else if ((PTR)[0] == 'f')                            \
        !           415:     {                                                  \
        !           416:       if (!strncmp ((PTR), "fmove", 5))                        \
        !           417:        { fprintf ((FILE), "fmov"); (PTR) += 5; }       \
        !           418:       else if (!strncmp ((PTR), "fbne", 4))            \
        !           419:        { fprintf ((FILE), "fbneq"); (PTR) += 4; }      \
        !           420:     }                                                  \
        !           421: /* MOVE, MOVEA, MOVEQ, MOVEC ==> MOV   */              \
        !           422:   else if ((PTR)[0] == 'm' && (PTR)[1] == 'o'          \
        !           423:           && (PTR)[2] == 'v' && (PTR)[3] == 'e')       \
        !           424:     { fprintf ((FILE), "mov"); (PTR) += 4;             \
        !           425:        if ((PTR)[0] == 'q' || (PTR)[0] == 'a'          \
        !           426:           || (PTR)[0] == 'c') (PTR)++; }               \
        !           427: /* SUB, SUBQ, SUBA, SUBI ==> SUB */                    \
        !           428:   else if ((PTR)[0] == 's' && (PTR)[1] == 'u'          \
        !           429:           && (PTR)[2] == 'b')                          \
        !           430:     { fprintf ((FILE), "sub"); (PTR) += 3;             \
        !           431:        if ((PTR)[0] == 'q' || (PTR)[0] == 'i'          \
        !           432:           || (PTR)[0] == 'a') (PTR)++; }               \
        !           433: /* CMP, CMPA, CMPI, CMPM ==> CMP       */              \
        !           434:   else if ((PTR)[0] == 'c' && (PTR)[1] == 'm'          \
        !           435:           && (PTR)[2] == 'p')                          \
        !           436:     { fprintf ((FILE), "cmp"); (PTR) += 3;             \
        !           437:        if ((PTR)[0] == 'a' || (PTR)[0] == 'i'          \
        !           438:           || (PTR)[0] == 'm') (PTR)++; }               \
        !           439: }
        !           440: 
        !           441: #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE, ROUNDED)  \
        !           442: ( fputs ("\tlcomm ", (FILE)),                  \
        !           443:   assemble_name ((FILE), (NAME)),              \
        !           444:   fprintf ((FILE), ",%u\n", (ROUNDED)))
        !           445: 
        !           446: #define ASM_OUTPUT_LABELREF(FILE,NAME) \
        !           447:   fprintf (FILE, "%s", NAME)
        !           448: 
        !           449: /* Override usual definitions of SDB output macros.
        !           450:    These definitions differ only in the absence of the period
        !           451:    at the beginning of the name of the directive
        !           452:    and in the use of `~' as the symbol for the current location.  */
        !           453: 
        !           454: #define PUT_SDB_SCL(a) fprintf(asm_out_file, "\tscl\t%d;", (a))
        !           455: #define PUT_SDB_INT_VAL(a) fprintf (asm_out_file, "\tval\t%d;", (a))
        !           456: #define PUT_SDB_VAL(a)                         \
        !           457: ( fputs ("\tval\t", asm_out_file),             \
        !           458:   output_addr_const (asm_out_file, (a)),       \
        !           459:   fputc (';', asm_out_file))
        !           460: 
        !           461: #define PUT_SDB_DEF(a)                         \
        !           462: do { fprintf (asm_out_file, "\tdef\t");        \
        !           463:      ASM_OUTPUT_LABELREF (asm_out_file, a);    \
        !           464:      fprintf (asm_out_file, ";"); } while (0)
        !           465: 
        !           466: #define PUT_SDB_PLAIN_DEF(a) fprintf(asm_out_file,"\tdef\t~%s;",a)
        !           467: #define PUT_SDB_ENDEF fputs("\tendef\n", asm_out_file)
        !           468: #define PUT_SDB_TYPE(a) fprintf(asm_out_file, "\ttype\t0%o;", a)
        !           469: #define PUT_SDB_SIZE(a) fprintf(asm_out_file, "\tsize\t%d;", a)
        !           470: #define PUT_SDB_START_DIM fprintf(asm_out_file, "\tdim\t")
        !           471: 
        !           472: #define PUT_SDB_TAG(a)                         \
        !           473: do { fprintf (asm_out_file, "\ttag\t");        \
        !           474:      ASM_OUTPUT_LABELREF (asm_out_file, a);    \
        !           475:      fprintf (asm_out_file, ";"); } while (0)
        !           476: 
        !           477: #define PUT_SDB_BLOCK_START(LINE)              \
        !           478:   fprintf (asm_out_file,                       \
        !           479:           "\tdef\t~bb;\tval\t~;\tscl\t100;\tline\t%d;\tendef\n",       \
        !           480:           (LINE))
        !           481: 
        !           482: #define PUT_SDB_BLOCK_END(LINE)                        \
        !           483:   fprintf (asm_out_file,                       \
        !           484:           "\tdef\t~eb;\tval\t~;\tscl\t100;\tline\t%d;\tendef\n",       \
        !           485:           (LINE))
        !           486: 
        !           487: #define PUT_SDB_FUNCTION_START(LINE)           \
        !           488:   fprintf (asm_out_file,                       \
        !           489:           "\tdef\t~bf;\tval\t~;\tscl\t101;\tline\t%d;\tendef\n",       \
        !           490:           (LINE))
        !           491: 
        !           492: #define PUT_SDB_FUNCTION_END(LINE)             \
        !           493:   fprintf (asm_out_file,                       \
        !           494:           "\tdef\t~ef;\tval\t~;\tscl\t101;\tline\t%d;\tendef\n",       \
        !           495:           (LINE))
        !           496: 
        !           497: #define PUT_SDB_EPILOGUE_END(NAME)             \
        !           498:   fprintf (asm_out_file,                       \
        !           499:           "\tdef\t%s;\tval\t~;\tscl\t-1;\tendef\n",    \
        !           500:           (NAME))
        !           501: 
        !           502: #define SDB_GENERATE_FAKE(BUFFER, NUMBER) \
        !           503:   sprintf ((BUFFER), "~%dfake", (NUMBER));
        !           504: 
        !           505: /* Define subroutines to call to handle multiply, divide, and remainder.
        !           506:    Use the subroutines that the 3b1's library provides.
        !           507:    The `*' prevents an underscore from being prepended by the compiler.  */
        !           508: 
        !           509: #define DIVSI3_LIBCALL "*ldiv"
        !           510: #define UDIVSI3_LIBCALL "*uldiv"
        !           511: #define MODSI3_LIBCALL "*lrem"
        !           512: #define UMODSI3_LIBCALL "*ulrem"
        !           513: #define MULSI3_LIBCALL "*lmul"
        !           514: #define UMULSI3_LIBCALL "*ulmul"
        !           515: 
        !           516: /* Definitions for collect2.  */
        !           517: 
        !           518: #define OBJECT_FORMAT_COFF
        !           519: #define NO_SYS_SIGLIST
        !           520: #define MY_ISCOFF(magic) \
        !           521:  ((magic) == MC68KWRMAGIC || (magic) == MC68KROMAGIC || (magic) == MC68KPGMAGIC)

unix.superglobalmegacorp.com

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