1995-02-01 16:58:22 -05:00
|
|
|
/* Core target definitions for GNU compiler
|
|
|
|
for IBM RS/6000 PowerPC targeted to embedded ELF systems.
|
|
|
|
Copyright (C) 1995 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, 675 Mass Ave, Cambridge, MA 02139, USA. */
|
|
|
|
|
|
|
|
/* eABI local switches */
|
|
|
|
/* Set PCC_BITFIELD_TYPE_MATTERS to 0 to ignore the type of bitfields
|
|
|
|
when calculating alignment. */
|
|
|
|
#define MASK_NO_BITFIELD_TYPE 0x40000000
|
1995-02-16 11:49:44 -05:00
|
|
|
#define MASK_STRICT_ALIGN 0x20000000
|
1995-02-01 16:58:22 -05:00
|
|
|
|
|
|
|
#define TARGET_NO_BITFIELD_TYPE (target_flags & MASK_NO_BITFIELD_TYPE)
|
|
|
|
#define TARGET_BITFIELD_TYPE (! TARGET_NO_BITFIELD_TYPE)
|
1995-02-16 11:49:44 -05:00
|
|
|
#define TARGET_STRICT_ALIGN (target_flags & MASK_STRICT_ALIGN)
|
1995-02-01 16:58:22 -05:00
|
|
|
|
|
|
|
#define SUBTARGET_SWITCHES \
|
|
|
|
{ "bit-align", -MASK_NO_BITFIELD_TYPE }, \
|
1995-02-16 11:49:44 -05:00
|
|
|
{ "no-bit-align", MASK_NO_BITFIELD_TYPE }, \
|
|
|
|
{ "strict-align", MASK_STRICT_ALIGN }, \
|
|
|
|
{ "no-strict-align", -MASK_STRICT_ALIGN },
|
1995-02-01 16:58:22 -05:00
|
|
|
|
|
|
|
#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)
|
|
|
|
|
1995-02-16 11:49:44 -05:00
|
|
|
/* 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. */
|
|
|
|
#undef STRICT_ALIGNMENT
|
|
|
|
#define STRICT_ALIGNMENT (TARGET_STRICT_ALIGN)
|
|
|
|
|
1995-02-01 16:58:22 -05:00
|
|
|
/* 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
|
|
|
|
|
|
|
|
#undef TARGET_VERSION
|
|
|
|
#define TARGET_VERSION fprintf (stderr, " (PowerPC Embedded)");
|
|
|
|
|
|
|
|
/* FIXME: These should actually indicate PowerPC, when there is some
|
|
|
|
standard way of expressing that. */
|
|
|
|
#undef CPP_PREDEFINES
|
|
|
|
#define CPP_PREDEFINES \
|
|
|
|
"-DPPC -D__embedded__ -Asystem(embedded) -Acpu(powerpc) -Amachine(powerpc)"
|