From: Adhemerval Zanella Date: Tue, 18 Mar 2025 19:10:05 +0000 (-0300) Subject: elf: Fix tst-origin make rules X-Git-Tag: glibc-2.42~384 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=5291d9f1e274dd869bc0b3d044fd4cbae486893d;p=thirdparty%2Fglibc.git elf: Fix tst-origin make rules The tst-origin build can fail with: /usr/bin/ld: [...]libc.so: undefined reference to `__tunable_is_initialized@GLIBC_PRIVATE' Since the custom link invocation links against system glibc instead of the built one. The only requirement is to avoid liborigin.so linked with a full path, which is the default for --enable-hardcoded-path-in-tests. There is no need to use a custom rule. Checked on x86_64-linux-gnu. --- diff --git a/elf/Makefile b/elf/Makefile index 5a50c7d50c..3d60000ec9 100644 --- a/elf/Makefile +++ b/elf/Makefile @@ -456,6 +456,7 @@ tests += \ tst-noload \ tst-non-directory-path \ tst-null-argv \ + tst-origin \ tst-p_align1 \ tst-p_align2 \ tst-p_align3 \ @@ -1195,7 +1196,6 @@ extra-test-objs += $(addsuffix .os,$(strip $(modules-names))) # filtmod1.so, tst-big-note-lib.so, tst-ro-dynamic-mod.so have special # rules. modules-names-nobuild += \ - liborigin-mod \ filtmod1 \ tst-audit24bmod1 \ tst-audit24bmod2 \ @@ -3451,15 +3451,8 @@ $(objpfx)tst-dlopen-constructor-null-mod2.so: \ CFLAGS-tst-origin.c += $(no-stack-protector) CFLAGS-liborigin-mod.c += $(no-stack-protector) -$(objpfx)tst-origin: $(objpfx)tst-origin.o $(objpfx)liborigin-mod.so - $(LINK.o) -o $@ -B$(csu-objpfx) $(LDFLAGS.so) $< \ - -Wl,-rpath,\$$ORIGIN \ - -L$(subst :, -L,$(rpath-link)) -Wl,--no-as-needed -lorigin-mod -$(objpfx)liborigin-mod.so: $(objpfx)liborigin-mod.os - $(LINK.o) -shared -o $@ -B$(csu-objpfx) $(LDFLAGS.so) \ - $(LDFLAGS-soname-fname) \ - $< -$(objpfx)tst-origin.out: tst-origin.sh $(objpfx)tst-origin +LDFLAGS-tst-origin += -Wl,-rpath,\$$ORIGIN -L$(subst :, -L,$(rpath-link)) -lorigin-mod +$(objpfx)tst-origin.out: tst-origin.sh $(objpfx)liborigin-mod.so $(objpfx)tst-origin $(SHELL) \ $< \ '$(common-objpfx)' \