olga / rpms / glibc

Forked from rpms/glibc 5 years ago
Clone

Blame SOURCES/glibc-rh1292018-0a.patch

00db10
Required to get access to _rtld_global_ro@@GLIBC_PRIVATE
00db10
since it's only available from ld.so.
00db10
00db10
commit fab7ce3f5b4060bf62659e8b58529de4156b5a2f
00db10
Author: Joseph Myers <joseph@codesourcery.com>
00db10
Date:   Fri May 31 16:16:33 2013 +0000
00db10
00db10
    Link extra-libs consistently with libc and ld.so.
00db10
00db10
Index: glibc-2.17-c758a686/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/Makefile
00db10
+++ glibc-2.17-c758a686/Makefile
00db10
@@ -127,6 +127,9 @@ lib: $(common-objpfx)libc.so
00db10
 
00db10
 lib: $(common-objpfx)linkobj/libc.so
00db10
 
00db10
+# Do not filter ld.so out of libc.so link.
00db10
+$(common-objpfx)linkobj/libc.so: link-libc-deps = # empty
00db10
+
00db10
 $(common-objpfx)linkobj/libc.so: $(elfobjdir)/soinit.os \
00db10
 				 $(common-objpfx)linkobj/libc_pic.a \
00db10
 				 $(elfobjdir)/sofini.os \
00db10
Index: glibc-2.17-c758a686/Makerules
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/Makerules
00db10
+++ glibc-2.17-c758a686/Makerules
00db10
@@ -470,9 +470,10 @@ link-libc-deps = $(common-objpfx)libc.so
00db10
 # This must come after the installation rules so Make doesn't try to
00db10
 # build shared libraries in place from the installed *_pic.a files.
00db10
 # $(LDLIBS-%.so) may contain -l switches to generate run-time dependencies
00db10
-# on other shared objects.
00db10
-lib%.so: lib%_pic.a $(+preinit) $(+postinit)
00db10
-	$(build-shlib)
00db10
+# on other shared objects.  The linking with libc and ld.so is intended
00db10
+# to be as similar as possible to a default link with an installed libc.
00db10
+lib%.so: lib%_pic.a $(+preinit) $(+postinit) $(+interp) $(link-libc-deps)
00db10
+	$(build-shlib) $(link-libc-args)
00db10
 
00db10
 define build-shlib-helper
00db10
 $(LINK.o) -shared $(static-libgcc) -Wl,-O1 $(sysdep-LDFLAGS) \
00db10
@@ -558,7 +559,8 @@ endef
00db10
 
00db10
 build-module-helper-objlist = \
00db10
 	$(patsubst %_pic.a,$(whole-archive) %_pic.a $(no-whole-archive),\
00db10
-		   $(filter-out %.lds $(map-file) $(+preinit) $(+postinit),$^))
00db10
+		   $(filter-out %.lds $(map-file) $(+preinit) $(+postinit) \
00db10
+				$(link-libc-deps),$^))
00db10
 
00db10
 build-module-objlist = $(build-module-helper-objlist) $(LDLIBS-$(@F:%.so=%).so)
00db10
 build-shlib-objlist = $(build-module-helper-objlist) \
00db10
@@ -601,6 +603,9 @@ generated += libc_pic.opts libc_pic.os.c
00db10
 libc_pic_clean := .clean
00db10
 endif
00db10
 
00db10
+# Do not filter ld.so out of libc.so link.
00db10
+$(common-objpfx)libc.so: link-libc-deps = # empty
00db10
+
00db10
 # Use our own special initializer and finalizer files for libc.so.
00db10
 $(common-objpfx)libc.so: $(elfobjdir)/soinit.os \
00db10
 			 $(common-objpfx)libc_pic.os$(libc_pic_clean) \
00db10
@@ -660,8 +665,7 @@ include $(patsubst %,$(..)extra-modules.
00db10
 
00db10
 extra-modules-build := $(filter-out $(modules-names-nobuild),$(modules-names))
00db10
 $(extra-modules-build:%=$(objpfx)%.so): $(objpfx)%.so: \
00db10
-		$(objpfx)%.os $(shlib-lds) \
00db10
-		$(common-objpfx)libc.so $(common-objpfx)libc_nonshared.a
00db10
+		$(objpfx)%.os $(shlib-lds) $(link-libs-deps)
00db10
 	$(build-module)
00db10
 endif
00db10
 
00db10
Index: glibc-2.17-c758a686/crypt/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/crypt/Makefile
00db10
+++ glibc-2.17-c758a686/crypt/Makefile
00db10
@@ -72,8 +72,3 @@ endif
00db10
 ifeq (yes,$(build-bounded))
00db10
 $(tests:%=$(objpfx)%-bp): $(objpfx)libcrypt_b.a
00db10
 endif
00db10
-
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
-$(objpfx)libcrypt.so: $(common-objpfx)libc.so $(common-objpfx)libc_nonshared.a
00db10
Index: glibc-2.17-c758a686/debug/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/debug/Makefile
00db10
+++ glibc-2.17-c758a686/debug/Makefile
00db10
@@ -159,13 +159,3 @@ $(objpfx)xtrace: xtrace.sh
00db10
 	    -e 's|@PKGVERSION@|$(PKGVERSION)|' \
00db10
 	    -e 's|@REPORT_BUGS_TO@|$(REPORT_BUGS_TO)|' $^ > $@.new \
00db10
 	&& rm -f $@ && mv $@.new $@ && chmod +x $@
00db10
-
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
-$(objpfx)libSegFault.so: $(common-objpfx)libc.so \
00db10
-			 $(common-objpfx)libc_nonshared.a \
00db10
-			 $(elf-objpfx)$(rtld-installed-name)
00db10
-$(objpfx)libpcprofile.so: $(common-objpfx)libc.so \
00db10
-			  $(common-objpfx)libc_nonshared.a \
00db10
-			  $(elf-objpfx)$(rtld-installed-name)
00db10
Index: glibc-2.17-c758a686/dlfcn/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/dlfcn/Makefile
00db10
+++ glibc-2.17-c758a686/dlfcn/Makefile
00db10
@@ -117,16 +117,9 @@ $(objpfx)bug-atexit1.out: $(objpfx)bug-a
00db10
 $(objpfx)bug-atexit2: $(libdl)
00db10
 $(objpfx)bug-atexit2.out: $(objpfx)bug-atexit2-lib.so
00db10
 
00db10
-LDLIBS-bug-atexit3-lib.so = -lstdc++ -lgcc_eh $(elfobjdir)/ld.so \
00db10
-			    $(common-objpfx)libc_nonshared.a
00db10
+LDLIBS-bug-atexit3-lib.so = -lstdc++ -lgcc_eh
00db10
 $(objpfx)bug-atexit3: $(libdl)
00db10
 $(objpfx)bug-atexit3.out: $(objpfx)bug-atexit3-lib.so
00db10
 
00db10
 $(objpfx)tst-rec-dlopen: $(libdl)
00db10
 $(objpfx)tst-rec-dlopen.out: $(objpfx)moddummy1.so $(objpfx)moddummy2.so
00db10
-
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
-$(objpfx)libdl.so: $(common-objpfx)libc.so $(common-objpfx)libc_nonshared.a \
00db10
-		   $(elfobjdir)/ld.so
00db10
Index: glibc-2.17-c758a686/hesiod/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/hesiod/Makefile
00db10
+++ glibc-2.17-c758a686/hesiod/Makefile
00db10
@@ -33,12 +33,7 @@ libnss_hesiod-inhibit-o	= $(filter-out .
00db10
 
00db10
 include ../Rules
00db10
 
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
-# The Hesiod NSS modules also needs the resolver and some help from
00db10
+# The Hesiod NSS module also needs the resolver and some help from
00db10
 # the file service.
00db10
 $(objpfx)libnss_hesiod.so: $(common-objpfx)resolv/libresolv.so \
00db10
-			   $(common-objpfx)nss/libnss_files.so \
00db10
-			   $(common-objpfx)libc.so \
00db10
-			   $(common-objpfx)libc_nonshared.a
00db10
+			   $(common-objpfx)nss/libnss_files.so
00db10
Index: glibc-2.17-c758a686/iconvdata/extra-module.mk
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/iconvdata/extra-module.mk
00db10
+++ glibc-2.17-c758a686/iconvdata/extra-module.mk
00db10
@@ -4,16 +4,9 @@ extra-modules-left := $(strip $(filter-o
00db10
 extra-objs := $(extra-objs) $(patsubst %,%.os,$($(mod)-routines))
00db10
 
00db10
 $(objpfx)$(mod).so: $(addprefix $(objpfx),$(addsuffix .os,$($(mod)-routines)))\
00db10
-		    $(shlib-lds)
00db10
+		    $(shlib-lds) $(link-libc-deps)
00db10
 	$(build-module-asneeded)
00db10
 
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
-$(objpfx)$(mod).so: $(common-objpfx)libc.so \
00db10
-	$(common-objpfx)/elf/ld.so \
00db10
-	$(common-objpfx)libc_nonshared.a
00db10
-
00db10
 ifneq (,$(extra-modules-left))
00db10
 include extra-module.mk
00db10
 endif
00db10
Index: glibc-2.17-c758a686/libidn/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/libidn/Makefile
00db10
+++ glibc-2.17-c758a686/libidn/Makefile
00db10
@@ -33,5 +33,3 @@ include $(..)Makeconfig
00db10
 libcidn-inhibit-o = $(filter-out .os,$(object-suffixes))
00db10
 
00db10
 include $(..)Rules
00db10
-
00db10
-$(objpfx)libcidn.so: $(common-objpfx)libc.so $(common-objpfx)libc_nonshared.a
00db10
Index: glibc-2.17-c758a686/locale/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/locale/Makefile
00db10
+++ glibc-2.17-c758a686/locale/Makefile
00db10
@@ -99,9 +99,3 @@ cpp-srcs-left := $(localedef-modules) $(
00db10
 		 $(lib-modules)
00db10
 lib := locale-programs
00db10
 include $(patsubst %,$(..)cppflags-iterator.mk,$(cpp-srcs-left))
00db10
-
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
-$(objpfx)libBrokenLocale.so: $(common-objpfx)libc.so \
00db10
-			     $(common-objpfx)libc_nonshared.a
00db10
Index: glibc-2.17-c758a686/login/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/login/Makefile
00db10
+++ glibc-2.17-c758a686/login/Makefile
00db10
@@ -76,8 +76,3 @@ endif
00db10
 $(inst_libexecdir)/pt_chown: $(objpfx)pt_chown $(+force)
00db10
 	$(make-target-directory)
00db10
 	-$(INSTALL_PROGRAM) -m 4755 -o root $< $@
00db10
-
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
-$(objpfx)libutil.so: $(common-objpfx)libc.so $(common-objpfx)libc_nonshared.a
00db10
Index: glibc-2.17-c758a686/malloc/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/malloc/Makefile
00db10
+++ glibc-2.17-c758a686/malloc/Makefile
00db10
@@ -151,7 +151,7 @@ $(objpfx)memusage: memusage.sh
00db10
 
00db10
 
00db10
 # The implementation uses `dlsym'
00db10
-$(objpfx)libmemusage.so: $(common-objpfx)dlfcn/libdl.so $(elfobjdir)/ld.so
00db10
+$(objpfx)libmemusage.so: $(common-objpfx)dlfcn/libdl.so
00db10
 
00db10
 # Extra dependencies
00db10
 $(foreach o,$(all-object-suffixes),$(objpfx)malloc$(o)): arena.c hooks.c
00db10
Index: glibc-2.17-c758a686/math/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/math/Makefile
00db10
+++ glibc-2.17-c758a686/math/Makefile
00db10
@@ -203,8 +203,3 @@ gmp-objs = $(patsubst %,$(common-objpfx)
00db10
 $(objpfx)atest-exp: $(gmp-objs)
00db10
 $(objpfx)atest-sincos: $(gmp-objs)
00db10
 $(objpfx)atest-exp2: $(gmp-objs)
00db10
-
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
-$(objpfx)libm.so: $(common-objpfx)libc.so $(common-objpfx)libc_nonshared.a
00db10
Index: glibc-2.17-c758a686/nis/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/nis/Makefile
00db10
+++ glibc-2.17-c758a686/nis/Makefile
00db10
@@ -77,12 +77,12 @@ $(objpfx)libnss_nis.so: $(objpfx)libnsl.
00db10
 			$(common-objpfx)nss/libnss_files.so
00db10
 $(objpfx)libnss_nisplus.so: $(objpfx)libnsl.so$(libnsl.so-version)
00db10
 
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
 libnsl-libc = $(common-objpfx)linkobj/libc.so
00db10
-$(services:%=$(objpfx)libnss_%.so) $(objpfx)libnsl.so: $(libnsl-libc) \
00db10
-					       $(common-objpfx)libc_nonshared.a
00db10
+# Target-specific variable setting to link objects using deprecated
00db10
+# RPC interfaces with the version of libc.so that makes them available
00db10
+# for new links:
00db10
+$(services:%=$(objpfx)libnss_%.so) $(objpfx)libnsl.so: \
00db10
+  libc-for-link = $(libnsl-libc)
00db10
 
00db10
 
00db10
 ifeq ($(build-shared),yes)
00db10
Index: glibc-2.17-c758a686/nptl/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/nptl/Makefile
00db10
+++ glibc-2.17-c758a686/nptl/Makefile
00db10
@@ -530,14 +530,6 @@ $(objpfx)libpthread.so: $(addprefix $(ob
00db10
 $(objpfx)libpthread.so: +preinit += $(addprefix $(objpfx),$(crti-objs))
00db10
 $(objpfx)libpthread.so: +postinit += $(addprefix $(objpfx),$(crtn-objs))
00db10
 
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
-# Depend on ld.so too to get proper versions of ld.so symbols.
00db10
-$(objpfx)libpthread.so: $(common-objpfx)libc.so \
00db10
-			$(common-objpfx)libc_nonshared.a \
00db10
-			$(elfobjdir)/ld.so
00db10
-
00db10
 # Make sure we link with the thread library.
00db10
 ifeq ($(build-shared),yes)
00db10
 $(addprefix $(objpfx), \
00db10
Index: glibc-2.17-c758a686/nptl_db/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/nptl_db/Makefile
00db10
+++ glibc-2.17-c758a686/nptl_db/Makefile
00db10
@@ -51,12 +51,6 @@ libthread_db.so-no-z-defs = yes
00db10
 
00db10
 include ../Rules
00db10
 
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
-$(objpfx)libthread_db.so: $(common-objpfx)libc.so \
00db10
-			  $(common-objpfx)libc_nonshared.a
00db10
-
00db10
 tests: $(objpfx)db-symbols.out
00db10
 $(objpfx)db-symbols.out: $(objpfx)db-symbols.v.i \
00db10
 			 $(common-objpfx)nptl/libpthread.so
00db10
Index: glibc-2.17-c758a686/nss/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/nss/Makefile
00db10
+++ glibc-2.17-c758a686/nss/Makefile
00db10
@@ -86,12 +86,11 @@ ifeq (yes,$(have-selinux))
00db10
 LDLIBS-makedb		:= -lselinux
00db10
 endif
00db10
 
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
 libnss-libc = $(common-objpfx)linkobj/libc.so
00db10
-$(services:%=$(objpfx)libnss_%.so): $(libnss-libc) \
00db10
-				    $(common-objpfx)libc_nonshared.a
00db10
+# Target-specific variable setting to link objects using deprecated
00db10
+# RPC interfaces with the version of libc.so that makes them available
00db10
+# for new links:
00db10
+$(services:%=$(objpfx)libnss_%.so): libc-for-link = $(libnss-libc)
00db10
 
00db10
 $(objpfx)libnss_db.so: $(objpfx)libnss_files.so
00db10
 
00db10
@@ -109,8 +108,7 @@ $(inst_vardbdir)/Makefile: db-Makefile $
00db10
 	$(do-install)
00db10
 
00db10
 libof-nss_test1 = extramodules
00db10
-$(objpfx)/libnss_test1.so: $(objpfx)nss_test1.os $(common-objpfx)libc.so \
00db10
-			   $(common-objpfx)libc_nonshared.a
00db10
+$(objpfx)/libnss_test1.so: $(objpfx)nss_test1.os $(link-libc-deps)
00db10
 	$(build-module)
00db10
 ifdef libnss_test1.so-version
00db10
 $(objpfx)/libnss_test1.so$(libnss_test1.so-version): $(objpfx)/libnss_test1.so
00db10
Index: glibc-2.17-c758a686/ports/sysdeps/arm/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/ports/sysdeps/arm/Makefile
00db10
+++ glibc-2.17-c758a686/ports/sysdeps/arm/Makefile
00db10
@@ -25,11 +25,6 @@ sysdep_routines += $(aeabi_constants) $(
00db10
 static-only-routines += $(aeabi_constants)
00db10
 endif
00db10
 
00db10
-# to pull in __aeabi_read_tp, needed for tls
00db10
-ifeq ($(subdir),malloc)
00db10
-$(objpfx)libmemusage.so: $(common-objpfx)libc_nonshared.a
00db10
-endif
00db10
-
00db10
 ifeq ($(subdir),gmon)
00db10
 sysdep_routines += arm-mcount
00db10
 endif
00db10
@@ -37,7 +32,3 @@ endif
00db10
 ifeq ($(subdir),debug)
00db10
 CFLAGS-backtrace.c += -funwind-tables
00db10
 endif
00db10
-
00db10
-ifeq ($(subdir),math)
00db10
-$(objpfx)libm.so: $(elfobjdir)/ld.so
00db10
-endif
00db10
Index: glibc-2.17-c758a686/resolv/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/resolv/Makefile
00db10
+++ glibc-2.17-c758a686/resolv/Makefile
00db10
@@ -88,23 +88,11 @@ CFLAGS-res_hconf.c = -fexceptions
00db10
 # The BIND code elicits some harmless warnings.
00db10
 +cflags += -Wno-strict-prototypes -Wno-write-strings
00db10
 
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
-$(objpfx)libresolv.so: $(common-objpfx)libc.so $(common-objpfx)libc_nonshared.a
00db10
-# Some hosts need '__stack_chk_guard', so pull in the definition from
00db10
-# ld.so if required.
00db10
-ifeq (yes,$(have-ssp))
00db10
-LDLIBS-resolv.so += $(as-needed) $(elfobjdir)/ld.so $(no-as-needed)
00db10
-endif
00db10
-
00db10
 # The DNS NSS modules needs the resolver.
00db10
-$(objpfx)libnss_dns.so: $(objpfx)libresolv.so $(common-objpfx)libc.so \
00db10
-			$(common-objpfx)libc_nonshared.a
00db10
+$(objpfx)libnss_dns.so: $(objpfx)libresolv.so
00db10
 
00db10
 # The asynchronous name lookup code needs the thread library.
00db10
-$(objpfx)libanl.so: $(common-objpfx)libc.so $(common-objpfx)libc_nonshared.a \
00db10
-		    $(shared-thread-library)
00db10
+$(objpfx)libanl.so: $(shared-thread-library)
00db10
 
00db10
 $(objpfx)ga_test: $(objpfx)libanl.so $(shared-thread-library)
00db10
 
00db10
Index: glibc-2.17-c758a686/rt/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/rt/Makefile
00db10
+++ glibc-2.17-c758a686/rt/Makefile
00db10
@@ -64,12 +64,7 @@ CFLAGS-librt-cancellation.c = -fasynchro
00db10
 
00db10
 LDFLAGS-rt.so = -Wl,--enable-new-dtags,-z,nodelete
00db10
 
00db10
-# Depend on libc.so so a DT_NEEDED is generated in the shared objects.
00db10
-# This ensures they will load libc.so for needed symbols if loaded by
00db10
-# a statically-linked program that hasn't already loaded it.
00db10
-$(objpfx)librt.so: $(common-objpfx)libc.so $(common-objpfx)libc_nonshared.a \
00db10
-		   $(shared-thread-library) \
00db10
-		   $(elfobjdir)/ld.so
00db10
+$(objpfx)librt.so: $(shared-thread-library)
00db10
 
00db10
 ifeq (yes,$(build-shared))
00db10
 $(addprefix $(objpfx),$(tests)): $(objpfx)librt.so $(shared-thread-library)
00db10
Index: glibc-2.17-c758a686/stdlib/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/stdlib/Makefile
00db10
+++ glibc-2.17-c758a686/stdlib/Makefile
00db10
@@ -136,7 +136,7 @@ $(objpfx)tst-fmtmsg.out: tst-fmtmsg.sh $
00db10
 $(objpfx)tst-putenv: $(objpfx)tst-putenvmod.so
00db10
 LDFLAGS-tst-putenv = $(no-as-needed)
00db10
 
00db10
-$(objpfx)tst-putenvmod.so: $(objpfx)tst-putenvmod.os
00db10
+$(objpfx)tst-putenvmod.so: $(objpfx)tst-putenvmod.os $(link-libc-deps)
00db10
 	$(build-module)
00db10
 libof-tst-putenvmod = extramodules
00db10
 
00db10
Index: glibc-2.17-c758a686/sysdeps/i386/fpu/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/sysdeps/i386/fpu/Makefile
00db10
+++ /dev/null
00db10
@@ -1,3 +0,0 @@
00db10
-ifeq ($(subdir),math)
00db10
-$(objpfx)libm.so: $(elfobjdir)/ld.so
00db10
-endif
00db10
Index: glibc-2.17-c758a686/sysdeps/powerpc/fpu/Makefile
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/sysdeps/powerpc/fpu/Makefile
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/fpu/Makefile
00db10
@@ -2,8 +2,6 @@ ifeq ($(subdir),math)
00db10
 libm-support += fenv_const fe_nomask fe_mask t_sqrt
00db10
 libm-tests += test-powerpc-snan
00db10
 
00db10
-# libm needs ld.so to access dl_hwcap
00db10
-$(objpfx)libm.so: $(elfobjdir)/ld.so
00db10
 endif
00db10
 
00db10
 ifeq ($(subdir),stdlib)