From: GNU Libc Maintainers Date: Fri, 10 Jan 2020 22:21:25 +0000 (+0000) Subject: local-libpic X-Git-Tag: archive/raspbian/2.29-9+rpi1~1^2~8 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=a29f60d9d8b6430618c1bcedd178ed952e65202b;p=glibc.git local-libpic Gbp-Pq: Topic any Gbp-Pq: Name local-libpic.diff --- diff --git a/Makerules b/Makerules index 7745e24c8..3be12d0c3 100644 --- a/Makerules +++ b/Makerules @@ -751,6 +751,9 @@ ifeq ($(build-shared),yes) $(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) @@ -982,6 +985,7 @@ endef 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 .PHONY: check-install-supported check-install-supported: @@ -1030,6 +1034,22 @@ versioned := $(strip $(foreach so,$(install-lib.so),\ 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 @@ -1287,9 +1307,22 @@ $(addprefix $(inst_includedir)/,$(headers-nonh)): $(inst_includedir)/%: \ 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: $(elf-objpfx)/%.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: \ @@ -1302,6 +1335,10 @@ install-data-nosubdir: $(addprefix $(inst_datadir)/,$(install-data)) 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. @@ -1311,7 +1348,8 @@ install-%:: install-%-nosubdir ; .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 \