diff options
author | Khem Raj <raj.khem@gmail.com> | 2016-05-11 10:35:04 -0700 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2016-05-13 13:40:50 +0100 |
commit | 93226e8c74be438781df79f0be5cbf563c79df8b (patch) | |
tree | 6f835995f61c293ada1931f2e7a7d58b4bd543ab /meta/recipes-devtools/gcc/0001-gcc-runtime-Symlink-c-header-in-target_triplet-for-S.patch | |
parent | 4f2898f598c466fa0fde5be64ac4d6a60aae68f7 (diff) | |
download | openembedded-core-93226e8c74be438781df79f0be5cbf563c79df8b.tar.gz |
gcc: Add gcc6 recipes
Signed-off-by: Khem Raj <raj.khem@gmail.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-devtools/gcc/0001-gcc-runtime-Symlink-c-header-in-target_triplet-for-S.patch')
-rw-r--r-- | meta/recipes-devtools/gcc/0001-gcc-runtime-Symlink-c-header-in-target_triplet-for-S.patch | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/meta/recipes-devtools/gcc/0001-gcc-runtime-Symlink-c-header-in-target_triplet-for-S.patch b/meta/recipes-devtools/gcc/0001-gcc-runtime-Symlink-c-header-in-target_triplet-for-S.patch new file mode 100644 index 0000000000..c598a0d6f7 --- /dev/null +++ b/meta/recipes-devtools/gcc/0001-gcc-runtime-Symlink-c-header-in-target_triplet-for-S.patch @@ -0,0 +1,49 @@ +From 0ef3d75514ee5a74b7c04ea36423cff97843fbb8 Mon Sep 17 00:00:00 2001 +From: Khem Raj <raj.khem@gmail.com> +Date: Tue, 10 May 2016 01:07:24 -0700 +Subject: [PATCH] gcc-runtime: Symlink c++ header in target_triplet for SDK use + +We build SDKs such that gcc-cross-candian is built for only one +target *-*-linux and then use -muclibc or -mmusl to let it compile +code for other libc variants. This works fine when libc = glibc +however it does not work for c++ programs when libc != glibc since +there are c++ headers installed under ${includedir}/c++/${BINV}/${TARGET_SYS} +which is fine when gcc-runtime and gcc-cross-candian uses same --target options +gxx includedir searches in right triplet, but it fails with musl/uclibc +since gcc will look for glibc based triplet but gcc-runtime will install +them under musl/uclibc triplet. + +This patch symlinks the musl/uclibc triplet to glibc triplet when libc != glibc + +This fixes SDKs for musl/uclibc + +Signed-off-by: Khem Raj <raj.khem@gmail.com> +--- + meta/recipes-devtools/gcc/gcc-runtime.inc | 6 ++++-- + 1 file changed, 4 insertions(+), 2 deletions(-) + +diff --git a/meta/recipes-devtools/gcc/gcc-runtime.inc b/meta/recipes-devtools/gcc/gcc-runtime.inc +index 8639c1c..8e4d5eb 100644 +--- a/meta/recipes-devtools/gcc/gcc-runtime.inc ++++ b/meta/recipes-devtools/gcc/gcc-runtime.inc +@@ -70,13 +70,15 @@ do_install () { + if [ -d ${D}${infodir} ]; then + rmdir --ignore-fail-on-non-empty -p ${D}${infodir} + fi ++} ++ ++do_install_append_class-target () { + if [ "${TARGET_VENDOR_MULTILIB_ORIGINAL}" != "" -a "${TARGET_VENDOR}" != "${TARGET_VENDOR_MULTILIB_ORIGINAL}" ]; then + ln -s ${TARGET_SYS} ${D}${includedir}/c++/${BINV}/${TARGET_ARCH}${TARGET_VENDOR_MULTILIB_ORIGINAL}-${TARGET_OS} + fi +- if [ "${TARGET_OS}" = "linux-gnuspe" ]; then ++ if [ "${TARGET_OS}" = "linux-gnuspe" -o "${TCLIBC}" != "glibc" ]; then + ln -s ${TARGET_SYS} ${D}${includedir}/c++/${BINV}/${TARGET_ARCH}${TARGET_VENDOR}-linux + fi +- chown -R root:root ${D} + } + + INHIBIT_DEFAULT_DEPS = "1" +-- +2.8.2 + |