Prepare build for upcoming arm-linux-androideabi toolchain.
Jing Yu [Thu, 22 Jul 2010 21:27:24 +0000 (14:27 -0700)]
Change-Id: I9b1cd5f0d361d092c24557ae1a2e2e2b85b13aaf

Makefile.in
README
config.sub
configure
configure.ac

index f66edc7..12d355d 100644 (file)
@@ -98,12 +98,12 @@ export      CC_FOR_TARGET="$(TARGET_GCC_BUILDDIR)/gcc/xgcc \
 # 
 # To build libstdc++ with RTTI and exceptions do:
 #
-# CFLAGS_FOR_TARGET= -O2 -Os -g -fexceptions
-# CXXFLAGS_FOR_TARGET=$(CFLAGS_FOR_TARGET) -frtti
+#CFLAGS_FOR_TARGET= -O2 -Os -g -fexceptions
+#CXXFLAGS_FOR_TARGET=$(CFLAGS_FOR_TARGET) -frtti
 # 
 CFLAGS_FOR_TARGET= -O2 -Os -g
 CXXFLAGS_FOR_TARGET=$(CFLAGS_FOR_TARGET)
-LDFLAGS_FOR_TARGET=-mandroid
+LDFLAGS_FOR_TARGET=
 
 # Helper
 prefix-list = $(foreach e, $(2), $(join $1, $e))
@@ -188,7 +188,10 @@ CFLAGS_FOR_TARGET += -DTARGET_POSIX_IO -fno-short-enums
 # ARM specific options.
 ifeq ($(target_cpu),arm)
 GCC_CONFIG_ARGS += --with-float=soft --with-fpu=vfp --with-arch=armv5te \
-       --enable-target-optspace --with-abi=aapcs
+       --enable-target-optspace
+ifneq ($(target_os),linux-androideabi)
+GCC_CONFIG_ARGS += --with-abi=aapcs
+endif
 endif
 
 endif
diff --git a/README b/README
index 9d7dbf0..9711518 100644 (file)
--- a/README
+++ b/README
@@ -12,15 +12,15 @@ The Android tool-chain supports the following hosts:
 
 The Android toolchain supports the following targets:
 
-   a. arm-eabi
-   b. arm-newlib-eabi  (for runnng gcc regression tests)
-   c. i[3456]86-*-linux-gnu, x86_64-*-linux-gnu        (for x86 targets)
-
-Currently we are using a modified arm-eabi target for Android.  To facilitate
-integrating our changes back to the FSF code bases for different tools, we
-may adopt an Android specific target arm-android-eabi some time in the future.
-The arm-newlib-eabi target is mainly used to run the gcc test suite with the
-gnu ARM emulator.
+   a. arm-linux-androideabi
+   b. arm-eabi  (for Android kernel)
+   c. arm-newlib-eabi  (for runnng gcc regression tests)
+   d. i[3456]86-*-linux-gnu, x86_64-*-linux-gnu        (for x86 targets)
+
+Currently we are using arm-linux-androideabi target for general Android use.
+This target is already in gcc upstream. arm-eabi target is only used to
+compile Android kernel. The arm-newlib-eabi target is mainly used to run
+the gcc test suite with the gnu ARM emulator.
 
 2. Configuring the toolchain
 
index 63bfff0..bfbf61d 100755 (executable)
@@ -120,8 +120,9 @@ esac
 # Here we must recognize all the valid KERNEL-OS combinations.
 maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
 case $maybe_os in
-  nto-qnx* | linux-gnu* | linux-dietlibc | linux-newlib* | linux-uclibc* | \
-  uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | knetbsd*-gnu* | netbsd*-gnu* | \
+  nto-qnx* | linux-gnu* | linux-android* | linux-dietlibc | linux-newlib* | \
+  linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | \
+  knetbsd*-gnu* | netbsd*-gnu* | \
   storm-chaos* | os2-emx* | rtmk-nova*)
     os=-$maybe_os
     basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
@@ -1258,7 +1259,8 @@ case $os in
              | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \
              | -chorusos* | -chorusrdb* \
              | -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \
-             | -mingw32* | -linux-gnu* | -linux-newlib* | -linux-uclibc* \
+             | -mingw32* | -linux-gnu* | -linux-android* \
+              | -linux-newlib* | -linux-uclibc* \
              | -uxpv* | -beos* | -mpeix* | -udk* \
              | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \
              | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \
index 101a7b1..96a2d52 100755 (executable)
--- a/configure
+++ b/configure
@@ -1,6 +1,6 @@
 #! /bin/sh
 # Guess values for system-dependent variables and create Makefiles.
-# Generated by GNU Autoconf 2.61 for android-tools 1.0.
+# Generated by GNU Autoconf 2.61 for android-tools 2.0.
 #
 # Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001,
 # 2002, 2003, 2004, 2005, 2006 Free Software Foundation, Inc.
@@ -572,8 +572,8 @@ SHELL=${CONFIG_SHELL-/bin/sh}
 # Identity of this package.
 PACKAGE_NAME='android-tools'
 PACKAGE_TARNAME='android-tools'
-PACKAGE_VERSION='1.0'
-PACKAGE_STRING='android-tools 1.0'
+PACKAGE_VERSION='2.0'
+PACKAGE_STRING='android-tools 2.0'
 PACKAGE_BUGREPORT=''
 
 ac_subst_vars='SHELL
@@ -1147,7 +1147,7 @@ if test "$ac_init_help" = "long"; then
   # Omit some internal or obsolete options to make the list less imposing.
   # This message is too long to be a string in the A/UX 3.1 sh.
   cat <<_ACEOF
-\`configure' configures android-tools 1.0 to adapt to many kinds of systems.
+\`configure' configures android-tools 2.0 to adapt to many kinds of systems.
 
 Usage: $0 [OPTION]... [VAR=VALUE]...
 
@@ -1218,7 +1218,7 @@ fi
 
 if test -n "$ac_init_help"; then
   case $ac_init_help in
-     short | recursive ) echo "Configuration of android-tools 1.0:";;
+     short | recursive ) echo "Configuration of android-tools 2.0:";;
    esac
   cat <<\_ACEOF
 
@@ -1300,7 +1300,7 @@ fi
 test -n "$ac_init_help" && exit $ac_status
 if $ac_init_version; then
   cat <<\_ACEOF
-android-tools configure 1.0
+android-tools configure 2.0
 generated by GNU Autoconf 2.61
 
 Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001,
@@ -1314,7 +1314,7 @@ cat >config.log <<_ACEOF
 This file contains any messages produced by compilers while
 running configure, to aid debugging if configure makes a mistake.
 
-It was created by android-tools $as_me 1.0, which was
+It was created by android-tools $as_me 2.0, which was
 generated by GNU Autoconf 2.61.  Invocation command line was
 
   $ $0 $@
@@ -1831,14 +1831,14 @@ test -n "$target_alias" &&
   program_prefix=${target_alias}-
 
 # We only allow the following 3 targets:
-# 1. arm-android-eabi (primary target)
+# 1. arm-linux-androideabi (primary target)
 # 2. arm-eabi (to be phased out.)
 # 3. arm-newlib-eabi (for gcc testing)
 # 4.i[3456]86-*-linux-gnu, x86-*-linux-gnu (for x86 targets)
 
 GDB_TARGET=$target
 case $target in
-  arm-android-eabi | arm-unknown-eabi)
+  arm-unknown-linux-androideabi | arm-unknown-eabi)
     BUILD_ANDROID_GCC=yes
     GDB_TARGET=arm-elf-linux
     ;;
@@ -2779,7 +2779,7 @@ exec 6>&1
 # report actual input values of CONFIG_FILES etc. instead of their
 # values after options handling.
 ac_log="
-This file was extended by android-tools $as_me 1.0, which was
+This file was extended by android-tools $as_me 2.0, which was
 generated by GNU Autoconf 2.61.  Invocation command line was
 
   CONFIG_FILES    = $CONFIG_FILES
@@ -2822,7 +2822,7 @@ Report bugs to <bug-autoconf@gnu.org>."
 _ACEOF
 cat >>$CONFIG_STATUS <<_ACEOF
 ac_cs_version="\\
-android-tools config.status 1.0
+android-tools config.status 2.0
 configured by $0, generated by GNU Autoconf 2.61,
   with options \\"`echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`\\"
 
index d13e9b1..973b8f4 100644 (file)
@@ -11,7 +11,7 @@
 # General Public License for more details.
 #
 
-AC_INIT(android-tools,1.0)
+AC_INIT(android-tools,2.0)
 AC_PREREQ(2.59)
 
 AC_CONFIG_FILES([Makefile])
@@ -19,14 +19,14 @@ AC_CONFIG_FILES([Makefile])
 AC_CANONICAL_SYSTEM
 
 # We only allow the following 3 targets:
-# 1. arm-android-eabi (primary target)
-# 2. arm-eabi (to be phased out.)
+# 1. arm-linux-androideabi (primary target)
+# 2. arm-eabi (for Android kernel)
 # 3. arm-newlib-eabi (for gcc testing)
 # 4.i[3456]86-*-linux-gnu, x86-*-linux-gnu (for x86 targets)
 
 GDB_TARGET=$target
 case $target in
-  arm-android-eabi | arm-unknown-eabi)
+  arm-unknown-linux-androideabi | arm-unknown-eabi)
     BUILD_ANDROID_GCC=yes
     GDB_TARGET=arm-elf-linux
     ;;