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:
parent
68b007788a
commit
75a933f399
@ -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>
|
||||
|
||||
* elf-linker-x86.h (elf_linker_x86_params): Add
|
||||
|
@ -1711,8 +1711,7 @@ _bfd_x86_elf_link_fixup_ifunc_symbol (struct bfd_link_info *info,
|
||||
&& h->def_regular
|
||||
&& h->dynindx != -1
|
||||
&& h->plt.offset != (bfd_vma) -1
|
||||
&& h->type == STT_GNU_IFUNC
|
||||
&& h->pointer_equality_needed)
|
||||
&& h->type == STT_GNU_IFUNC)
|
||||
{
|
||||
asection *plt_s;
|
||||
bfd_vma plt_offset;
|
||||
|
@ -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>
|
||||
|
||||
* NEWS: Mention -z report-relative-reloc.
|
||||
|
@ -640,7 +640,7 @@ run_cc_link_tests [list \
|
||||
"$NOPIE_LDFLAGS -Wl,--no-as-needed tmpdir/libpr23169a.so" \
|
||||
"-fPIE -O2 -g" \
|
||||
{ pr23169b.c pr23169c.c } \
|
||||
{{readelf {--dyn-syms} pr23169c.rd} \
|
||||
{{readelf {--dyn-syms} pr23169a.rd} \
|
||||
{readelf {-r -W} pr23169b.rd}} \
|
||||
"pr23169c" \
|
||||
] \
|
||||
@ -653,21 +653,12 @@ run_cc_link_tests [list \
|
||||
{readelf {-r -W} pr23169b.rd}} \
|
||||
"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 \
|
||||
"Build pr23169f" \
|
||||
"$NOPIE_LDFLAGS -Wl,--no-as-needed,-z,now tmpdir/libpr23169b.so" \
|
||||
"-fPIE -O2 -g" \
|
||||
{ pr23169b.c pr23169c.c } \
|
||||
{{readelf {--dyn-syms} pr23169c.rd} \
|
||||
{{readelf {--dyn-syms} pr23169a.rd} \
|
||||
{readelf {-r -W} pr23169b.rd}} \
|
||||
"pr23169f" \
|
||||
] \
|
||||
@ -774,15 +765,6 @@ run_ld_link_exec_tests [list \
|
||||
"pass.out" \
|
||||
"$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 \
|
||||
"Run pr23169f" \
|
||||
"$NOPIE_LDFLAGS -Wl,--no-as-needed,-z,now tmpdir/libpr23169b.so" \
|
||||
|
@ -4,6 +4,6 @@ extern int func (void);
|
||||
void
|
||||
foo (void)
|
||||
{
|
||||
if (func_p != &func || func_p () != 0xbadbeef)
|
||||
if (func () != 0xbadbeef || func_p () != 0xbadbeef)
|
||||
__builtin_abort ();
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user