summaryrefslogtreecommitdiffstats
path: root/meta/recipes-devtools
diff options
context:
space:
mode:
authorJulian Pidancet <julian.pidancet@gmail.com>2011-11-16 01:01:59 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2011-11-29 11:22:06 +0000
commit7edf5cff9c8815f74804082fef4f0dfcdbab3cf6 (patch)
treef1a3201603c9ecf4eed2abb15cba5d4166ed4f45 /meta/recipes-devtools
parentf4791847cd22fbb874d471be4abfe5ef5711bd42 (diff)
downloadpoky-7edf5cff9c8815f74804082fef4f0dfcdbab3cf6.tar.gz
Introduce multiarch DISTRO_FEATURE
This patch introduces a distro feature which enables gcc to produce both 32bit and 64bit code, and enables binutils to operate on both 32bit and 64bit binaries. It differs from multilib toolchains in that it does not require to compile a version of the libc for each architecture variant. However, the code produced for the secondary architecture will not be linkable against the libc. v2: - Renamed the feature name from "biarch" to "multiarch". The GCC installation manual claims that the mips-linux can be made a tri-arch compiler (http://gcc.gnu.org/install/configure.html) - For x86_64, the compiler is made bi-arch by default, so nothing has to be done in particular. - I analyzed the gcc/config.gcc from GCC sources and added in this patch all the architectures that could be made biarch with the version of gcc currently used in OE, which are powerpc, and sparc, in addition to x86. mips and s390 will probably be supported in future versions of gcc. For x86 and sparc, only the --enable-targets=all option is valid to make this work (this option doesn't have any other side effects than making the compiler bi-arch). For powerpc, I used the --enable-targets=powerpc64 option (although 'all' also works). Note: - Untested on powerpc and sparc. But I believe it works the same as with x86. - gcc in meta-toolchain is also made multiarch. (From OE-Core rev: 99e295ef30ba02db3966c66619807c037ef5089f) Signed-off-by: Julian Pidancet <julian.pidancet@gmail.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-devtools')
-rw-r--r--meta/recipes-devtools/binutils/binutils-cross.inc3
-rw-r--r--meta/recipes-devtools/binutils/binutils.inc3
-rw-r--r--meta/recipes-devtools/gcc/gcc-common.inc10
-rw-r--r--meta/recipes-devtools/gcc/gcc-configure-common.inc3
4 files changed, 16 insertions, 3 deletions
diff --git a/meta/recipes-devtools/binutils/binutils-cross.inc b/meta/recipes-devtools/binutils/binutils-cross.inc
index 982224ff2f..f07907ef13 100644
--- a/meta/recipes-devtools/binutils/binutils-cross.inc
+++ b/meta/recipes-devtools/binutils/binutils-cross.inc
@@ -10,7 +10,8 @@ EXTRA_OECONF = "--with-sysroot=${STAGING_DIR_TARGET} \
10 --disable-werror \ 10 --disable-werror \
11 --disable-nls \ 11 --disable-nls \
12 --enable-poison-system-directories \ 12 --enable-poison-system-directories \
13 ${@base_contains('DISTRO_FEATURES', 'ld-is-gold', '--enable-gold=default', '', d)}" 13 ${@base_contains('DISTRO_FEATURES', 'ld-is-gold', '--enable-gold=default', '', d)} \
14 ${@base_contains('DISTRO_FEATURES', 'multiarch', '--enable-64-bit-bfd', '', d)}"
14 15
15do_install () { 16do_install () {
16 oe_runmake 'DESTDIR=${D}' install 17 oe_runmake 'DESTDIR=${D}' install
diff --git a/meta/recipes-devtools/binutils/binutils.inc b/meta/recipes-devtools/binutils/binutils.inc
index 58fee854e3..51e425791c 100644
--- a/meta/recipes-devtools/binutils/binutils.inc
+++ b/meta/recipes-devtools/binutils/binutils.inc
@@ -49,7 +49,8 @@ B = "${S}/build.${HOST_SYS}.${TARGET_SYS}"
49 49
50EXTRA_OECONF = "--program-prefix=${TARGET_PREFIX} \ 50EXTRA_OECONF = "--program-prefix=${TARGET_PREFIX} \
51 --enable-install-libbfd \ 51 --enable-install-libbfd \
52 --enable-shared" 52 --enable-shared \
53 ${@base_contains('DISTRO_FEATURES', 'multiarch', '--enable-64-bit-bfd', '', d)}"
53 54
54EXTRA_OECONF_virtclass-native = "--enable-target=all --enable-64-bit-bfd --enable-install-libbfd" 55EXTRA_OECONF_virtclass-native = "--enable-target=all --enable-64-bit-bfd --enable-install-libbfd"
55 56
diff --git a/meta/recipes-devtools/gcc/gcc-common.inc b/meta/recipes-devtools/gcc/gcc-common.inc
index 69e0213e9f..7ec2f7e463 100644
--- a/meta/recipes-devtools/gcc/gcc-common.inc
+++ b/meta/recipes-devtools/gcc/gcc-common.inc
@@ -21,6 +21,16 @@ def get_gcc_mips_plt_setting(bb, d):
21 return "--with-mips-plt" 21 return "--with-mips-plt"
22 return "" 22 return ""
23 23
24def get_gcc_multiarch_setting(bb, d):
25 if 'multiarch' in bb.data.getVar('DISTRO_FEATURES',d,1).split() :
26 if bb.data.getVar('TARGET_ARCH', d, 1) in [ 'i586', 'i686' ] :
27 return "--enable-targets=all"
28 if bb.data.getVar('TARGET_ARCH', d, 1) in [ 'powerpc' ] :
29 return "--enable-targets=powerpc64"
30 if bb.data.getVar('TARGET_ARCH', d, 1) in [ 'sparc' ] :
31 return "--enable-targets=all"
32 return ""
33
24# We really need HOST_SYS here for some packages and TARGET_SYS for others. 34# We really need HOST_SYS here for some packages and TARGET_SYS for others.
25# For now, libgcc is most important so we fix for that - RP. 35# For now, libgcc is most important so we fix for that - RP.
26SHLIBSDIR = "${STAGING_DIR_TARGET}/shlibs" 36SHLIBSDIR = "${STAGING_DIR_TARGET}/shlibs"
diff --git a/meta/recipes-devtools/gcc/gcc-configure-common.inc b/meta/recipes-devtools/gcc/gcc-configure-common.inc
index ae23e8ee49..d0149801db 100644
--- a/meta/recipes-devtools/gcc/gcc-configure-common.inc
+++ b/meta/recipes-devtools/gcc/gcc-configure-common.inc
@@ -42,7 +42,8 @@ EXTRA_OECONF = "${@['--enable-clocale=generic', ''][d.getVar('USE_NLS', 1) != 'n
42 ${EXTRA_OECONF_BASE} \ 42 ${EXTRA_OECONF_BASE} \
43 ${EXTRA_OECONF_FPU} \ 43 ${EXTRA_OECONF_FPU} \
44 ${EXTRA_OECONF_PATHS} \ 44 ${EXTRA_OECONF_PATHS} \
45 ${@get_gcc_mips_plt_setting(bb, d)}" 45 ${@get_gcc_mips_plt_setting(bb, d)} \
46 ${@get_gcc_multiarch_setting(bb, d)}"
46 47
47# Build uclibc compilers without cxa_atexit support 48# Build uclibc compilers without cxa_atexit support
48EXTRA_OECONF_append_linux = " --enable-__cxa_atexit" 49EXTRA_OECONF_append_linux = " --enable-__cxa_atexit"