diff options
4 files changed, 68 insertions, 0 deletions
diff --git a/meta/recipes-devtools/gcc/gcc-4.6.inc b/meta/recipes-devtools/gcc/gcc-4.6.inc index 7a70a3848a..03d887149d 100644 --- a/meta/recipes-devtools/gcc/gcc-4.6.inc +++ b/meta/recipes-devtools/gcc/gcc-4.6.inc | |||
| @@ -75,6 +75,7 @@ SRC_URI = "svn://gcc.gnu.org/svn/gcc/branches;module=${BRANCH};proto=http \ | |||
| 75 | file://fortran-cross-compile-hack.patch \ | 75 | file://fortran-cross-compile-hack.patch \ |
| 76 | file://cpp-honour-sysroot.patch \ | 76 | file://cpp-honour-sysroot.patch \ |
| 77 | file://mips64-default-n64.patch \ | 77 | file://mips64-default-n64.patch \ |
| 78 | file://gcc-argument-list-too-long.patch \ | ||
| 78 | " | 79 | " |
| 79 | 80 | ||
| 80 | SRC_URI_append_sh3 = " file://sh3-installfix-fixheaders.patch " | 81 | SRC_URI_append_sh3 = " file://sh3-installfix-fixheaders.patch " |
diff --git a/meta/recipes-devtools/gcc/gcc-4.6/gcc-argument-list-too-long.patch b/meta/recipes-devtools/gcc/gcc-4.6/gcc-argument-list-too-long.patch new file mode 100644 index 0000000000..70d3c53a84 --- /dev/null +++ b/meta/recipes-devtools/gcc/gcc-4.6/gcc-argument-list-too-long.patch | |||
| @@ -0,0 +1,33 @@ | |||
| 1 | There would be an "Argument list too long" error when the | ||
| 2 | build directory is longer than 200, this is caused by: | ||
| 3 | |||
| 4 | headers=`echo $(PLUGIN_HEADERS) | tr ' ' '\012' | sort -u` | ||
| 5 | |||
| 6 | The PLUGIN_HEADERS is too long before sort, so the "echo" can't handle | ||
| 7 | it, use the $(sort list) of GNU make which can handle the too long list | ||
| 8 | would fix the problem, the header would be short enough after sorted. | ||
| 9 | The "tr ' ' '\012'" was used for translating the space to "\n", the | ||
| 10 | $(sort list) doesn't need this. | ||
| 11 | |||
| 12 | Signed-off-by: Robert Yang <liezhi.yang@windriver.com> | ||
| 13 | |||
| 14 | Upstream-Status: Pending | ||
| 15 | --- | ||
| 16 | gcc/Makefile.in | 2 +- | ||
| 17 | 1 file changed, 1 insertion(+), 1 deletion(-) | ||
| 18 | |||
| 19 | diff --git a/gcc/Makefile.in b/gcc/Makefile.in | ||
| 20 | --- a/gcc/Makefile.in | ||
| 21 | +++ b/gcc/Makefile.in | ||
| 22 | @@ -4553,7 +4553,7 @@ install-plugin: installdirs lang.install-plugin s-header-vars install-gengtype | ||
| 23 | # We keep the directory structure for files in config or c-family and .def | ||
| 24 | # files. All other files are flattened to a single directory. | ||
| 25 | $(mkinstalldirs) $(DESTDIR)$(plugin_includedir) | ||
| 26 | - headers=`echo $(PLUGIN_HEADERS) | tr ' ' '\012' | sort -u`; \ | ||
| 27 | + headers="$(sort $(PLUGIN_HEADERS))"; \ | ||
| 28 | srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'`; \ | ||
| 29 | for file in $$headers; do \ | ||
| 30 | if [ -f $$file ] ; then \ | ||
| 31 | -- | ||
| 32 | 1.7.10.2 | ||
| 33 | |||
diff --git a/meta/recipes-devtools/gcc/gcc-4.7.inc b/meta/recipes-devtools/gcc/gcc-4.7.inc index 973c211fdb..34a73b1731 100644 --- a/meta/recipes-devtools/gcc/gcc-4.7.inc +++ b/meta/recipes-devtools/gcc/gcc-4.7.inc | |||
| @@ -66,6 +66,7 @@ SRC_URI = "svn://gcc.gnu.org/svn/gcc/branches;module=${BRANCH};proto=http \ | |||
| 66 | file://cpp-honor-sysroot.patch \ | 66 | file://cpp-honor-sysroot.patch \ |
| 67 | file://mips64-default-n64.patch \ | 67 | file://mips64-default-n64.patch \ |
| 68 | file://arm-hard-float-loader.patch \ | 68 | file://arm-hard-float-loader.patch \ |
| 69 | file://gcc-argument-list-too-long.patch \ | ||
| 69 | " | 70 | " |
| 70 | 71 | ||
| 71 | S = "${TMPDIR}/work-shared/gcc-${PV}-${PR}/${BRANCH}" | 72 | S = "${TMPDIR}/work-shared/gcc-${PV}-${PR}/${BRANCH}" |
diff --git a/meta/recipes-devtools/gcc/gcc-4.7/gcc-argument-list-too-long.patch b/meta/recipes-devtools/gcc/gcc-4.7/gcc-argument-list-too-long.patch new file mode 100644 index 0000000000..70d3c53a84 --- /dev/null +++ b/meta/recipes-devtools/gcc/gcc-4.7/gcc-argument-list-too-long.patch | |||
| @@ -0,0 +1,33 @@ | |||
| 1 | There would be an "Argument list too long" error when the | ||
| 2 | build directory is longer than 200, this is caused by: | ||
| 3 | |||
| 4 | headers=`echo $(PLUGIN_HEADERS) | tr ' ' '\012' | sort -u` | ||
| 5 | |||
| 6 | The PLUGIN_HEADERS is too long before sort, so the "echo" can't handle | ||
| 7 | it, use the $(sort list) of GNU make which can handle the too long list | ||
| 8 | would fix the problem, the header would be short enough after sorted. | ||
| 9 | The "tr ' ' '\012'" was used for translating the space to "\n", the | ||
| 10 | $(sort list) doesn't need this. | ||
| 11 | |||
| 12 | Signed-off-by: Robert Yang <liezhi.yang@windriver.com> | ||
| 13 | |||
| 14 | Upstream-Status: Pending | ||
| 15 | --- | ||
| 16 | gcc/Makefile.in | 2 +- | ||
| 17 | 1 file changed, 1 insertion(+), 1 deletion(-) | ||
| 18 | |||
| 19 | diff --git a/gcc/Makefile.in b/gcc/Makefile.in | ||
| 20 | --- a/gcc/Makefile.in | ||
| 21 | +++ b/gcc/Makefile.in | ||
| 22 | @@ -4553,7 +4553,7 @@ install-plugin: installdirs lang.install-plugin s-header-vars install-gengtype | ||
| 23 | # We keep the directory structure for files in config or c-family and .def | ||
| 24 | # files. All other files are flattened to a single directory. | ||
| 25 | $(mkinstalldirs) $(DESTDIR)$(plugin_includedir) | ||
| 26 | - headers=`echo $(PLUGIN_HEADERS) | tr ' ' '\012' | sort -u`; \ | ||
| 27 | + headers="$(sort $(PLUGIN_HEADERS))"; \ | ||
| 28 | srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'`; \ | ||
| 29 | for file in $$headers; do \ | ||
| 30 | if [ -f $$file ] ; then \ | ||
| 31 | -- | ||
| 32 | 1.7.10.2 | ||
| 33 | |||
