7509c75936
From-SVN: r11093
91 lines
3.1 KiB
C
91 lines
3.1 KiB
C
/* Core target definitions for GNU compiler
|
|
for IBM RS/6000 PowerPC targeted to embedded ELF systems.
|
|
Copyright (C) 1995, 1996 Free Software Foundation, Inc.
|
|
Contributed by Cygnus Support.
|
|
|
|
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, 59 Temple Place - Suite 330,
|
|
Boston, MA 02111-1307, USA. */
|
|
|
|
#include "rs6000/sysv4.h"
|
|
|
|
/* For now, make stabs the default debugging type, not dwarf. */
|
|
#undef PREFERRED_DEBUGGING_TYPE
|
|
#define PREFERRED_DEBUGGING_TYPE DBX_DEBUG
|
|
|
|
/* Make int foo : 8 not cause structures to be aligned to an int boundary */
|
|
|
|
#undef PCC_BITFIELD_TYPE_MATTERS
|
|
#define PCC_BITFIELD_TYPE_MATTERS (TARGET_BITFIELD_TYPE)
|
|
|
|
/* Define this macro to be the value 1 if instructions will fail to
|
|
work if given data not on the nominal alignment. If instructions
|
|
will merely go slower in that case, define this macro as 0.
|
|
|
|
Note, little endian systems trap on unaligned addresses, so never
|
|
turn off strict alignment in that case. */
|
|
#undef STRICT_ALIGNMENT
|
|
#define STRICT_ALIGNMENT (TARGET_STRICT_ALIGN || TARGET_LITTLE_ENDIAN)
|
|
|
|
/* Align stack to 8 byte boundaries, rather than 16 bytes Sys V.4 uses */
|
|
#undef STACK_BOUNDARY
|
|
#define STACK_BOUNDARY 64
|
|
|
|
/* No data type wants to be aligned rounder than this. */
|
|
#undef BIGGEST_ALIGNMENT
|
|
#define BIGGEST_ALIGNMENT 64
|
|
|
|
/* Put PC relative got entries in .got2 */
|
|
#undef MINIMAL_TOC_SECTION_ASM_OP
|
|
#define MINIMAL_TOC_SECTION_ASM_OP \
|
|
((TARGET_RELOCATABLE) ? "\t.section\t\".got2\",\"aw\"" : "\t.section\t\".got1\",\"aw\"")
|
|
|
|
/* Put relocatable data in .data, not .rodata so initialized pointers can be updated */
|
|
#undef CONST_SECTION_ASM_OP
|
|
#define CONST_SECTION_ASM_OP \
|
|
((TARGET_RELOCATABLE) ? "\t.section\t\".data\"\t# .rodata" : "\t.section\t\".rodata\"")
|
|
|
|
/* Invoke an initializer function to set up the GOT */
|
|
#define NAME__MAIN "__eabi"
|
|
|
|
#undef TARGET_VERSION
|
|
#define TARGET_VERSION fprintf (stderr, " (PowerPC Embedded)");
|
|
|
|
#undef CPP_PREDEFINES
|
|
#define CPP_PREDEFINES \
|
|
"-DPPC -D__embedded__ -Asystem(embedded) -Acpu(powerpc) -Amachine(powerpc)"
|
|
|
|
/* Clue the simulator in to use netbsd */
|
|
#undef LINK_START_SPEC
|
|
#define LINK_START_SPEC "%{msim: %{!Ttext*: -Ttext 0x10000000}}"
|
|
|
|
/* Use the simulator crt0 or mvme and libgloss/newlib libraries if desired */
|
|
#undef STARTFILE_SPEC
|
|
#define STARTFILE_SPEC "crti.o%s \
|
|
%{mmvme: mvme-crt0.o%s} \
|
|
%{msim: sim-crt0.o%s}"
|
|
|
|
#undef LIB_SPEC
|
|
#define LIB_SPEC "\
|
|
%{mmvme: -lmvme -lc -lmvme} \
|
|
%{msim: -lsim -lc -lsim}"
|
|
|
|
#undef LIBGCC_SPEC
|
|
#define LIBGCC_SPEC "libgcc.a%s"
|
|
|
|
#undef ENDFILE_SPEC
|
|
#define ENDFILE_SPEC "crtn.o%s"
|