1992-01-15 17:12:35 -05:00
|
|
|
/* Definitions of target machine for GNU compiler, for AMD Am29000 CPU, Unix.
|
1994-11-19 05:36:13 -05:00
|
|
|
Copyright (C) 1991, 1993, 1994 Free Software Foundation, Inc.
|
|
|
|
Contributed by Richard Kenner (kenner@vlsi1.ultra.nyu.edu)
|
1992-01-15 17:12:35 -05:00
|
|
|
|
|
|
|
This file is part of GNU CC.
|
|
|
|
|
|
|
|
GNU CC is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2, or (at your option)
|
|
|
|
any later version.
|
|
|
|
|
|
|
|
GNU CC is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with GNU CC; see the file COPYING. If not, write to
|
|
|
|
the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
|
|
|
|
|
|
|
|
|
|
|
|
/* This is mostly the same as a29k.h, except that we define unix instead of
|
|
|
|
EPI and define unix-style machine names. */
|
|
|
|
|
1992-12-26 21:32:35 -05:00
|
|
|
#include "a29k/a29k.h"
|
1992-01-15 17:12:35 -05:00
|
|
|
|
|
|
|
/* Set our default target to be the 29050; that is the more interesting chip
|
|
|
|
for Unix systems. */
|
|
|
|
|
|
|
|
#undef TARGET_DEFAULT
|
1993-12-23 07:33:56 -05:00
|
|
|
#define TARGET_DEFAULT (1+2+16+128)
|
1992-01-15 17:12:35 -05:00
|
|
|
|
|
|
|
#undef CPP_PREDEFINES
|
1993-10-02 04:55:06 -04:00
|
|
|
#define CPP_PREDEFINES "-Dam29k -Da29k -Dam29000 -Asystem(unix) -Acpu(a29k) -Amachine(a29k)"
|
1992-01-15 17:12:35 -05:00
|
|
|
|
|
|
|
#undef CPP_SPEC
|
|
|
|
#define CPP_SPEC "%{!m29000:-Dam29050 -D__am29050__}"
|
|
|
|
|
1992-12-11 07:15:43 -05:00
|
|
|
/* Use a default linker configuration file. */
|
1992-02-13 18:46:18 -05:00
|
|
|
#undef LINK_SPEC
|
1992-12-11 07:15:43 -05:00
|
|
|
#define LINK_SPEC "-T default.gld%s"
|
1992-02-13 18:46:18 -05:00
|
|
|
|
1993-01-27 06:46:02 -05:00
|
|
|
/* Define the magic numbers that we recognize as COFF. */
|
|
|
|
|
|
|
|
#define MY_ISCOFF(magic) ((magic) == SIPFBOMAGIC || (magic) == SIPRBOMAGIC)
|
|
|
|
|
1992-01-15 17:12:35 -05:00
|
|
|
/* For some systems, it is best if double-word objects are aligned on a
|
|
|
|
doubleword boundary. We want to maintain compatibility with MetaWare in
|
|
|
|
a29k.h, but do not feel constrained to do so here. */
|
|
|
|
|
|
|
|
#undef BIGGEST_ALIGNMENT
|
|
|
|
#define BIGGEST_ALIGNMENT 64
|
1992-05-15 01:02:54 -04:00
|
|
|
|
1992-08-17 07:32:34 -04:00
|
|
|
/* Add shared data as a kludge for now. */
|
|
|
|
|
|
|
|
#undef ASM_FILE_START
|
|
|
|
#define ASM_FILE_START(FILE) \
|
|
|
|
{ char *p, *after_dir = main_input_filename; \
|
|
|
|
if (TARGET_29050) \
|
|
|
|
fprintf (FILE, "\t.cputype 29050\n"); \
|
|
|
|
for (p = main_input_filename; *p; p++) \
|
|
|
|
if (*p == '/') \
|
|
|
|
after_dir = p + 1; \
|
1993-09-27 20:23:58 -04:00
|
|
|
fprintf (FILE, "\t.file "); \
|
|
|
|
output_quoted_string (FILE, after_dir); \
|
|
|
|
fprintf (FILE, "\n"); \
|
1992-08-17 07:32:34 -04:00
|
|
|
if (flag_shared_data) \
|
|
|
|
fprintf (FILE, "\t.sect .shdata,data\n"); \
|
|
|
|
fprintf (FILE, "\t.sect .lit,lit\n"); }
|
|
|
|
|
|
|
|
/* Output before shared data. */
|
|
|
|
|
|
|
|
#define SHARED_SECTION_ASM_OP "\t.use .shdata"
|
|
|
|
|
|
|
|
/* If we want shared data, we have to turn off commons. */
|
|
|
|
|
|
|
|
#define OVERRIDE_OPTIONS if (flag_shared_data) flag_no_common = 1;
|
|
|
|
|
1994-11-19 05:36:13 -05:00
|
|
|
/* Default to -fno-pcc-struct-return, since we don't have to worry about
|
|
|
|
compatibility. */
|
|
|
|
#define DEFAULT_PCC_STRUCT_RETURN 0
|
|
|
|
|
1992-05-15 01:02:54 -04:00
|
|
|
#if 0 /* This would be needed except that the 29k doesn't have strict
|
|
|
|
alignment requirements. */
|
|
|
|
|
|
|
|
#define FUNCTION_ARG_BOUNDARY(MODE, TYPE) \
|
|
|
|
(((TYPE) != 0) \
|
|
|
|
? ((TYPE_ALIGN(TYPE) <= PARM_BOUNDARY) \
|
|
|
|
? PARM_BOUNDARY \
|
|
|
|
: TYPE_ALIGN(TYPE)) \
|
|
|
|
: ((GET_MODE_ALIGNMENT(MODE) <= PARM_BOUNDARY) \
|
|
|
|
? PARM_BOUNDARY \
|
|
|
|
: GET_MODE_ALIGNMENT(MODE)))
|
|
|
|
#endif
|