glibc/dlfcn
Florian Weimer bc56ab1f4a dlfcn: Do not use rtld_active () to determine ld.so state (bug 29078)
When audit modules are loaded, ld.so initialization is not yet
complete, and rtld_active () returns false even though ld.so is
mostly working.  Instead, the static dlopen hook is used, but that
does not work at all because this is not a static dlopen situation.

Commit 466c1ea15f ("dlfcn: Rework
static dlopen hooks") moved the hook pointer into _rtld_global_ro,
which means that separate protection is not needed anymore and the
hook pointer can be checked directly.

The guard for disabling libio vtable hardening in _IO_vtable_check
should stay for now.

Fixes commit 8e1472d2c1 ("ld.so:
Examine GLRO to detect inactive loader [BZ #20204]").

Reviewed-by: Adhemerval Zanella  <adhemerval.zanella@linaro.org>
(cherry picked from commit 8dcb6d0af0)
2022-04-26 15:28:39 +02:00
..
bug-atexit1-lib.c
bug-atexit1.c
bug-atexit2-lib.c
bug-atexit2.c
bug-atexit3-lib.cc
bug-atexit3.c
bug-dl-leaf-lib-cb.c
bug-dl-leaf-lib.c
bug-dl-leaf.c
bug-dlopen1.c
bug-dlsym1-lib1.c
bug-dlsym1-lib2.c
bug-dlsym1.c
default.c
defaultmod1.c
defaultmod2.c
dladdr1.c dlfcn: Do not use rtld_active () to determine ld.so state (bug 29078) 2022-04-26 15:28:39 +02:00
dladdr.c dlfcn: Do not use rtld_active () to determine ld.so state (bug 29078) 2022-04-26 15:28:39 +02:00
dlclose.c dlfcn: Do not use rtld_active () to determine ld.so state (bug 29078) 2022-04-26 15:28:39 +02:00
dlerror.c dlfcn: Do not use rtld_active () to determine ld.so state (bug 29078) 2022-04-26 15:28:39 +02:00
dlerror.h dlfcn: dlerror needs to call free from the base namespace [BZ #24773] 2021-04-21 19:49:51 +02:00
dlfcn.h
dlinfo.c dlfcn: Do not use rtld_active () to determine ld.so state (bug 29078) 2022-04-26 15:28:39 +02:00
dlmopen.c dlfcn: Do not use rtld_active () to determine ld.so state (bug 29078) 2022-04-26 15:28:39 +02:00
dlopen.c dlfcn: Do not use rtld_active () to determine ld.so state (bug 29078) 2022-04-26 15:28:39 +02:00
dlopenold.c dlfcn: Do not use rtld_active () to determine ld.so state (bug 29078) 2022-04-26 15:28:39 +02:00
dlsym.c dlfcn: Do not use rtld_active () to determine ld.so state (bug 29078) 2022-04-26 15:28:39 +02:00
dlvsym.c dlfcn: Do not use rtld_active () to determine ld.so state (bug 29078) 2022-04-26 15:28:39 +02:00
errmsg1.c
errmsg1mod.c
failtest.c
failtestmod.c
glreflib1.c
glreflib2.c
glreflib3.c
glrefmain.c
libc_dlerror_result.c dlfcn: dlerror needs to call free from the base namespace [BZ #24773] 2021-04-21 19:49:51 +02:00
libdl-compat.c dlfcn: Cleanups after -ldl is no longer required 2021-06-03 09:11:45 +02:00
Makefile dlfcn: Cleanups after -ldl is no longer required 2021-06-03 09:11:45 +02:00
modatexit.c
modcxaatexit.c
moddummy1.c
moddummy2.c
modstatic2.c dlfcn: Eliminate GLIBC_PRIVATE dependency from tststatic2 2021-06-03 09:12:05 +02:00
modstatic3.c
modstatic5.c
modstatic.c
sdlfreeres.c
tst-dladdr.c
tst-dlinfo.c
tst-rec-dlopen.c
tstatexit.c
tstcxaatexit.c
tststatic2.c dlfcn: Eliminate GLIBC_PRIVATE dependency from tststatic2 2021-06-03 09:12:05 +02:00
tststatic3.c
tststatic4.c
tststatic5.c elf: Partially initialize ld.so after static dlopen (bug 20802) 2021-05-17 10:06:57 +02:00
tststatic.c
Versions dlfcn: Move dlopen into libc 2021-06-03 08:26:04 +02:00