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

1.1     ! root        1: /* Definitions of target machine for GNU compiler.
        !             2:    Charles River Data Systems UNiverse/32
        !             3: 
        !             4:    Written by Gary E. Miller
        !             5:    bug reports to [email protected]
        !             6: 
        !             7:    Copyright (C) 1987, 1993 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 MOTOROLA               /* Use Motorola syntax rather than "MIT" */
        !            26: #define SGS                    /* Uses SGS assembler */
        !            27: #define SGS_SWITCH_TABLES      /* Different switch table handling */
        !            28: #define CRDS                   /* Charles River Data Systems assembler */
        !            29: 
        !            30: #include "m68k/m68k.h"
        !            31: 
        !            32: /* Without STRUCTURE_SIZE_BOUNDARY, we can't ensure that structures are
        !            33:    aligned such that we can correctly extract bitfields from them.
        !            34:    Someone should check whether the usual compiler on the crds machine
        !            35:    provides the equivalent behavior of STRUCTURE_SIZE_BOUNDARY.  */
        !            36: #error This does not define STRUCTURE_SIZE_BOUNDARY
        !            37: 
        !            38: /* See m68k.h.  0 means 680[01]0 with no 68881.  */
        !            39: 
        !            40: #undef TARGET_DEFAULT
        !            41: #define        TARGET_DEFAULT 0
        !            42: 
        !            43: /* Don't try using XFmode.  */
        !            44: #undef LONG_DOUBLE_TYPE_SIZE
        !            45: #define LONG_DOUBLE_TYPE_SIZE 64
        !            46: 
        !            47: /* special flags to the unos assembler.  */
        !            48: 
        !            49: #undef ASM_SPEC
        !            50: #define ASM_SPEC "-g"
        !            51: 
        !            52: #undef LIB_SPEC
        !            53: #define LIB_SPEC "%{!p:%{!pg:-lunos}}%{p:-lc_p}%{pg:-lc_p}"
        !            54: 
        !            55: #undef STARTFILE_SPEC
        !            56: #define STARTFILE_SPEC  \
        !            57:   "%{pg:gcrt0.o%s}%{!pg:%{p:mc68rt0.o%s}%{!p:c68rt0.o%s}}"
        !            58: 
        !            59: /* CC1 spec */
        !            60: #if 0
        !            61: /* c.sac only used in _s_call_r() in libunos.a and malloc() in libmalloc.a */
        !            62: /* so we do not need to bother ! */
        !            63: #define CC1_SPEC "-fpcc-struct-return"
        !            64: #endif
        !            65: 
        !            66: /* -O2 for MAX optimization */
        !            67: #undef CC1_SPEC
        !            68: #define CC1_SPEC "%{O2:-fstrength-reduce}"
        !            69: 
        !            70: /* cpp has to support a #sccs directive for the /usr/include files */
        !            71: 
        !            72: #define SCCS_DIRECTIVE
        !            73: 
        !            74: /* Make output for SDB.  */
        !            75: 
        !            76: /* #define SDB_DEBUGGING_INFO UNOS casm has no debugging :-( */
        !            77: 
        !            78: /* UNOS has vprintf() */ 
        !            79: 
        !            80: #define HAVE_VPRINTF
        !            81: 
        !            82: /* UNOS need stack probe :-( */
        !            83: 
        !            84: #define HAVE_probe 1
        !            85: #define gen_probe()  gen_rtx(ASM_INPUT, VOIDmode, "tstb -2048(sp)\t;probe\n")
        !            86: 
        !            87: /* use memcpy, memset instead of bcopy, etc. */
        !            88: 
        !            89: #define TARGET_MEM_FUNCTIONS
        !            90: 
        !            91: /* Don't try to define `gcc_compiled.' since the assembler might not
        !            92:    accept symbols with periods and GDB doesn't run on this machine anyway.  */
        !            93: #define ASM_IDENTIFY_GCC(FILE)
        !            94: 
        !            95: /* Define __HAVE_68881__ in preprocessor if -m68881 is specified.
        !            96:    This will control the use of inline 68881 insns in certain macros.  */
        !            97: 
        !            98: #undef CPP_SPEC
        !            99: #define CPP_SPEC "%{m68881:-D__HAVE_68881__}"
        !           100: 
        !           101: /* Names to predefine in the preprocessor for this target machine.  */
        !           102: 
        !           103: #undef CPP_PREDEFINES
        !           104: #define CPP_PREDEFINES "-Dmc68k -DM68000 -Dmc68000 -Dunos -Dunix -D__motorola__ -Asystem(unix)  -Acpu(m68k) -Amachine(m68k)"
        !           105: 
        !           106: /* Register in which address to store a structure value
        !           107:    is passed to a function.  */
        !           108: /* unos uses ".comm c.sac" returns &c.sac in d0 */
        !           109: /* make pointer to c.sac ?
        !           110: #undef STRUCT_VALUE_REGNUM
        !           111: #define STRUCT_VALUE gen_rtx(MEM, Pmode, gen_rtx( , , ) )
        !           112: */
        !           113: 
        !           114: #define EXTRA_SECTIONS in_bss
        !           115: 
        !           116: #define EXTRA_SECTION_FUNCTIONS                                                \
        !           117: void                                                                   \
        !           118: bss_section ()                                                         \
        !           119: {                                                                      \
        !           120:   if (in_section != in_bss)                                            \
        !           121:     {                                                                  \
        !           122:       fprintf (asm_out_file, ".bss\n");                                        \
        !           123:       in_section = in_bss;                                             \
        !           124:     }                                                                  \
        !           125: }
        !           126: 
        !           127: /* Specify how to pad function arguments.
        !           128:    Value should be `upward', `downward' or `none'.
        !           129:    Same as the default, except no padding for large or variable-size args.  */
        !           130: 
        !           131: #define FUNCTION_ARG_PADDING(MODE, TYPE)                               \
        !           132:   (((MODE) == BLKmode                                                  \
        !           133:     ? ((TYPE) && TREE_CODE (TYPE_SIZE (TYPE))  == INTEGER_CST          \
        !           134:        && int_size_in_bytes (TYPE) < PARM_BOUNDARY / BITS_PER_UNIT)    \
        !           135:     : GET_MODE_BITSIZE (MODE) < PARM_BOUNDARY)                         \
        !           136:    ? downward : none)
        !           137: 
        !           138: /* Override part of the obstack macros.  */
        !           139: 
        !           140: #define __PTR_TO_INT(P) ((int)(P))
        !           141: #define __INT_TO_PTR(P) ((char *)(P))
        !           142: 
        !           143: /* Override parts of m68k.h to fit the CRuDS assembler.  */
        !           144: 
        !           145: #undef TARGET_VERSION 
        !           146: #define TARGET_VERSION fprintf (stderr, " (68k, CRDS/UNOS)");
        !           147: 
        !           148: /* Specify extra dir to search for include files.  */
        !           149: #define SYSTEM_INCLUDE_DIR "/include"
        !           150: 
        !           151: /* Control the assembler format that we output.  */
        !           152: 
        !           153: /* Output at beginning of assembler file.  */
        !           154: 
        !           155: #undef ASM_FILE_START
        !           156: #define ASM_FILE_START(FILE)   \
        !           157:   fprintf (FILE, ";#NO_APP\n");
        !           158: 
        !           159: /* Output to assembler file text saying following lines
        !           160:    may contain character constants, extra white space, comments, etc.  */
        !           161: 
        !           162: #undef ASM_APP_ON
        !           163: #define ASM_APP_ON ";#APP\n"
        !           164: 
        !           165: /* Output to assembler file text saying following lines
        !           166:    no longer contain unusual constructs.  */
        !           167: 
        !           168: #undef ASM_APP_OFF 
        !           169: #define ASM_APP_OFF ";#NO_APP\n"
        !           170: 
        !           171: /* This is how to output an assembler line defining a `double' constant.  */
        !           172: 
        !           173: #undef ASM_OUTPUT_DOUBLE
        !           174: #define ASM_OUTPUT_DOUBLE(FILE,VALUE)  \
        !           175: do { long l[2];                                                \
        !           176:      REAL_VALUE_TO_TARGET_DOUBLE (VALUE, l);           \
        !           177:      fprintf (FILE, "\t.long 0x%x, 0x%x\n", l[0], l[1]);       \
        !           178:    } while (0)
        !           179: 
        !           180: /*unos has no .skip :-( */
        !           181: #undef ASM_OUTPUT_SKIP
        !           182: #define ASM_OUTPUT_SKIP(FILE,SIZE)             \
        !           183:     fprintf (FILE, "\t. = . + %u\n", (SIZE));  
        !           184: 
        !           185: /* This says how to output an assembler line
        !           186:    to define a local common symbol.  */
        !           187: /* should use bss_section instead of data_section but this makes casm die ? */
        !           188: 
        !           189: #undef ASM_OUTPUT_LOCAL
        !           190: #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE, ROUNDED)  \
        !           191: { data_section ();                             \
        !           192:   if ((SIZE) > 1) fprintf (FILE, "\t.even\n"); \
        !           193:   assemble_name ((FILE), (NAME));              \
        !           194:   fprintf ((FILE), ":\t. = . + %u\n", (ROUNDED));}
        !           195: 
        !           196: /* This is how to output an insn to push a register on the stack.
        !           197:    It need not be very fast code.  */
        !           198: 
        !           199: #undef ASM_OUTPUT_REG_PUSH
        !           200: #define ASM_OUTPUT_REG_PUSH(FILE,REGNO)  \
        !           201:   fprintf (FILE, "\tmovel %s,-(sp)\n", reg_names[REGNO])
        !           202: 
        !           203: /* This is how to output an insn to pop a register from the stack.
        !           204:    It need not be very fast code.  */
        !           205: 
        !           206: #undef ASM_OUTPUT_REG_POP
        !           207: #define ASM_OUTPUT_REG_POP(FILE,REGNO)  \
        !           208:   fprintf (FILE, "\tmovel (sp)+,%s\n", reg_names[REGNO])
        !           209: 
        !           210: #undef  ASM_OUTPUT_ASCII
        !           211: #define  ASM_OUTPUT_ASCII(FILE, P , SIZE)                              \
        !           212: {  int i;                                                              \
        !           213:          fprintf ((FILE), "\t.ascii \"");                              \
        !           214:          for (i = 0; i < (SIZE); i++)                                  \
        !           215:            {                                                           \
        !           216:              register int c = (P)[i];                                  \
        !           217:              if (i != 0 && (i / 200) * 200 == i)                       \
        !           218:                fprintf ((FILE), "\"\n\t.ascii \"");                    \
        !           219:              if (c >= ' ' && c < 0177) {                               \
        !           220:                if (c != '\"' && c != '\\') {                           \
        !           221:                  putc (c, (FILE));                                     \
        !           222:                  continue;                                             \
        !           223:                }                                                       \
        !           224:               }                                                        \
        !           225:               /* brain dead asm doesn't understand char escapes */  \
        !           226:               fprintf ((FILE), "\"\n\t.byte\t%d\n\t.ascii \"", c);     \
        !           227:            }                                                           \
        !           228:          fprintf ((FILE), "\"\n");                                     \
        !           229:  }
        !           230: 
        !           231: 
        !           232: /* Change all JBxx to Bxx.  Also change all DBRA to DBF.
        !           233:    Also change divs.l, etc., to divs, etc.  But don't change divsl.l.  */
        !           234: 
        !           235: #define ASM_OUTPUT_OPCODE(FILE, PTR)                   \
        !           236: { if ((PTR)[0] == 'j' && (PTR)[1] == 'b')              \
        !           237:     { ++(PTR); }                                       \
        !           238:   else if ((PTR)[0] == 'd')                            \
        !           239:     {                                                  \
        !           240:       if (!strncmp ((PTR), "dbra", 4))                 \
        !           241:        { fprintf ((FILE), "dbf"); (PTR) += 4; }        \
        !           242:       else if (!strncmp ((PTR), "div", 3) && (PTR)[5] == ' ')  \
        !           243:        { fprintf ((FILE), "div%c", (PTR)[3]); (PTR) += 6; }   \
        !           244:     }                                                  \
        !           245: }
        !           246: 
        !           247: 
        !           248: /* Print operand X (an rtx) in assembler syntax to file FILE.
        !           249:    CODE is a letter or dot (`z' in `%z0') or 0 if no letter was specified.
        !           250:    For `%' followed by punctuation, CODE is the punctuation and X is null.
        !           251: 
        !           252:    On the 68000, we use several CODE characters:
        !           253:    '.' for dot needed in Motorola-style opcode names.
        !           254:    '-' for an operand pushing on the stack:
        !           255:        sp@-, -(sp) or -(%sp) depending on the style of syntax.
        !           256:    '+' for an operand pushing on the stack:
        !           257:        sp@+, (sp)+ or (%sp)+ depending on the style of syntax.
        !           258:    '@' for a reference to the top word on the stack:
        !           259:        sp@, (sp) or (%sp) depending on the style of syntax.
        !           260:    '#' for an immediate operand prefix (# in MIT and Motorola syntax
        !           261:        but & in SGS syntax, $ in unos syntax).
        !           262:    '!' for the fpcr register (used in some float-to-fixed conversions).
        !           263: 
        !           264:    'b' for byte insn (no effect, on the Sun; this is for the ISI).
        !           265:    'd' to force memory addressing to be absolute, not relative.
        !           266:    'f' for float insn (print a CONST_DOUBLE as a float rather than in hex)
        !           267:    'w' for FPA insn (print a CONST_DOUBLE as a SunFPA constant rather
        !           268:        than directly).  Second part of 'y' below.
        !           269:    'x' for float insn (print a CONST_DOUBLE as a float rather than in hex),
        !           270:        or print pair of registers as rx:ry.
        !           271:    'y' for a FPA insn (print pair of registers as rx:ry).  This also outputs
        !           272:        CONST_DOUBLE's as SunFPA constant RAM registers if
        !           273:        possible, so it should not be used except for the SunFPA. */
        !           274: 
        !           275: #undef PRINT_OPERAND_PUNCT_VALID_P
        !           276: #define PRINT_OPERAND_PUNCT_VALID_P(CODE)                              \
        !           277:   ((CODE) == '.' || (CODE) == '#' || (CODE) == '-'                     \
        !           278:    || (CODE) == '+' || (CODE) == '@' || (CODE) == '!')
        !           279: 
        !           280: #undef PRINT_OPERAND
        !           281: #define PRINT_OPERAND(FILE, X, CODE)  \
        !           282: { int i;                                                               \
        !           283:   if (CODE == '.') ;                                                   \
        !           284:   else if (CODE == '#') fprintf (FILE, "$");                           \
        !           285:   else if (CODE == '-') fprintf (FILE, "-(sp)");                       \
        !           286:   else if (CODE == '+') fprintf (FILE, "(sp)+");                       \
        !           287:   else if (CODE == '@') fprintf (FILE, "(sp)");                                \
        !           288:   else if (CODE == '!') fprintf (FILE, "fpcr");                                \
        !           289:   else if (CODE == '/')                                                        \
        !           290:     ;                                                                  \
        !           291:   else if (GET_CODE (X) == REG)                                                \
        !           292:     { if (REGNO (X) < 16 && (CODE == 'y' || CODE == 'x') && GET_MODE (X) == DFmode)    \
        !           293:         fprintf (FILE, "%s:%s", reg_names[REGNO (X)], reg_names[REGNO (X)+1]); \
        !           294:       else                                                             \
        !           295:         fprintf (FILE, "%s", reg_names[REGNO (X)]);                    \
        !           296:     }                                                                  \
        !           297:   else if (GET_CODE (X) == MEM)                                                \
        !           298:     {                                                                  \
        !           299:       output_address (XEXP (X, 0));                                    \
        !           300:       if (CODE == 'd' && ! TARGET_68020                                        \
        !           301:          && CONSTANT_ADDRESS_P (XEXP (X, 0)))                          \
        !           302:        /* fprintf (FILE, ".l") */;                                     \
        !           303:     }                                                                  \
        !           304:   else if ((CODE == 'y' || CODE == 'w')                                        \
        !           305:           && GET_CODE(X) == CONST_DOUBLE                               \
        !           306:           && (i = standard_sun_fpa_constant_p (X)))                    \
        !           307:     fprintf (FILE, "%%%d", i & 0x1ff);                                 \
        !           308:   else if (GET_CODE (X) == CONST_DOUBLE && GET_MODE (X) == SFmode)     \
        !           309:     { REAL_VALUE_TYPE r; long l;                                       \
        !           310:       REAL_VALUE_FROM_CONST_DOUBLE (r, X);                             \
        !           311:       if (CODE == 'f')                                                 \
        !           312:        ASM_OUTPUT_FLOAT_OPERAND (CODE, FILE, r);                       \
        !           313:       else                                                             \
        !           314:         { REAL_VALUE_TO_TARGET_SINGLE (r, l);                          \
        !           315:           fprintf (FILE, "$0x%x", l); } }                              \
        !           316:   else if (GET_CODE (X) == CONST_DOUBLE && GET_MODE (X) == XFmode)     \
        !           317:     { REAL_VALUE_TYPE r;                                               \
        !           318:       REAL_VALUE_FROM_CONST_DOUBLE (r, X);                             \
        !           319:       ASM_OUTPUT_LONG_DOUBLE_OPERAND (FILE, r); }                      \
        !           320:   else if (GET_CODE (X) == CONST_DOUBLE && GET_MODE (X) != DImode)     \
        !           321:     { REAL_VALUE_TYPE r;                                               \
        !           322:       REAL_VALUE_FROM_CONST_DOUBLE (r, X);                             \
        !           323:       ASM_OUTPUT_DOUBLE_OPERAND (FILE, r); }                           \
        !           324:   else { putc ('$', FILE); output_addr_const (FILE, X); }}
        !           325: 
        !           326: /* Note that this contains a kludge that knows that the only reason
        !           327:    we have an address (plus (label_ref...) (reg...))
        !           328:    is in the insn before a tablejump, and we know that m68k.md
        !           329:    generates a label LInnn: on such an insn.  */
        !           330: #undef PRINT_OPERAND_ADDRESS
        !           331: #define PRINT_OPERAND_ADDRESS(FILE, ADDR)  \
        !           332: { register rtx reg1, reg2, breg, ireg;                                 \
        !           333:   register rtx addr = ADDR;                                            \
        !           334:   rtx offset;                                                          \
        !           335:   switch (GET_CODE (addr))                                             \
        !           336:     {                                                                  \
        !           337:     case REG:                                                          \
        !           338:       fprintf (FILE, "(%s)", reg_names[REGNO (addr)]);                 \
        !           339:       break;                                                           \
        !           340:     case PRE_DEC:                                                      \
        !           341:       fprintf (FILE, "-(%s)", reg_names[REGNO (XEXP (addr, 0))]);      \
        !           342:       break;                                                           \
        !           343:     case POST_INC:                                                     \
        !           344:       fprintf (FILE, "(%s)+", reg_names[REGNO (XEXP (addr, 0))]);      \
        !           345:       break;                                                           \
        !           346:     case PLUS:                                                         \
        !           347:       reg1 = 0;        reg2 = 0;                                               \
        !           348:       ireg = 0;        breg = 0;                                               \
        !           349:       offset = 0;                                                      \
        !           350:       if (CONSTANT_ADDRESS_P (XEXP (addr, 0)))                         \
        !           351:        {                                                               \
        !           352:          offset = XEXP (addr, 0);                                      \
        !           353:          addr = XEXP (addr, 1);                                        \
        !           354:        }                                                               \
        !           355:       else if (CONSTANT_ADDRESS_P (XEXP (addr, 1)))                    \
        !           356:        {                                                               \
        !           357:          offset = XEXP (addr, 1);                                      \
        !           358:          addr = XEXP (addr, 0);                                        \
        !           359:        }                                                               \
        !           360:       if (GET_CODE (addr) != PLUS) ;                                   \
        !           361:       else if (GET_CODE (XEXP (addr, 0)) == SIGN_EXTEND)               \
        !           362:        {                                                               \
        !           363:          reg1 = XEXP (addr, 0);                                        \
        !           364:          addr = XEXP (addr, 1);                                        \
        !           365:        }                                                               \
        !           366:       else if (GET_CODE (XEXP (addr, 1)) == SIGN_EXTEND)               \
        !           367:        {                                                               \
        !           368:          reg1 = XEXP (addr, 1);                                        \
        !           369:          addr = XEXP (addr, 0);                                        \
        !           370:        }                                                               \
        !           371:       else if (GET_CODE (XEXP (addr, 0)) == MULT)                      \
        !           372:        {                                                               \
        !           373:          reg1 = XEXP (addr, 0);                                        \
        !           374:          addr = XEXP (addr, 1);                                        \
        !           375:        }                                                               \
        !           376:       else if (GET_CODE (XEXP (addr, 1)) == MULT)                      \
        !           377:        {                                                               \
        !           378:          reg1 = XEXP (addr, 1);                                        \
        !           379:          addr = XEXP (addr, 0);                                        \
        !           380:        }                                                               \
        !           381:       else if (GET_CODE (XEXP (addr, 0)) == REG)                       \
        !           382:        {                                                               \
        !           383:          reg1 = XEXP (addr, 0);                                        \
        !           384:          addr = XEXP (addr, 1);                                        \
        !           385:        }                                                               \
        !           386:       else if (GET_CODE (XEXP (addr, 1)) == REG)                       \
        !           387:        {                                                               \
        !           388:          reg1 = XEXP (addr, 1);                                        \
        !           389:          addr = XEXP (addr, 0);                                        \
        !           390:        }                                                               \
        !           391:       if (GET_CODE (addr) == REG || GET_CODE (addr) == MULT            \
        !           392:          || GET_CODE (addr) == SIGN_EXTEND)                            \
        !           393:        { if (reg1 == 0) reg1 = addr; else reg2 = addr; addr = 0; }     \
        !           394:       if (offset != 0) { if (addr != 0) abort (); addr = offset; }     \
        !           395:       if ((reg1 && (GET_CODE (reg1) == SIGN_EXTEND                     \
        !           396:                    || GET_CODE (reg1) == MULT))                        \
        !           397:          || (reg2 != 0 && REGNO_OK_FOR_BASE_P (REGNO (reg2))))         \
        !           398:        { breg = reg2; ireg = reg1; }                                   \
        !           399:       else if (reg1 != 0 && REGNO_OK_FOR_BASE_P (REGNO (reg1)))                \
        !           400:        { breg = reg1; ireg = reg2; }                                   \
        !           401:       if (ireg != 0 && breg == 0 && GET_CODE (addr) == LABEL_REF)      \
        !           402:         { int scale = 1;                                               \
        !           403:          if (GET_CODE (ireg) == MULT)                                  \
        !           404:            { scale = INTVAL (XEXP (ireg, 1));                          \
        !           405:              ireg = XEXP (ireg, 0); }                                  \
        !           406:          if (GET_CODE (ireg) == SIGN_EXTEND)                           \
        !           407:            fprintf (FILE, "L%d-LI%d-2(pc,%s.w",                        \
        !           408:                     CODE_LABEL_NUMBER (XEXP (addr, 0)),                \
        !           409:                     CODE_LABEL_NUMBER (XEXP (addr, 0)),                \
        !           410:                     reg_names[REGNO (XEXP (ireg, 0))]);                \
        !           411:          else                                                          \
        !           412:            fprintf (FILE, "L%d-LI%d-2(pc,%s.l",                        \
        !           413:                     CODE_LABEL_NUMBER (XEXP (addr, 0)),                \
        !           414:                     CODE_LABEL_NUMBER (XEXP (addr, 0)),                \
        !           415:                     reg_names[REGNO (ireg)]);                          \
        !           416:          if (scale != 1) fprintf (FILE, ":%d", scale);                 \
        !           417:          putc (')', FILE);                                             \
        !           418:          break; }                                                      \
        !           419:       if (breg != 0 && ireg == 0 && GET_CODE (addr) == LABEL_REF)      \
        !           420:         { fprintf (FILE, "L%d-LI%d-2(pc,%s.l",                         \
        !           421:                   CODE_LABEL_NUMBER (XEXP (addr, 0)),                  \
        !           422:                   CODE_LABEL_NUMBER (XEXP (addr, 0)),                  \
        !           423:                   reg_names[REGNO (breg)]);                            \
        !           424:          putc (')', FILE);                                             \
        !           425:          break; }                                                      \
        !           426:       if (ireg != 0 || breg != 0)                                      \
        !           427:        { int scale = 1;                                                \
        !           428:          if (breg == 0)                                                \
        !           429:            abort ();                                                   \
        !           430:          if (addr && GET_CODE (addr) == LABEL_REF) abort ();           \
        !           431:          if (addr != 0)                                                \
        !           432:            output_addr_const (FILE, addr);                             \
        !           433:          fprintf (FILE, "(%s", reg_names[REGNO (breg)]);               \
        !           434:          if (breg != 0 && ireg != 0)                                   \
        !           435:            putc (',', FILE);                                           \
        !           436:          if (ireg != 0 && GET_CODE (ireg) == MULT)                     \
        !           437:            { scale = INTVAL (XEXP (ireg, 1));                          \
        !           438:              ireg = XEXP (ireg, 0); }                                  \
        !           439:          if (ireg != 0 && GET_CODE (ireg) == SIGN_EXTEND)              \
        !           440:            fprintf (FILE, "%s.w", reg_names[REGNO (XEXP (ireg, 0))]);  \
        !           441:          else if (ireg != 0)                                           \
        !           442:            fprintf (FILE, "%s.l", reg_names[REGNO (ireg)]);            \
        !           443:          if (scale != 1) fprintf (FILE, ":%d", scale);                 \
        !           444:          putc (')', FILE);                                             \
        !           445:          break;                                                        \
        !           446:        }                                                               \
        !           447:       else if (reg1 != 0 && GET_CODE (addr) == LABEL_REF)              \
        !           448:        { fprintf (FILE, "L%d-LI%d-2(pc,%s.l)",                         \
        !           449:                   CODE_LABEL_NUMBER (XEXP (addr, 0)),                  \
        !           450:                   CODE_LABEL_NUMBER (XEXP (addr, 0)),                  \
        !           451:                   reg_names[REGNO (reg1)]);                            \
        !           452:          break; }                                                      \
        !           453:     default:                                                           \
        !           454:       if (GET_CODE (addr) == CONST_INT                                 \
        !           455:          && INTVAL (addr) < 0x8000                                     \
        !           456:          && INTVAL (addr) >= -0x8000)                                  \
        !           457:        fprintf (FILE, "%d", INTVAL (addr));                            \
        !           458:       else                                                             \
        !           459:         output_addr_const (FILE, addr);                                        \
        !           460:     }}
        !           461: 
        !           462: #define ASM_OUTPUT_SOURCE_FILENAME(FILE, FILENAME) \
        !           463:   do { fprintf (FILE, "\t; file\t");                   \
        !           464:        output_quoted_string (FILE, FILENAME);          \
        !           465:        fprintf (FILE, "\n");                           \
        !           466:   } while (0)
        !           467: 
        !           468: #define ASM_OUTPUT_SOURCE_LINE(FILE, LINENO)   \
        !           469:   fprintf (FILE, "\t; ln\t%d\n",                       \
        !           470:           (sdb_begin_function_line             \
        !           471:            ? last_linenum - sdb_begin_function_line : 1))
        !           472: 
        !           473: /* This macro generates the assembly code for function entry.
        !           474:    FILE is a stdio stream to output the code to.
        !           475:    SIZE is an int: how many units of temporary storage to allocate.
        !           476:    Refer to the array `regs_ever_live' to determine which registers
        !           477:    to save; `regs_ever_live[I]' is nonzero if register number I
        !           478:    is ever used in the function.  This macro is responsible for
        !           479:    knowing which registers should not be saved even if used.  */
        !           480: 
        !           481: /* Note that the order of the bit mask for fmovem is the opposite
        !           482:    of the order for movem!  */
        !           483: 
        !           484: #undef FUNCTION_PROLOGUE
        !           485: #define FUNCTION_PROLOGUE(FILE, SIZE)     \
        !           486: { register int regno;                                          \
        !           487:   register int mask = 0;                                       \
        !           488:   extern char call_used_regs[];                                        \
        !           489:   int fsize = ((SIZE) + 3) & -4;                               \
        !           490:   /* unos stack probe */                                       \
        !           491:   if ( fsize > 30000 ) {                                       \
        !           492:     fprintf (FILE, "\tmovel sp,a0\n");                         \
        !           493:     fprintf (FILE, "\taddl $-%d,a0\n", 2048 + fsize);          \
        !           494:     fprintf (FILE, "\ttstb (a0)\n");                           \
        !           495:   } else {                                                     \
        !           496:     fprintf (FILE, "\ttstb -%d(sp)\n", 2048 + fsize);          \
        !           497:   }                                                            \
        !           498:   if (frame_pointer_needed)                                    \
        !           499:     { if (TARGET_68020 || fsize < 0x8000)                      \
        !           500:         fprintf (FILE, "\tlink a6,$%d\n", -fsize);             \
        !           501:       else                                                     \
        !           502:        fprintf (FILE, "\tlink a6,$0\n\tsubl $%d,sp\n", fsize); }  \
        !           503:   for (regno = 24; regno < 56; regno++)                                \
        !           504:     if (regs_ever_live[regno] && ! call_used_regs[regno])      \
        !           505:       fprintf(FILE, "\tfpmoved %s, sp@-\n",                    \
        !           506:              reg_names[regno]);                                \
        !           507:   for (regno = 16; regno < 24; regno++)                                \
        !           508:     if (regs_ever_live[regno] && ! call_used_regs[regno])      \
        !           509:        mask |= 1 << (regno - 16);                              \
        !           510:   if ((mask & 0xff) != 0)                                      \
        !           511:     fprintf (FILE, "\tfmovem $0x%x,-(sp)\n", mask & 0xff);       \
        !           512:   mask = 0;                                                    \
        !           513:   for (regno = 0; regno < 16; regno++)                         \
        !           514:     if (regs_ever_live[regno] && ! call_used_regs[regno])      \
        !           515:        mask |= 1 << (15 - regno);                              \
        !           516:   if (frame_pointer_needed)                                    \
        !           517:     mask &= ~ (1 << (15-FRAME_POINTER_REGNUM));                        \
        !           518:   if (exact_log2 (mask) >= 0)                                  \
        !           519:     fprintf (FILE, "\tmovel %s,-(sp)\n", reg_names[15 - exact_log2 (mask)]);  \
        !           520:   else if (mask) fprintf (FILE, "\tmovem $0x%x,-(sp)\n", mask); }
        !           521: 
        !           522: /* Must put address in  %a0 , not  %d0 . -- LGM, 7/15/88 */
        !           523: /* UNOS ?? */
        !           524: #undef FUNCTION_PROFILER
        !           525: #define FUNCTION_PROFILER(FILE, LABEL_NO)      \
        !           526:     fprintf (FILE, "\tmovl &LP%%%d,%%a0\n\tjsr mcount\n", (LABEL_NO))
        !           527: 
        !           528: /* This macro generates the assembly code for function exit,
        !           529:    on machines that need it.  If FUNCTION_EPILOGUE is not defined
        !           530:    then individual return instructions are generated for each
        !           531:    return statement.  Args are same as for FUNCTION_PROLOGUE.
        !           532: 
        !           533:    The function epilogue should not depend on the current stack pointer!
        !           534:    It should use the frame pointer only.  This is mandatory because
        !           535:    of alloca; we also take advantage of it to omit stack adjustments
        !           536:    before returning.  */
        !           537: 
        !           538: #undef FUNCTION_EPILOGUE
        !           539: #define FUNCTION_EPILOGUE(FILE, SIZE) \
        !           540: { register int regno;                                          \
        !           541:   register int mask, fmask;                                    \
        !           542:   register int nregs;                                          \
        !           543:   int offset, foffset, fpoffset;                               \
        !           544:   extern char call_used_regs[];                                        \
        !           545:   int fsize = ((SIZE) + 3) & -4;                               \
        !           546:   int big = 0;                                                 \
        !           547:   nregs = 0;  fmask = 0; fpoffset = 0;                         \
        !           548:   for (regno = 24 ; regno < 56 ; regno++)                      \
        !           549:     if (regs_ever_live[regno] && ! call_used_regs[regno])      \
        !           550:       nregs++;                                                 \
        !           551:   fpoffset = nregs*8;                                          \
        !           552:   nregs = 0;                                                   \
        !           553:   for (regno = 16; regno < 24; regno++)                                \
        !           554:     if (regs_ever_live[regno] && ! call_used_regs[regno])      \
        !           555:       { nregs++; fmask |= 1 << (23 - regno); }                 \
        !           556:   foffset = fpoffset + nregs * 12;                             \
        !           557:   nregs = 0;  mask = 0;                                                \
        !           558:   if (frame_pointer_needed) regs_ever_live[FRAME_POINTER_REGNUM] = 0; \
        !           559:   for (regno = 0; regno < 16; regno++)                         \
        !           560:     if (regs_ever_live[regno] && ! call_used_regs[regno])      \
        !           561:       { nregs++; mask |= 1 << regno; }                         \
        !           562:   offset = foffset + nregs * 4;                                        \
        !           563:   if (offset + fsize >= 0x8000                                         \
        !           564:       && frame_pointer_needed                                  \
        !           565:       && (mask || fmask || fpoffset))                          \
        !           566:     { fprintf (FILE, "\tmovel $%d,a0\n", -fsize);              \
        !           567:       fsize = 0, big = 1; }                                    \
        !           568:   if (exact_log2 (mask) >= 0) {                                        \
        !           569:     if (big)                                                   \
        !           570:       fprintf (FILE, "\tmovel -%d(a6,a0.l),%s\n",              \
        !           571:               offset + fsize, reg_names[exact_log2 (mask)]);   \
        !           572:     else if (! frame_pointer_needed)                           \
        !           573:       fprintf (FILE, "\tmovel (sp)+,%s\n",                     \
        !           574:               reg_names[exact_log2 (mask)]);                   \
        !           575:     else                                                       \
        !           576:       fprintf (FILE, "\tmovel -%d(a6),%s\n",                   \
        !           577:               offset + fsize, reg_names[exact_log2 (mask)]); } \
        !           578:   else if (mask) {                                             \
        !           579:     if (big)                                                   \
        !           580:       fprintf (FILE, "\tmovem -%d(a6,a0.l),$0x%x\n",           \
        !           581:               offset + fsize, mask);                           \
        !           582:     else if (! frame_pointer_needed)                           \
        !           583:       fprintf (FILE, "\tmovem (sp)+,$0x%x\n", mask);           \
        !           584:     else                                                       \
        !           585:       fprintf (FILE, "\tmovem -%d(a6),$0x%x\n",                \
        !           586:               offset + fsize, mask); }                         \
        !           587:   if (fmask) {                                                 \
        !           588:     if (big)                                                   \
        !           589:       fprintf (FILE, "\tfmovem -%d(a6,a0.l),$0x%x\n",          \
        !           590:               foffset + fsize, fmask);                         \
        !           591:     else if (! frame_pointer_needed)                           \
        !           592:       fprintf (FILE, "\tfmovem (sp)+,$0x%x\n", fmask);         \
        !           593:     else                                                       \
        !           594:       fprintf (FILE, "\tfmovem -%d(a6),$0x%x\n",               \
        !           595:               foffset + fsize, fmask); }                       \
        !           596:   if (fpoffset != 0)                                           \
        !           597:     for (regno = 55; regno >= 24; regno--)                     \
        !           598:       if (regs_ever_live[regno] && ! call_used_regs[regno]) {  \
        !           599:        if (big)                                                \
        !           600:          fprintf(FILE, "\tfpmoved -%d(a6,a0.l), %s\n", \
        !           601:                  fpoffset + fsize, reg_names[regno]);          \
        !           602:        else if (! frame_pointer_needed)                        \
        !           603:          fprintf(FILE, "\tfpmoved (sp)+, %s\n",                        \
        !           604:                  reg_names[regno]);                            \
        !           605:        else                                                    \
        !           606:          fprintf(FILE, "\tfpmoved -%d(a6), %s\n",              \
        !           607:                  fpoffset + fsize, reg_names[regno]);          \
        !           608:        fpoffset -= 8;                                          \
        !           609:       }                                                                \
        !           610:   if (frame_pointer_needed)                                    \
        !           611:     fprintf (FILE, "\tunlk a6\n");                             \
        !           612:   if (current_function_pops_args)                              \
        !           613:     fprintf (FILE, "\trtd $%d\n", current_function_pops_args); \
        !           614:   else fprintf (FILE, "\trts\n"); }
        !           615: 

unix.superglobalmegacorp.com

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