summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPatrick Georgi <patrick.georgi@coresystems.de>2010-02-10 20:31:38 +0000
committerPatrick Georgi <patrick.georgi@coresystems.de>2010-02-10 20:31:38 +0000
commite82f4754ee905437d434f0d58c03e9ee2929224e (patch)
tree9b3df98755e03d56cd52a29e0d8c1fab3988b5ba
parent942a40da3ae2688ab9303d54d8b0fffdd98002b7 (diff)
downloadcoreboot-e82f4754ee905437d434f0d58c03e9ee2929224e.tar.xz
Improve compiler detection and configuration in xcompile.
Move -fno-stack-protector support from Makefile to xcompile. Signed-off-by: Patrick Georgi <patrick.georgi@coresystems.de> Acked-by: Stefan Reinauer <stepan@coresystems.de> git-svn-id: svn://svn.coreboot.org/coreboot/trunk@5113 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
-rw-r--r--Makefile14
-rw-r--r--util/xcompile/xcompile88
2 files changed, 73 insertions, 29 deletions
diff --git a/Makefile b/Makefile
index 6cf1ff9c50..65a740595a 100644
--- a/Makefile
+++ b/Makefile
@@ -221,19 +221,7 @@ INCLUDES += -I$(shell $(CC) -print-search-dirs | head -n 1 | cut -d' ' -f2)inclu
INCLUDES += -I$(top)/util/x86emu/include
INCLUDES += -include $(obj)/build.h
-try-run= $(shell set -e; \
-TMP=".$$$$.tmp"; \
-if ($(1)) > /dev/null 2>&1; \
-then echo "$(2)"; \
-else echo "$(3)"; \
-fi; rm -rf "$$TMP")
-
-cc-option= $(call try-run,\
-$(CC) $(1) -S -xc /dev/null -o "$$TMP", $(1), $(2))
-
-STACKPROTECT += $(call cc-option, -fno-stack-protector,)
-
-CFLAGS = $(STACKPROTECT) $(INCLUDES) -Os -nostdinc
+CFLAGS = $(INCLUDES) -Os -nostdinc
CFLAGS += -nostdlib -Wall -Wundef -Wstrict-prototypes -Wmissing-prototypes
CFLAGS += -Wwrite-strings -Wredundant-decls -Wno-trigraphs
CFLAGS += -Wstrict-aliasing -Wshadow
diff --git a/util/xcompile/xcompile b/util/xcompile/xcompile
index a8ffa82cc2..5da7874343 100644
--- a/util/xcompile/xcompile
+++ b/util/xcompile/xcompile
@@ -1,3 +1,31 @@
+#!/bin/sh
+#
+# This file is part of the coreboot project.
+#
+# Copyright (C) 2007-2010 coresystems GmbH
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License version 2 as
+# published by the Free Software Foundation.
+#
+# This program 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 this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+#
+
+testcc()
+{
+ echo "_start(void) {}" > .$$$$.c
+ $1 -nostdlib $2 .$$$$.c -o .$$$$.tmp 2>/dev/null >/dev/null
+ ret=$?
+ rm -f .$$$$.c .$$$$.tmp
+ return $ret
+}
for make in make gmake gnumake; do
if [ "`$make --version 2>/dev/null | grep -c GNU`" -gt 0 ]; then
@@ -8,39 +36,67 @@ done
GCCPREFIX=invalid
TMP=`mktemp /tmp/temp.XXXX 2>/dev/null || echo /tmp/temp.78gOIUGz`
-echo "mov %eax, %eax" > ${TMP}.s
-printf "\x7fELF\n" > ${TMP}.compare
-for gccprefixes in `pwd`/util/crossgcc/xgcc/bin/i386-elf- i386-elf- ""; do
- if which ${gccprefixes}as 2>/dev/null >/dev/null; then
- printf ""
- else
+touch $TMP
+
+# This should be a loop over all supported architectures
+TARCH=i386
+TWIDTH=32
+for gccprefixes in `pwd`/util/crossgcc/xgcc/bin/${TARCH}-elf- ${TARCH}-elf- ""; do
+ if ! which ${gccprefixes}as 2>/dev/null >/dev/null; then
continue
fi
rm -f ${TMP}.o
- if ${gccprefixes}as --32 -o ${TMP}.o ${TMP}.s; then
- cut -c-4 ${TMP}.o > ${TMP}.test 2>/dev/null
- if cmp ${TMP}.test ${TMP}.compare; then
+ if ${gccprefixes}as -o ${TMP}.o ${TMP}; then
+ TYPE=`${gccprefixes}objdump -p ${TMP}.o`
+ if [ ${TYPE##* } == "elf${TWIDTH}-${TARCH}" ]; then
+ GCCPREFIX=$gccprefixes
+ ASFLAGS=
+ CFLAGS=
+ LDFLAGS=
+ break
+ fi
+ fi
+ if ${gccprefixes}as --32 -o ${TMP}.o ${TMP}; then
+ TYPE=`${gccprefixes}objdump -p ${TMP}.o`
+ if [ ${TYPE##* } == "elf${TWIDTH}-${TARCH}" ]; then
GCCPREFIX=$gccprefixes
+ ASFLAGS=--32
+ CFLAGS="-m32 "
+ LDFLAGS="-b elf32-i386"
break
fi
fi
done
-rm -f $TMP ${TMP}.s ${TMP}.o ${TMP}.compare ${TMP}.test
+rm -f $TMP ${TMP}.o
if [ "$GCCPREFIX" = "invalid" ]; then
echo '$(error no suitable gcc found)'
exit 1
fi
-cat << afteroptions
-AS:=${GCCPREFIX}as --32
-CC:=${GCCPREFIX}gcc -m32
+CC="${GCCPREFIX}gcc"
+testcc "$CC" "$CFLAGS-fno-stack-protector " && CFLAGS="$CFLAGS-fno-stack-protector "
+testcc "$CC" "$CFLAGS-Wl,--build-id=none " && CFLAGS="$CFLAGS-Wl,--build-id=none "
+
+if which gcc 2>/dev/null >/dev/null; then
+ HOSTCC=gcc
+else
+ HOSTCC=cc
+fi
+
+cat << EOF
+# elf${TWIDTH}-${TARCH} toolchain
+AS:=${GCCPREFIX}as ${ASFLAGS}
+CC:=${GCCPREFIX}gcc ${CFLAGS}
CPP:=${GCCPREFIX}cpp
AR:=${GCCPREFIX}ar
-LD:=${GCCPREFIX}ld -b elf32-i386
+LD:=${GCCPREFIX}ld ${LDFLAGS}
STRIP:=${GCCPREFIX}strip
NM:=${GCCPREFIX}nm
OBJCOPY:=${GCCPREFIX}objcopy
OBJDUMP:=${GCCPREFIX}objdump
-HOSTCC:=gcc
-afteroptions
+
+# native toolchain
+HOSTCC:=${HOSTCC}
+EOF
+