diff options
Diffstat (limited to 'public/xscale-be-elf.inc')
-rw-r--r-- | public/xscale-be-elf.inc | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/public/xscale-be-elf.inc b/public/xscale-be-elf.inc new file mode 100644 index 0000000..bb42dfb --- /dev/null +++ b/public/xscale-be-elf.inc @@ -0,0 +1,62 @@ +# +# Copyright (c) 2002-2008 Sam Leffler, Errno Consulting +# Copyright (c) 2002-2008 Atheros Communications, Inc. +# +# Permission to use, copy, modify, and/or distribute this software for any +# purpose with or without fee is hereby granted, provided that the above +# copyright notice and this permission notice appear in all copies. +# +# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. +# +# $Id: xscale-be-elf.inc,v 1.2 2008/11/10 03:45:03 sam Exp $ +# + +# +# Compilation configuration for building big-endian XScale/arm-elf. +# +# NB: built with AH_REGOPS_FUNC to so that register accesses +# can be done using the Linux readl/writel functions on +# systems that need it. +# +# Reported to work on: +# IXP425 +# + +# +# Built with GNU cross-devel tools: +# +# PREFIX=/pub/gnu +# BINUTILS=binutils-2.14 +# GCC=gcc-3.3.2 +# target=arm-elf +# +# ${BINUTILS}/configure --target=$target --prefix=${PREFIX} +# ${GCC}/configure --target=$target --prefix=${PREFIX} \ +# --enable-languages=c --with-gnu-as --with-gnu-ld \ +# --with-newlib --with-gxx-include-dir=${PREFIX}/$target/include +# +ifndef TOOLPREFIX +TOOLPREFIX= /pub/gnu/bin/arm-elf- +endif +# +CC= ${TOOLPREFIX}gcc +LD= ${TOOLPREFIX}ld +STRIP= ${TOOLPREFIX}strip +OBJCOPY=${TOOLPREFIX}objcopy +NM= ${TOOLPREFIX}nm + +# +# Force register read/write operations to go through a function. +# +AH_REGOPS_FUNC=1 + +LDOPTS= -EB +COPTS+= -DAH_BYTE_ORDER=AH_BIG_ENDIAN +COPTS+= -march=armv4 -mbig-endian -fno-strict-aliasing -fno-common -mapcs-32 \ + -mtune=xscale -mshort-load-bytes |