ld/elf/x86: Don't compare IFUNC address in the shared object

On x86, glibc 2.33 starts to issue a fatal error message when calling
IFUNC function defined in the unrelocated executable from a shared
library.

1. Update x86 ELF linker to always convert IFUNC function defined in
position-dependent executable (PDE) to the normal function.  GOT in PDE
will be updated by R_*_IRELATIVE at run-time.
2. Update PR ld/23169 tests not to compare function address of external
IFUNC function in the shared object to avoid calling the IFUNC function
defined in the unrelocated executable.
3. Remove pr23169e tests which call the IFUNC function defined in the
unrelocated position-independent executable from a shared library.

bfd/

	PR ld/23169
	* elfxx-x86.c (_bfd_x86_elf_link_fixup_ifunc_symbol): Don't
	check pointer_equality_needed.

ld/

	PR ld/23169
	* testsuite/ld-ifunc/ifunc.exp: Replace pr23169c.rd with
	pr23169a.rd for pr23169c and pr23169f.  Remove pr23169e tests.
	* testsuite/ld-ifunc/pr23169a.c (foo): Don't compare function
	address.
This commit is contained in:
H.J. Lu 2021-01-16 07:00:09 -08:00
parent 68b007788a
commit 75a933f399
5 changed files with 18 additions and 23 deletions

View File

@ -1,3 +1,9 @@
2021-01-16 H.J. Lu <hongjiu.lu@intel.com>
PR ld/23169
* elfxx-x86.c (_bfd_x86_elf_link_fixup_ifunc_symbol): Don't
check pointer_equality_needed.
2021-01-15 H.J. Lu <hongjiu.lu@intel.com> 2021-01-15 H.J. Lu <hongjiu.lu@intel.com>
* elf-linker-x86.h (elf_linker_x86_params): Add * elf-linker-x86.h (elf_linker_x86_params): Add

View File

@ -1711,8 +1711,7 @@ _bfd_x86_elf_link_fixup_ifunc_symbol (struct bfd_link_info *info,
&& h->def_regular && h->def_regular
&& h->dynindx != -1 && h->dynindx != -1
&& h->plt.offset != (bfd_vma) -1 && h->plt.offset != (bfd_vma) -1
&& h->type == STT_GNU_IFUNC && h->type == STT_GNU_IFUNC)
&& h->pointer_equality_needed)
{ {
asection *plt_s; asection *plt_s;
bfd_vma plt_offset; bfd_vma plt_offset;

View File

@ -1,3 +1,11 @@
2021-01-16 H.J. Lu <hongjiu.lu@intel.com>
PR ld/23169
* testsuite/ld-ifunc/ifunc.exp: Replace pr23169c.rd with
pr23169a.rd for pr23169c and pr23169f. Remove pr23169e tests.
* testsuite/ld-ifunc/pr23169a.c (foo): Don't compare function
address.
2021-01-15 H.J. Lu <hongjiu.lu@intel.com> 2021-01-15 H.J. Lu <hongjiu.lu@intel.com>
* NEWS: Mention -z report-relative-reloc. * NEWS: Mention -z report-relative-reloc.

View File

@ -640,7 +640,7 @@ run_cc_link_tests [list \
"$NOPIE_LDFLAGS -Wl,--no-as-needed tmpdir/libpr23169a.so" \ "$NOPIE_LDFLAGS -Wl,--no-as-needed tmpdir/libpr23169a.so" \
"-fPIE -O2 -g" \ "-fPIE -O2 -g" \
{ pr23169b.c pr23169c.c } \ { pr23169b.c pr23169c.c } \
{{readelf {--dyn-syms} pr23169c.rd} \ {{readelf {--dyn-syms} pr23169a.rd} \
{readelf {-r -W} pr23169b.rd}} \ {readelf {-r -W} pr23169b.rd}} \
"pr23169c" \ "pr23169c" \
] \ ] \
@ -653,21 +653,12 @@ run_cc_link_tests [list \
{readelf {-r -W} pr23169b.rd}} \ {readelf {-r -W} pr23169b.rd}} \
"pr23169d" \ "pr23169d" \
] \ ] \
[list \
"Build pr23169e" \
"-pie -Wl,--no-as-needed,-z,now tmpdir/libpr23169b.so" \
"-fPIE -O2 -g" \
{ pr23169b.c pr23169c.c } \
{{readelf {--dyn-syms} pr23169c.rd} \
{readelf {-r -W} pr23169b.rd}} \
"pr23169e" \
] \
[list \ [list \
"Build pr23169f" \ "Build pr23169f" \
"$NOPIE_LDFLAGS -Wl,--no-as-needed,-z,now tmpdir/libpr23169b.so" \ "$NOPIE_LDFLAGS -Wl,--no-as-needed,-z,now tmpdir/libpr23169b.so" \
"-fPIE -O2 -g" \ "-fPIE -O2 -g" \
{ pr23169b.c pr23169c.c } \ { pr23169b.c pr23169c.c } \
{{readelf {--dyn-syms} pr23169c.rd} \ {{readelf {--dyn-syms} pr23169a.rd} \
{readelf {-r -W} pr23169b.rd}} \ {readelf {-r -W} pr23169b.rd}} \
"pr23169f" \ "pr23169f" \
] \ ] \
@ -774,15 +765,6 @@ run_ld_link_exec_tests [list \
"pass.out" \ "pass.out" \
"$NOPIE_CFLAGS -O2 -g" \ "$NOPIE_CFLAGS -O2 -g" \
] \ ] \
[list \
"Run pr23169e" \
"-pie -Wl,--no-as-needed,-z,now tmpdir/libpr23169b.so" \
"" \
{ pr23169b.c pr23169c.c } \
"pr23169e" \
"pass.out" \
"-fPIE -O2 -g" \
] \
[list \ [list \
"Run pr23169f" \ "Run pr23169f" \
"$NOPIE_LDFLAGS -Wl,--no-as-needed,-z,now tmpdir/libpr23169b.so" \ "$NOPIE_LDFLAGS -Wl,--no-as-needed,-z,now tmpdir/libpr23169b.so" \

View File

@ -4,6 +4,6 @@ extern int func (void);
void void
foo (void) foo (void)
{ {
if (func_p != &func || func_p () != 0xbadbeef) if (func () != 0xbadbeef || func_p () != 0xbadbeef)
__builtin_abort (); __builtin_abort ();
} }