|
|
1.1 ! root 1: /* Definitions of target machine for GNU compiler, for AMD Am29000 CPU, Unix. ! 2: Copyright (C) 1991 Free Software Foundation, Inc. ! 3: Contributed by Richard Kenner ([email protected]) ! 4: ! 5: This file is part of GNU CC. ! 6: ! 7: GNU CC is free software; you can redistribute it and/or modify ! 8: it under the terms of the GNU General Public License as published by ! 9: the Free Software Foundation; either version 2, or (at your option) ! 10: any later version. ! 11: ! 12: GNU CC is distributed in the hope that it will be useful, ! 13: but WITHOUT ANY WARRANTY; without even the implied warranty of ! 14: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ! 15: GNU General Public License for more details. ! 16: ! 17: You should have received a copy of the GNU General Public License ! 18: along with GNU CC; see the file COPYING. If not, write to ! 19: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ ! 20: ! 21: ! 22: /* This is mostly the same as a29k.h, except that we define unix instead of ! 23: EPI and define unix-style machine names. */ ! 24: ! 25: #include "a29k/a29k.h" ! 26: ! 27: /* Set our default target to be the 29050; that is the more interesting chip ! 28: for Unix systems. */ ! 29: ! 30: #undef TARGET_DEFAULT ! 31: #define TARGET_DEFAULT (1+2+8+64) ! 32: ! 33: #undef CPP_PREDEFINES ! 34: #define CPP_PREDEFINES "-Dam29k -Da29k -Dam29000 -Asystem(unix) -Acpu(a29k) -Amachine(a29k)" ! 35: ! 36: #undef CPP_SPEC ! 37: #define CPP_SPEC "%{!m29000:-Dam29050 -D__am29050__}" ! 38: ! 39: /* Use a default linker configuration file. */ ! 40: #undef LINK_SPEC ! 41: #define LINK_SPEC "-T default.gld%s" ! 42: ! 43: /* Define the magic numbers that we recognize as COFF. */ ! 44: ! 45: #define MY_ISCOFF(magic) ((magic) == SIPFBOMAGIC || (magic) == SIPRBOMAGIC) ! 46: ! 47: /* For some systems, it is best if double-word objects are aligned on a ! 48: doubleword boundary. We want to maintain compatibility with MetaWare in ! 49: a29k.h, but do not feel constrained to do so here. */ ! 50: ! 51: #undef BIGGEST_ALIGNMENT ! 52: #define BIGGEST_ALIGNMENT 64 ! 53: ! 54: /* Add shared data as a kludge for now. */ ! 55: ! 56: #undef ASM_FILE_START ! 57: #define ASM_FILE_START(FILE) \ ! 58: { char *p, *after_dir = main_input_filename; \ ! 59: if (TARGET_29050) \ ! 60: fprintf (FILE, "\t.cputype 29050\n"); \ ! 61: for (p = main_input_filename; *p; p++) \ ! 62: if (*p == '/') \ ! 63: after_dir = p + 1; \ ! 64: fprintf (FILE, "\t.file "); \ ! 65: output_quoted_string (FILE, after_dir); \ ! 66: fprintf (FILE, "\n"); \ ! 67: if (flag_shared_data) \ ! 68: fprintf (FILE, "\t.sect .shdata,data\n"); \ ! 69: fprintf (FILE, "\t.sect .lit,lit\n"); } ! 70: ! 71: /* Output before shared data. */ ! 72: ! 73: #define SHARED_SECTION_ASM_OP "\t.use .shdata" ! 74: ! 75: /* If we want shared data, we have to turn off commons. */ ! 76: ! 77: #define OVERRIDE_OPTIONS if (flag_shared_data) flag_no_common = 1; ! 78: ! 79: #if 0 /* This would be needed except that the 29k doesn't have strict ! 80: alignment requirements. */ ! 81: ! 82: #define FUNCTION_ARG_BOUNDARY(MODE, TYPE) \ ! 83: (((TYPE) != 0) \ ! 84: ? ((TYPE_ALIGN(TYPE) <= PARM_BOUNDARY) \ ! 85: ? PARM_BOUNDARY \ ! 86: : TYPE_ALIGN(TYPE)) \ ! 87: : ((GET_MODE_ALIGNMENT(MODE) <= PARM_BOUNDARY) \ ! 88: ? PARM_BOUNDARY \ ! 89: : GET_MODE_ALIGNMENT(MODE))) ! 90: #endif
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.