mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-21 20:40:05 +00:00
csu: Move static pie self relocation later [BZ #27072]
IFUNC resolvers may depend on tunables and cpu feature setup so move static pie self relocation after those. It is hard to guarantee that the ealy startup code does not rely on relocations so this is a bit fragile. It would be more robust to handle RELATIVE relocs early and only IRELATIVE relocs later, but the current relocation processing code cannot do that. The early startup code up to relocation processing includes _dl_aux_init (auxvec); __libc_init_secure (); __tunables_init (__environ); ARCH_INIT_CPU_FEATURES (); _dl_relocate_static_pie (); These are simple enough that RELATIVE relocs can be avoided. The following steps include ARCH_SETUP_IREL (); ARCH_SETUP_TLS (); ARCH_APPLY_IREL (); On some targets IRELATIVE processing relies on TLS setup on others TLS setup relies on IRELATIVE relocs, so the right position for _dl_relocate_static_pie is target dependent. For now move self relocation as early as possible on targets that support static PIE. Fixes bug 27072. Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
This commit is contained in:
parent
47618209d0
commit
86d439b06f
@ -146,8 +146,6 @@ LIBC_START_MAIN (int (*main) (int, char **, char ** MAIN_AUXVEC_DECL),
|
||||
int result;
|
||||
|
||||
#ifndef SHARED
|
||||
_dl_relocate_static_pie ();
|
||||
|
||||
char **ev = &argv[argc + 1];
|
||||
|
||||
__environ = ev;
|
||||
@ -199,6 +197,11 @@ LIBC_START_MAIN (int (*main) (int, char **, char ** MAIN_AUXVEC_DECL),
|
||||
|
||||
ARCH_INIT_CPU_FEATURES ();
|
||||
|
||||
/* Do static pie self relocation after tunables and cpu features
|
||||
are setup for ifunc resolvers. Before this point relocations
|
||||
must be avoided. */
|
||||
_dl_relocate_static_pie ();
|
||||
|
||||
/* Perform IREL{,A} relocations. */
|
||||
ARCH_SETUP_IREL ();
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user