2020-10-14 23:45:26 +00:00
|
|
|
Short description: Cleanup use of _dl_starting_up.
|
|
|
|
Author(s): Fedora glibc team <glibc@lists.fedoraproject.org>
|
|
|
|
Origin: PATCH
|
|
|
|
Upstream status: https://sourceware.org/ml/libc-alpha/2014-02/msg00589.html
|
|
|
|
|
|
|
|
Upstream discussions:
|
|
|
|
https://sourceware.org/ml/libc-alpha/2014-02/msg00580.html
|
|
|
|
|
|
|
|
Based on the following commit:
|
|
|
|
~~~
|
|
|
|
From 16552c01a66633c9e412984d9d92616bd4e5303c Mon Sep 17 00:00:00 2001
|
|
|
|
From: Andreas Schwab <schwab@redhat.com>
|
|
|
|
Date: Fri, 11 Jun 2010 11:04:11 +0200
|
|
|
|
Subject: [PATCH] Properly set __libc_multiple_libcs
|
|
|
|
|
|
|
|
* elf/rtld.c (_dl_starting_up): Always define.
|
|
|
|
(dl_main): Always set _dl_starting_up.
|
|
|
|
* elf/dl-support.c (_dl_starting_up): Always define.
|
|
|
|
* elf/dl-init.c (_dl_init): Always clear _dl_starting_up.
|
|
|
|
|
|
|
|
---
|
|
|
|
ChangeLog | 7 +++++++
|
|
|
|
elf/dl-init.c | 4 ----
|
|
|
|
elf/dl-support.c | 2 --
|
|
|
|
elf/rtld.c | 4 ----
|
|
|
|
4 files changed, 7 insertions(+), 10 deletions(-)
|
|
|
|
~~~
|
|
|
|
|
|
|
|
This patch needs to go upstream to get cleaned up, but has always involed
|
|
|
|
analysis of the GNU/Hurd parts of the change and that stalled out, but
|
|
|
|
perhaps with build-many-glibcs we can now test these changes more easily.
|
|
|
|
|
|
|
|
diff --git a/elf/dl-init.c b/elf/dl-init.c
|
|
|
|
index 518824e8a5826314..66c395474a57c1fd 100644
|
|
|
|
--- a/elf/dl-init.c
|
|
|
|
+++ b/elf/dl-init.c
|
|
|
|
@@ -120,8 +120,6 @@ _dl_init (struct link_map *main_map, int argc, char **argv, char **env)
|
|
|
|
while (i-- > 0)
|
|
|
|
call_init (main_map->l_initfini[i], argc, argv, env);
|
|
|
|
|
|
|
|
-#ifndef HAVE_INLINED_SYSCALLS
|
|
|
|
/* Finished starting up. */
|
|
|
|
_dl_starting_up = 0;
|
|
|
|
-#endif
|
|
|
|
}
|
|
|
|
diff --git a/elf/dl-support.c b/elf/dl-support.c
|
2020-10-23 15:45:59 +00:00
|
|
|
index afbc94df5435a7d7..e894f98e97641cef 100644
|
2020-10-14 23:45:26 +00:00
|
|
|
--- a/elf/dl-support.c
|
|
|
|
+++ b/elf/dl-support.c
|
|
|
|
@@ -120,10 +120,8 @@ struct r_scope_elem _dl_initial_searchlist =
|
|
|
|
.r_nlist = 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
-#ifndef HAVE_INLINED_SYSCALLS
|
|
|
|
/* Nonzero during startup. */
|
|
|
|
int _dl_starting_up = 1;
|
|
|
|
-#endif
|
|
|
|
|
|
|
|
/* Random data provided by the kernel. */
|
|
|
|
void *_dl_random;
|
|
|
|
diff --git a/elf/rtld.c b/elf/rtld.c
|
2020-10-23 15:45:59 +00:00
|
|
|
index 5d117d0d2c5902c1..3c4bb5605234409d 100644
|
2020-10-14 23:45:26 +00:00
|
|
|
--- a/elf/rtld.c
|
|
|
|
+++ b/elf/rtld.c
|
2020-10-23 15:45:59 +00:00
|
|
|
@@ -294,7 +294,6 @@ dl_main_state_init (struct dl_main_state *state)
|
|
|
|
state->version_info = false;
|
2020-10-14 23:45:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
-#ifndef HAVE_INLINED_SYSCALLS
|
|
|
|
/* Set nonzero during loading and initialization of executable and
|
|
|
|
libraries, cleared before the executable's entry point runs. This
|
|
|
|
must not be initialized to nonzero, because the unused dynamic
|
2020-10-23 15:45:59 +00:00
|
|
|
@@ -304,7 +303,6 @@ dl_main_state_init (struct dl_main_state *state)
|
2020-10-14 23:45:26 +00:00
|
|
|
never be called. */
|
|
|
|
int _dl_starting_up = 0;
|
|
|
|
rtld_hidden_def (_dl_starting_up)
|
|
|
|
-#endif
|
|
|
|
|
|
|
|
/* This is the structure which defines all variables global to ld.so
|
|
|
|
(except those which cannot be added for some reason). */
|
2020-10-23 15:45:59 +00:00
|
|
|
@@ -1146,10 +1144,8 @@ dl_main (const ElfW(Phdr) *phdr,
|
2020-10-14 23:45:26 +00:00
|
|
|
/* Process the environment variable which control the behaviour. */
|
2020-10-23 15:45:59 +00:00
|
|
|
process_envvars (&state);
|
2020-10-14 23:45:26 +00:00
|
|
|
|
|
|
|
-#ifndef HAVE_INLINED_SYSCALLS
|
|
|
|
/* Set up a flag which tells we are just starting. */
|
|
|
|
_dl_starting_up = 1;
|
|
|
|
-#endif
|
|
|
|
|
2020-10-23 15:45:59 +00:00
|
|
|
const char *ld_so_name = _dl_argv[0];
|
2020-10-14 23:45:26 +00:00
|
|
|
if (*user_entry == (ElfW(Addr)) ENTRY_POINT)
|