|
|
1.1 ! root 1: /* Definitions of target machine for GNU compiler. Apollo 680X0 version. ! 2: Copyright (C) 1989,1992 Free Software Foundation, Inc. ! 3: ! 4: This file is part of GNU CC. ! 5: ! 6: GNU CC is free software; you can redistribute it and/or modify ! 7: it under the terms of the GNU General Public License as published by ! 8: the Free Software Foundation; either version 2, or (at your option) ! 9: any later version. ! 10: ! 11: GNU CC is distributed in the hope that it will be useful, ! 12: but WITHOUT ANY WARRANTY; without even the implied warranty of ! 13: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ! 14: GNU General Public License for more details. ! 15: ! 16: You should have received a copy of the GNU General Public License ! 17: along with GNU CC; see the file COPYING. If not, write to ! 18: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ ! 19: ! 20: #include "m68k/m68k.h" ! 21: ! 22: /* This symbol may be tested in other files for special Apollo handling */ ! 23: ! 24: #define TM_APOLLO ! 25: ! 26: /* See m68k.h. 7 means 68020 with 68881. */ ! 27: ! 28: #ifndef TARGET_DEFAULT ! 29: #define TARGET_DEFAULT 7 ! 30: #endif ! 31: ! 32: /* Target switches for the Apollo is the same as in m68k.h, except ! 33: there is no Sun FPA. */ ! 34: ! 35: #undef TARGET_SWITCHES ! 36: #define TARGET_SWITCHES \ ! 37: { { "68020", 5}, \ ! 38: { "c68020", 5}, \ ! 39: { "68881", 2}, \ ! 40: { "bitfield", 4}, \ ! 41: { "68000", -5}, \ ! 42: { "c68000", -5}, \ ! 43: { "soft-float", -0102}, \ ! 44: { "nobitfield", -4}, \ ! 45: { "rtd", 8}, \ ! 46: { "nortd", -8}, \ ! 47: { "short", 040}, \ ! 48: { "noshort", -040}, \ ! 49: { "", TARGET_DEFAULT}} ! 50: ! 51: /* Define __HAVE_68881__ in preprocessor, ! 52: according to the -m flags. ! 53: This will control the use of inline 68881 insns in certain macros. ! 54: Also inform the program which CPU this is for. */ ! 55: ! 56: #if TARGET_DEFAULT & 02 ! 57: ! 58: /* -m68881 is the default */ ! 59: #define CPP_SPEC \ ! 60: "%{!msoft-float:%{mfpa:-D__HAVE_FPA__ }%{!mfpa:-D__HAVE_68881__ }}\ ! 61: %{!ansi:%{m68000:-Dmc68010 }%{mc68000:-Dmc68010 }%{!mc68000:%{!m68000:-Dmc68020 }}\ ! 62: %{!ansi:-D_APOLLO_SOURCE}}" ! 63: ! 64: #else ! 65: ! 66: /* -msoft-float is the default */ ! 67: #define CPP_SPEC \ ! 68: "%{m68881:-D__HAVE_68881__ }%{mfpa:-D__HAVE_FPA__ }\ ! 69: %{!ansi:%{m68000:-Dmc68010 }%{mc68000:-Dmc68010 }%{!mc68000:%{!m68000:-Dmc68020 }}\ ! 70: %{!ansi:-D_APOLLO_SOURCE}}" ! 71: ! 72: #endif ! 73: ! 74: /* Names to predefine in the preprocessor for this target machine. */ ! 75: /* These are the ones defined by Apollo, plus mc68000 for uniformity with ! 76: GCC on other 68000 systems. */ ! 77: ! 78: #define CPP_PREDEFINES "-Dapollo -Daegis -Dunix -Asystem(unix) -Acpu(m68k) -Amachine(m68k)" ! 79: ! 80: /* cpp has to support a #sccs directive for the /usr/include files */ ! 81: ! 82: #define SCCS_DIRECTIVE ! 83: ! 84: /* Allow #ident but output nothing for it. */ ! 85: ! 86: #define IDENT_DIRECTIVE ! 87: #define ASM_OUTPUT_IDENT(FILE, NAME) ! 88: ! 89: /* Allow dollarsigns in identifiers */ ! 90: ! 91: #define DOLLARS_IN_IDENTIFIERS 2 ! 92: ! 93: /* -m68000 requires special flags to the assembler. */ ! 94: ! 95: #define ASM_SPEC \ ! 96: "%{m68000:-mc68010}%{mc68000:-mc68010}%{!mc68000:%{!m68000:-mc68020}}" ! 97: ! 98: /* STARTFILE_SPEC ! 99: Note that includes knowledge of the default specs for gcc, ie. no ! 100: args translates to the same effect as -m68881 */ ! 101: ! 102: #if TARGET_DEFAULT & 2 ! 103: /* -m68881 is the default */ ! 104: #define STARTFILE_SPEC \ ! 105: "%{pg:gcrt0.o%s}%{!pg:%{p:mcrt0.o%s}%{!p:crt0.o%s}}" ! 106: #else ! 107: /* -msoft-float is the default */ ! 108: #define STARTFILE_SPEC \ ! 109: "%{pg:gcrt0.o%s}%{!pg:%{p:mcrt0.o%s}%{!p:crt0.o%s}}" ! 110: #endif ! 111: ! 112: /* Specify library to handle `-a' basic block profiling. */ ! 113: ! 114: #define LIB_SPEC "%{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p} \ ! 115: %{a:/usr/lib/bb_link.o} " ! 116: ! 117: /* Debugging is not supported yet */ ! 118: ! 119: #undef DBX_DEBUGGING_INFO ! 120: #undef SDB_DEBUGGING_INFO ! 121: ! 122: /* We have atexit(2). So C++ can use it for global destructors. */ ! 123: ! 124: #if 0 /* [email protected] says people are still using sr10.2 ! 125: and it does not support atexit. */ ! 126: #define HAVE_ATEXIT ! 127: #endif ! 128: ! 129: /* Every structure or union's size must be a multiple of 2 bytes. */ ! 130: ! 131: #define STRUCTURE_SIZE_BOUNDARY 16 ! 132: ! 133: /* Boundary (in *bits*) on which stack pointer should be aligned. */ ! 134: #undef STACK_BOUNDARY ! 135: #define STACK_BOUNDARY 32 ! 136: ! 137: /* Functions which return large structures get the address ! 138: to place the wanted value from a hidden parameter. */ ! 139: ! 140: #undef PCC_STATIC_STRUCT_RETURN ! 141: #undef STRUCT_VALUE_REGNUM ! 142: #define STRUCT_VALUE 0 ! 143: #define STRUCT_VALUE_INCOMING 0 ! 144: ! 145: /* Specify how to pad function arguments. ! 146: Arguments are not padded at all; the stack is kept aligned on long ! 147: boundaries. */ ! 148: ! 149: #define FUNCTION_ARG_PADDING(mode, size) none ! 150: ! 151: /* The definition of this macro imposes a limit on the size of ! 152: an aggregate object which can be treated as if it were a scalar ! 153: object. */ ! 154: ! 155: #define MAX_FIXED_MODE_SIZE BITS_PER_WORD ! 156: ! 157: /* The definition of this macro implies that there are cases where ! 158: a scalar value cannot be returned in registers. ! 159: For Apollo, anything larger than one integer register is returned ! 160: using the structure-value mechanism, i.e. objects of DFmode are ! 161: returned that way. */ ! 162: ! 163: #define RETURN_IN_MEMORY(type) \ ! 164: (TYPE_MODE (type) == BLKmode \ ! 165: || GET_MODE_SIZE (TYPE_MODE (type)) > UNITS_PER_WORD) ! 166: ! 167: /* In order to link with Apollo libraries, we can't prefix external ! 168: symbols with an underscore. */ ! 169: ! 170: #undef USER_LABEL_PREFIX ! 171: ! 172: /* Use a prefix for local labels, just to be on the save side. */ ! 173: ! 174: #undef LOCAL_LABEL_PREFIX ! 175: #define LOCAL_LABEL_PREFIX "." ! 176: ! 177: /* Use a register prefix to avoid clashes with external symbols (classic ! 178: example: `extern char PC;' in termcap). */ ! 179: ! 180: #undef REGISTER_PREFIX ! 181: #define REGISTER_PREFIX "%" ! 182: ! 183: /* In the machine description we can't use %R, because it will not be seen ! 184: by ASM_FPRINTF. (Isn't that a design bug?). */ ! 185: ! 186: #undef REGISTER_PREFIX_MD ! 187: #define REGISTER_PREFIX_MD "%%" ! 188: ! 189: /* config/m68k.md has an explicit reference to the program counter, ! 190: prefix this by the register prefix. */ ! 191: ! 192: #define ASM_RETURN_CASE_JUMP return "jmp %%pc@(2,%0:w)" ! 193: ! 194: ! 195: /* Here are the new register names. */ ! 196: ! 197: #undef REGISTER_NAMES ! 198: #ifndef SUPPORT_SUN_FPA ! 199: #define REGISTER_NAMES \ ! 200: {"%d0", "%d1", "%d2", "%d3", "%d4", "%d5", "%d6", "%d7", \ ! 201: "%a0", "%a1", "%a2", "%a3", "%a4", "%a5", "%a6", "%sp", \ ! 202: "%fp0", "%fp1", "%fp2", "%fp3", "%fp4", "%fp5", "%fp6", "%fp7" } ! 203: #else /* SUPPORTED_SUN_FPA */ ! 204: #define REGISTER_NAMES \ ! 205: {"%d0", "%d1", "%d2", "%d3", "%d4", "%d5", "%d6", "%d7", \ ! 206: "%a0", "%a1", "%a2", "%a3", "%a4", "%a5", "%a6", "%sp", \ ! 207: "%fp0", "%fp1", "%fp2", "%fp3", "%fp4", "%fp5", "%fp6", "%fp7", \ ! 208: "%fpa0", "%fpa1", "%fpa2", "%fpa3", "%fpa4", "%fpa5", "%fpa6", "%fpa7", \ ! 209: "%fpa8", "%fpa9", "%fpa10", "%fpa11", "%fpa12", "%fpa13", "%fpa14", "%fpa15", \ ! 210: "%fpa16", "%fpa17", "%fpa18", "%fpa19", "%fpa20", "%fpa21", "%fpa22", "%fpa23", \ ! 211: "%fpa24", "%fpa25", "%fpa26", "%fpa27", "%fpa28", "%fpa29", "%fpa30", "%fpa31" } ! 212: #endif /* defined SUPPORT_SUN_FPA */
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.