aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xdistrib/build-kernel.sh12
l---------distrib/kernel-toolchain/android-kernel-toolchain-ar1
l---------distrib/kernel-toolchain/android-kernel-toolchain-as1
l---------distrib/kernel-toolchain/android-kernel-toolchain-gcc1
l---------distrib/kernel-toolchain/android-kernel-toolchain-ld1
l---------distrib/kernel-toolchain/android-kernel-toolchain-nm1
l---------distrib/kernel-toolchain/android-kernel-toolchain-objcopy1
l---------distrib/kernel-toolchain/android-kernel-toolchain-objdump1
l---------distrib/kernel-toolchain/android-kernel-toolchain-ranlib1
l---------distrib/kernel-toolchain/android-kernel-toolchain-strip1
-rwxr-xr-xdistrib/kernel-toolchain/toolbox.sh52
11 files changed, 73 insertions, 0 deletions
diff --git a/distrib/build-kernel.sh b/distrib/build-kernel.sh
index 0329156..20d85c6 100755
--- a/distrib/build-kernel.sh
+++ b/distrib/build-kernel.sh
@@ -182,6 +182,18 @@ else
echo "Auto-config: -j$JOBS"
fi
+
+# Special magic redirection with our magic toolbox script
+# This is needed to add extra compiler flags for x86
+#
+# We could use that for ARM, but don't need to at the moment.
+#
+if [ "$ARCH" = "x86" ]; then
+ export REAL_CROSS_COMPILE="$CROSS_COMPILE"
+ export ARCH
+ CROSS_COMPILE=$(dirname "$0")/kernel-toolchain/android-kernel-toolchain-
+fi
+
# Do the build
#
rm -f include/asm &&
diff --git a/distrib/kernel-toolchain/android-kernel-toolchain-ar b/distrib/kernel-toolchain/android-kernel-toolchain-ar
new file mode 120000
index 0000000..dc0b8a0
--- /dev/null
+++ b/distrib/kernel-toolchain/android-kernel-toolchain-ar
@@ -0,0 +1 @@
+toolbox.sh \ No newline at end of file
diff --git a/distrib/kernel-toolchain/android-kernel-toolchain-as b/distrib/kernel-toolchain/android-kernel-toolchain-as
new file mode 120000
index 0000000..dc0b8a0
--- /dev/null
+++ b/distrib/kernel-toolchain/android-kernel-toolchain-as
@@ -0,0 +1 @@
+toolbox.sh \ No newline at end of file
diff --git a/distrib/kernel-toolchain/android-kernel-toolchain-gcc b/distrib/kernel-toolchain/android-kernel-toolchain-gcc
new file mode 120000
index 0000000..dc0b8a0
--- /dev/null
+++ b/distrib/kernel-toolchain/android-kernel-toolchain-gcc
@@ -0,0 +1 @@
+toolbox.sh \ No newline at end of file
diff --git a/distrib/kernel-toolchain/android-kernel-toolchain-ld b/distrib/kernel-toolchain/android-kernel-toolchain-ld
new file mode 120000
index 0000000..dc0b8a0
--- /dev/null
+++ b/distrib/kernel-toolchain/android-kernel-toolchain-ld
@@ -0,0 +1 @@
+toolbox.sh \ No newline at end of file
diff --git a/distrib/kernel-toolchain/android-kernel-toolchain-nm b/distrib/kernel-toolchain/android-kernel-toolchain-nm
new file mode 120000
index 0000000..dc0b8a0
--- /dev/null
+++ b/distrib/kernel-toolchain/android-kernel-toolchain-nm
@@ -0,0 +1 @@
+toolbox.sh \ No newline at end of file
diff --git a/distrib/kernel-toolchain/android-kernel-toolchain-objcopy b/distrib/kernel-toolchain/android-kernel-toolchain-objcopy
new file mode 120000
index 0000000..dc0b8a0
--- /dev/null
+++ b/distrib/kernel-toolchain/android-kernel-toolchain-objcopy
@@ -0,0 +1 @@
+toolbox.sh \ No newline at end of file
diff --git a/distrib/kernel-toolchain/android-kernel-toolchain-objdump b/distrib/kernel-toolchain/android-kernel-toolchain-objdump
new file mode 120000
index 0000000..dc0b8a0
--- /dev/null
+++ b/distrib/kernel-toolchain/android-kernel-toolchain-objdump
@@ -0,0 +1 @@
+toolbox.sh \ No newline at end of file
diff --git a/distrib/kernel-toolchain/android-kernel-toolchain-ranlib b/distrib/kernel-toolchain/android-kernel-toolchain-ranlib
new file mode 120000
index 0000000..dc0b8a0
--- /dev/null
+++ b/distrib/kernel-toolchain/android-kernel-toolchain-ranlib
@@ -0,0 +1 @@
+toolbox.sh \ No newline at end of file
diff --git a/distrib/kernel-toolchain/android-kernel-toolchain-strip b/distrib/kernel-toolchain/android-kernel-toolchain-strip
new file mode 120000
index 0000000..dc0b8a0
--- /dev/null
+++ b/distrib/kernel-toolchain/android-kernel-toolchain-strip
@@ -0,0 +1 @@
+toolbox.sh \ No newline at end of file
diff --git a/distrib/kernel-toolchain/toolbox.sh b/distrib/kernel-toolchain/toolbox.sh
new file mode 100755
index 0000000..94e89b2
--- /dev/null
+++ b/distrib/kernel-toolchain/toolbox.sh
@@ -0,0 +1,52 @@
+#!/bin/sh
+#
+# This is a wrapper around our x86 toolchain that allows us to add a few
+# compiler flags.
+# The issue is that our x86 toolchain is NDK-compatible, and hence enforces
+# -mfpmath=sse and -fpic by default. When building the kernel, we need to
+# disable this.
+#
+# Also support ccache compilation if USE_CCACHE is defined as "1"
+#
+
+# REAL_CROSS_COMPILE must be defined, and its value must be one of the
+# CROSS_COMPILE values that are supported by the Kernel build system
+# (e.g. "i686-android-linux-")
+#
+if [ -z "$REAL_CROSS_COMPILE" ]; then
+ echo "ERROR: The REAL_CROSS_COMPILE environment variable should be defined!"
+ exit 1
+fi
+
+# ARCH must also be defined before calling this script, e.g. 'arm' or 'x86'
+#
+if [ -z "$ARCH" ]; then
+ echo "ERROR: ARCH must be defined!"
+ exit 1
+fi
+
+# Common prefix for all fake toolchain programs, which are all really
+# symlinks to this script, i.e.
+#
+# $PROGPREFIX-gcc --> $0
+# $PROGPREFIX-ld --> $0
+# etc...
+#
+PROGPREFIX=android-kernel-toolchain-
+
+# Get program name, must be of the form $PROGPREFIX-<suffix>, where
+# <suffix> can be 'gcc', 'ld', etc... We expect that the fake toolchain
+# files are all symlinks to this script.
+#
+PROGNAME=$(basename "$0")
+PROGSUFFIX=${PROGNAME##$PROGPREFIX}
+
+EXTRA_FLAGS=
+
+# Special case #1: For x86, disable SSE FPU arithmetic, and PIC code
+if [ "$ARCH" = "x86" -a "$PROGSUFFIX" = gcc ]; then
+ EXTRA_FLAGS=$EXTRA_FLAGS" -mfpmath=387 -fno-pic"
+fi
+
+# Invoke real cross-compiler toolchain program now
+${REAL_CROSS_COMPILE}$PROGSUFFIX $EXTRA_FLAGS "$@"