forked from rpms/glibc
36 lines
1.1 KiB
Diff
36 lines
1.1 KiB
Diff
|
commit b893410be304ddcea0bd43f537a13e8b18d37cf2
|
||
|
Author: Florian Weimer <fweimer@redhat.com>
|
||
|
Date: Mon Nov 27 11:28:07 2023 +0100
|
||
|
|
||
|
elf: In _dl_relocate_object, skip processing if object is relocated
|
||
|
|
||
|
This is just a minor optimization. It also makes it more obvious that
|
||
|
_dl_relocate_object can be called multiple times.
|
||
|
|
||
|
Reviewed-by: Carlos O'Donell <carlos@redhat.com>
|
||
|
|
||
|
diff --git a/elf/dl-reloc.c b/elf/dl-reloc.c
|
||
|
index 5b69321bda1f2b27..bbc5c15170a0856b 100644
|
||
|
--- a/elf/dl-reloc.c
|
||
|
+++ b/elf/dl-reloc.c
|
||
|
@@ -192,6 +192,9 @@ void
|
||
|
_dl_relocate_object (struct link_map *l, struct r_scope_elem *scope[],
|
||
|
int reloc_mode, int consider_profiling)
|
||
|
{
|
||
|
+ if (l->l_relocated)
|
||
|
+ return;
|
||
|
+
|
||
|
struct textrels
|
||
|
{
|
||
|
caddr_t start;
|
||
|
@@ -229,9 +232,6 @@ _dl_relocate_object (struct link_map *l, struct r_scope_elem *scope[],
|
||
|
# define consider_symbind 0
|
||
|
#endif
|
||
|
|
||
|
- if (l->l_relocated)
|
||
|
- return;
|
||
|
-
|
||
|
/* If DT_BIND_NOW is set relocate all references in this object. We
|
||
|
do not do this if we are profiling, of course. */
|
||
|
// XXX Correct for auditing?
|