2008-02-07 Joseph Myers * Makerules (install-extras, install-map): New variables. (installed-libcs): Add libc_pic.a. (install-lib): Include _pic.a files for versioned shared libraries. (install-map-nosubdir, install-extras-nosubdir): Add rules for installing extra files. (install-no-libc.a-nosubdir): Depend on install-map-nosubdir and install-extras-nosubdir. 2008-04-01 Maxim Kuvyrkov * Makerules (install-lib): Don't install libpthread_pic.a. (install-map): Don't install libpthread_pic.map. Upstream-Status: Pending Index: git/Makerules =================================================================== --- git.orig/Makerules 2014-08-27 18:49:22.552070587 +0000 +++ git/Makerules 2014-08-27 18:49:27.308070587 +0000 @@ -612,6 +631,9 @@ $(common-objpfx)libc.so: $(common-objpfx)libc.map endif common-generated += libc.so libc_pic.os +ifndef subdir +install-extras := soinit.o sofini.o +endif ifdef libc.so-version $(common-objpfx)libc.so$(libc.so-version): $(common-objpfx)libc.so $(make-link) @@ -834,6 +856,7 @@ installed-libcs := $(foreach o,$(filter-out .os,$(object-suffixes-for-libc)),\ $(inst_libdir)/$(patsubst %,$(libtype$o),\ $(libprefix)$(libc-name))) +installed-libcs := $(installed-libcs) $(inst_libdir)/libc_pic.a install: $(installed-libcs) $(installed-libcs): $(inst_libdir)/lib$(libprefix)%: lib $(+force) $(make-target-directory) @@ -862,6 +885,22 @@ install-lib.so-versioned := $(filter $(versioned), $(install-lib.so)) install-lib.so-unversioned := $(filter-out $(versioned), $(install-lib.so)) +# Install the _pic.a files for versioned libraries, and corresponding +# .map files. +# libpthread_pic.a breaks mklibs, so don't install it and its map. +install-lib := $(install-lib) $(install-lib.so-versioned:%.so=%_pic.a) +install-lib := $(filter-out libpthread_pic.a,$(install-lib)) +# Despite having a soname libhurduser and libmachuser do not use symbol +# versioning, so don't install the corresponding .map files. +ifeq ($(build-shared),yes) +install-map := $(patsubst %.so,%.map,\ + $(foreach L,$(install-lib.so-versioned),$(notdir $L))) +install-map := $(filter-out libhurduser.map libmachuser.map libpthread.map,$(install-map)) +ifndef subdir +install-map := $(install-map) libc.map +endif +endif + # For versioned libraries, we install three files: # $(inst_libdir)/libfoo.so -- for linking, symlink or ld script # $(inst_slibdir)/libfoo.so.NN -- for loading by SONAME, symlink @@ -1103,9 +1142,22 @@ endif # headers-nonh endif # headers +ifdef install-map +$(addprefix $(inst_libdir)/,$(patsubst lib%.map,lib%_pic.map,$(install-map))): \ + $(inst_libdir)/lib%_pic.map: $(common-objpfx)lib%.map $(+force) + $(do-install) +endif + +ifdef install-extras +$(addprefix $(inst_libdir)/libc_pic/,$(install-extras)): \ + $(inst_libdir)/libc_pic/%.o: $(elfobjdir)/%.os $(+force) + $(do-install) +endif + .PHONY: install-bin-nosubdir install-bin-script-nosubdir \ install-rootsbin-nosubdir install-sbin-nosubdir install-lib-nosubdir \ - install-data-nosubdir install-headers-nosubdir + install-data-nosubdir install-headers-nosubdir install-map-nosubdir \ + install-extras-nosubdir install-bin-nosubdir: $(addprefix $(inst_bindir)/,$(install-bin)) install-bin-script-nosubdir: $(addprefix $(inst_bindir)/,$(install-bin-script)) install-rootsbin-nosubdir: \ @@ -1118,6 +1170,10 @@ install-headers-nosubdir: $(addprefix $(inst_includedir)/,$(headers)) install-others-nosubdir: $(install-others) install-others-programs-nosubdir: $(install-others-programs) +install-map-nosubdir: $(addprefix $(inst_libdir)/,\ + $(patsubst lib%.map,lib%_pic.map,$(install-map))) +install-extras-nosubdir: $(addprefix $(inst_libdir)/libc_pic/,\ + $(install-extras)) # We need all the `-nosubdir' targets so that `install' in the parent # doesn't depend on several things which each iterate over the subdirs. @@ -1127,7 +1183,8 @@ .PHONY: install install-no-libc.a-nosubdir install-no-libc.a-nosubdir: install-headers-nosubdir install-data-nosubdir \ - install-lib-nosubdir install-others-nosubdir + install-lib-nosubdir install-others-nosubdir \ + install-map-nosubdir install-extras-nosubdir ifeq ($(build-programs),yes) install-no-libc.a-nosubdir: install-bin-nosubdir install-bin-script-nosubdir \ install-rootsbin-nosubdir install-sbin-nosubdir \