diff options
author | Florian Weimer <fweimer@redhat.com> | 2020-02-19 20:55:48 +0100 |
---|---|---|
committer | DJ Delorie <dj@redhat.com> | 2020-12-04 17:15:05 -0500 |
commit | 171689dac7fcb979e7d3ffbd307eacae3c07c2d3 (patch) | |
tree | ddd9febed20f88719d7eaf2938798a57b0631074 /malloc/set-freeres.c | |
parent | 7dc2f14bb340bce9a6283dfa7dfde18ec2cb24a2 (diff) | |
download | glibc-171689dac7fcb979e7d3ffbd307eacae3c07c2d3.tar glibc-171689dac7fcb979e7d3ffbd307eacae3c07c2d3.tar.gz glibc-171689dac7fcb979e7d3ffbd307eacae3c07c2d3.tar.bz2 glibc-171689dac7fcb979e7d3ffbd307eacae3c07c2d3.zip |
nss: Introduce <nss_module.h>
This provides the struct nss_module type, which combines the old
struct service_library type with the known_function tree, by
statically allocating space for all function pointers.
struct nss_module is fairly large (536 bytes), but it will be
shared across NSS databases. The old known_function handling
had non-some per-function overhead (at least 32 bytes per looked-up
function, but more for long function anmes), so overall, this is not
too bad. Resolving all functions at load time simplifies locking,
and the repeated lookups should be fast because the caches are hot
at this point.
Reviewed-by: Siddhesh Poyarekar <siddhesh@sourceware.org>
Diffstat (limited to 'malloc/set-freeres.c')
-rw-r--r-- | malloc/set-freeres.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/malloc/set-freeres.c b/malloc/set-freeres.c index aa80eb64b8..b328cca7c6 100644 --- a/malloc/set-freeres.c +++ b/malloc/set-freeres.c @@ -20,6 +20,7 @@ #include <set-hooks.h> #include <libc-internal.h> +#include "../nss/nss_module.h" #include "../libio/libioP.h" DEFINE_HOOK (__libc_subfreeres, (void)); @@ -41,6 +42,8 @@ __libc_freeres (void) { void *const *p; + call_function_static_weak (__nss_module_freeres); + _IO_cleanup (); /* We run the resource freeing after IO cleanup. */ |