patches/gcc/4.4.1/370-bootstrap-target_lib_path.patch
author Anthony Foiani <anthony.foiani@gmail.com>
Thu May 19 23:06:16 2011 +0200 (2011-05-19)
changeset 2461 ec30b191f0e3
permissions -rw-r--r--
complibs/ppl: build only C and C++ interfaces for PPL

By default, PPL wants to build interfaces for any of a variety of
langauges it finds on the local host (python, java, possibly perl, also
more esoteric languages such as ocaml and prolog).

These extra interfaces can double the compile time for the library. For
single-process builds, I found a savings of more than 40%:

default / j1: 716s total, 143.2s avg, 0.52s stdev
just_c / j1: 406s total, 81.2s avg, 0.33s stdev
just_c_cpp / j1: 413s total, 82.6s avg, 0.22s stdev

And for multi-process builds, it approached 50%:

default / j4: 625s total, 125.0s avg, 0.57s stdev
just_c / j4: 338s total, 67.6s avg, 1.25s stdev
just_c_cpp / j4: 327s total, 65.4s avg, 0.36s stdev

Since the PPL we build within ct-ng is only used by GCC, we only need to
build the C and C++ interfaces.

Signed-Off-By: Anthony Foiani <anthony.foiani@gmail.com>
yann@1698
     1
ChangeLog:
yann@1698
     2
2010-01-06  Ralf Wildenhues  <Ralf.Wildenhues@gmx.de>
yann@1698
     3
yann@1698
     4
	PR bootstrap/41818
yann@1698
     5
	* Makefile.tpl (BASE_TARGET_EXPORTS): Only add TARGET_LIB_PATH
yann@1698
     6
	to $(RPATH_ENVVAR) if bootstrapping.
yann@1698
     7
	* Makefile.in: Regenerate.
yann@1698
     8
yann@1698
     9
diff --git a/Makefile.in b/Makefile.in
yann@1698
    10
index e5fa1d3..dbfc1f0 100644
yann@1698
    11
--- a/Makefile.in
yann@1698
    12
+++ b/Makefile.in
yann@1698
    13
@@ -281,7 +281,10 @@ BASE_TARGET_EXPORTS = \
yann@1698
    14
 	STRIP="$(STRIP_FOR_TARGET)"; export STRIP; \
yann@1698
    15
 	WINDRES="$(WINDRES_FOR_TARGET)"; export WINDRES; \
yann@1698
    16
 	WINDMC="$(WINDMC_FOR_TARGET)"; export WINDMC; \
yann@1698
    17
-	$(RPATH_ENVVAR)=`echo "$(HOST_LIB_PATH)$(TARGET_LIB_PATH)$$$(RPATH_ENVVAR)" | sed 's,::*,:,g;s,^:*,,;s,:*$$,,'`; export $(RPATH_ENVVAR);
yann@1698
    18
+@if gcc-bootstrap
yann@1698
    19
+	$(RPATH_ENVVAR)=`echo "$(TARGET_LIB_PATH)$$$(RPATH_ENVVAR)" | sed 's,::*,:,g;s,^:*,,;s,:*$$,,'`; export $(RPATH_ENVVAR); \
yann@1698
    20
+@endif gcc-bootstrap
yann@1698
    21
+	$(RPATH_ENVVAR)=`echo "$(HOST_LIB_PATH)$$$(RPATH_ENVVAR)" | sed 's,::*,:,g;s,^:*,,;s,:*$$,,'`; export $(RPATH_ENVVAR);
yann@1698
    22
 
yann@1698
    23
 RAW_CXX_TARGET_EXPORTS = \
yann@1698
    24
 	$(BASE_TARGET_EXPORTS) \
yann@1698
    25
diff --git a/Makefile.tpl b/Makefile.tpl
yann@1698
    26
index 15102e5..452d47c 100644
yann@1698
    27
--- a/Makefile.tpl
yann@1698
    28
+++ b/Makefile.tpl
yann@1698
    29
@@ -284,7 +284,10 @@ BASE_TARGET_EXPORTS = \
yann@1698
    30
 	STRIP="$(STRIP_FOR_TARGET)"; export STRIP; \
yann@1698
    31
 	WINDRES="$(WINDRES_FOR_TARGET)"; export WINDRES; \
yann@1698
    32
 	WINDMC="$(WINDMC_FOR_TARGET)"; export WINDMC; \
yann@1698
    33
-	$(RPATH_ENVVAR)=`echo "$(HOST_LIB_PATH)$(TARGET_LIB_PATH)$$$(RPATH_ENVVAR)" | sed 's,::*,:,g;s,^:*,,;s,:*$$,,'`; export $(RPATH_ENVVAR);
yann@1698
    34
+@if gcc-bootstrap
yann@1698
    35
+	$(RPATH_ENVVAR)=`echo "$(TARGET_LIB_PATH)$$$(RPATH_ENVVAR)" | sed 's,::*,:,g;s,^:*,,;s,:*$$,,'`; export $(RPATH_ENVVAR); \
yann@1698
    36
+@endif gcc-bootstrap
yann@1698
    37
+	$(RPATH_ENVVAR)=`echo "$(HOST_LIB_PATH)$$$(RPATH_ENVVAR)" | sed 's,::*,:,g;s,^:*,,;s,:*$$,,'`; export $(RPATH_ENVVAR);
yann@1698
    38
 
yann@1698
    39
 RAW_CXX_TARGET_EXPORTS = \
yann@1698
    40
 	$(BASE_TARGET_EXPORTS) \