diff options
| author | Khem Raj <raj.khem@gmail.com> | 2012-04-12 21:33:22 -0700 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2012-04-30 11:37:27 +0100 |
| commit | 9f328535440abe241fd679aa1d211e6b4e71f885 (patch) | |
| tree | 1c8fe42f3c36d3520794dffb14757ba13fcc4271 /meta/recipes-devtools | |
| parent | 8e6a74222061e763953e4913a5f08d57ba74c540 (diff) | |
| download | poky-9f328535440abe241fd679aa1d211e6b4e71f885.tar.gz | |
gcc-4.7: Let cpp specs honor include searches in relocated install tree
Fix from Yocto Bug 2074
(From OE-Core rev: fe32e09ccbef3a9896955e8d4c3113c53f95de48)
Signed-off-by: Khem Raj <raj.khem@gmail.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-devtools')
| -rw-r--r-- | meta/recipes-devtools/gcc/gcc-4.7.inc | 6 | ||||
| -rw-r--r-- | meta/recipes-devtools/gcc/gcc-4.7/cpp-honor-sysroot.patch | 40 |
2 files changed, 46 insertions, 0 deletions
diff --git a/meta/recipes-devtools/gcc/gcc-4.7.inc b/meta/recipes-devtools/gcc/gcc-4.7.inc index 7cfc388b78..784a3be328 100644 --- a/meta/recipes-devtools/gcc/gcc-4.7.inc +++ b/meta/recipes-devtools/gcc/gcc-4.7.inc | |||
| @@ -63,6 +63,7 @@ SRC_URI = "svn://gcc.gnu.org/svn/gcc/branches;module=${BRANCH};proto=http \ | |||
| 63 | file://pr32219.patch \ | 63 | file://pr32219.patch \ |
| 64 | file://fortran-cross-compile-hack.patch \ | 64 | file://fortran-cross-compile-hack.patch \ |
| 65 | file://libgcc-sjlj-check.patch \ | 65 | file://libgcc-sjlj-check.patch \ |
| 66 | file://cpp-honor-sysroot.patch \ | ||
| 66 | " | 67 | " |
| 67 | 68 | ||
| 68 | S = "${TMPDIR}/work-shared/gcc-${PV}-${PR}/${BRANCH}" | 69 | S = "${TMPDIR}/work-shared/gcc-${PV}-${PR}/${BRANCH}" |
| @@ -103,6 +104,11 @@ EXTRA_OECONF_INTERMEDIATE = "--disable-libmudflap \ | |||
| 103 | 104 | ||
| 104 | EXTRA_OECONF_append_libc-uclibc = " --disable-decimal-float " | 105 | EXTRA_OECONF_append_libc-uclibc = " --disable-decimal-float " |
| 105 | 106 | ||
| 107 | EXTRA_OECONF_PATHS = " \ | ||
| 108 | --with-gxx-include-dir=${STAGING_DIR_TARGET}${target_includedir}/c++ \ | ||
| 109 | --with-sysroot=${STAGING_DIR_TARGET} \ | ||
| 110 | --with-build-sysroot=${STAGING_DIR_TARGET}" | ||
| 111 | |||
| 106 | do_configure_prepend () { | 112 | do_configure_prepend () { |
| 107 | # teach gcc to find correct target includedir when checking libc ssp support | 113 | # teach gcc to find correct target includedir when checking libc ssp support |
| 108 | mkdir -p ${B}/gcc | 114 | mkdir -p ${B}/gcc |
diff --git a/meta/recipes-devtools/gcc/gcc-4.7/cpp-honor-sysroot.patch b/meta/recipes-devtools/gcc/gcc-4.7/cpp-honor-sysroot.patch new file mode 100644 index 0000000000..731067741d --- /dev/null +++ b/meta/recipes-devtools/gcc/gcc-4.7/cpp-honor-sysroot.patch | |||
| @@ -0,0 +1,40 @@ | |||
| 1 | Currently, if the gcc toolchain is relocated and installed from sstate, then you try and compile | ||
| 2 | preprocessed source (.i or .ii files), the compiler will try and access the builtin sysroot location | ||
| 3 | rather than the --sysroot option specified on the commandline. If access to that directory is | ||
| 4 | permission denied (unreadable), gcc will error. | ||
| 5 | |||
| 6 | This happens when ccache is in use due to the fact it uses preprocessed source files. | ||
| 7 | |||
| 8 | The fix below adds %I to the cpp-output spec macro so the default substitutions for -iprefix, | ||
| 9 | -isystem, -isysroot happen and the correct sysroot is used. | ||
| 10 | |||
| 11 | [YOCTO #2074] | ||
| 12 | |||
| 13 | Upstream-Status: Pending | ||
| 14 | |||
| 15 | RP 2012/04/13 | ||
| 16 | |||
| 17 | Index: gcc-4_6-branch/gcc/gcc.c | ||
| 18 | =================================================================== | ||
| 19 | --- gcc-4_6-branch.orig/gcc/gcc.c 2012-04-13 12:24:37.939671140 +0000 | ||
| 20 | +++ gcc-4_6-branch/gcc/gcc.c 2012-04-13 12:24:54.439670688 +0000 | ||
| 21 | @@ -953,7 +953,7 @@ | ||
| 22 | %W{o*:--output-pch=%*}}%V}}}}}}", 0, 0, 0}, | ||
| 23 | {".i", "@cpp-output", 0, 0, 0}, | ||
| 24 | {"@cpp-output", | ||
| 25 | - "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0}, | ||
| 26 | + "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %I %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0}, | ||
| 27 | {".s", "@assembler", 0, 0, 0}, | ||
| 28 | {"@assembler", | ||
| 29 | "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0}, | ||
| 30 | Index: gcc-4_6-branch/gcc/cp/lang-specs.h | ||
| 31 | =================================================================== | ||
| 32 | --- gcc-4_6-branch.orig/gcc/cp/lang-specs.h 2012-04-13 12:25:01.019670594 +0000 | ||
| 33 | +++ gcc-4_6-branch/gcc/cp/lang-specs.h 2012-04-13 12:25:07.567670180 +0000 | ||
| 34 | @@ -64,5 +64,5 @@ | ||
| 35 | {".ii", "@c++-cpp-output", 0, 0, 0}, | ||
| 36 | {"@c++-cpp-output", | ||
| 37 | "%{!M:%{!MM:%{!E:\ | ||
| 38 | - cc1plus -fpreprocessed %i %(cc1_options) %2\ | ||
| 39 | + cc1plus -fpreprocessed %i %I %(cc1_options) %2\ | ||
| 40 | %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0}, | ||
