aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFlorian Weimer <fweimer@redhat.com>2019-10-29 12:23:48 +0100
committerFlorian Weimer <fweimer@redhat.com>2019-10-29 12:23:48 +0100
commit10c5d5518cd6a90f8e541194889a38061acc7951 (patch)
tree802608066907d99752e54765b62f76ad001f884f
parentaae3acbaa7cf9ebba084bc4ae0f2c56bad425b89 (diff)
downloadglibc-10c5d5518cd6a90f8e541194889a38061acc7951.tar
glibc-10c5d5518cd6a90f8e541194889a38061acc7951.tar.gz
glibc-10c5d5518cd6a90f8e541194889a38061acc7951.tar.bz2
glibc-10c5d5518cd6a90f8e541194889a38061acc7951.zip
Introduce DL_LOOKUP_FOR_RELOCATE flag for _dl_lookup_symbol_xfw/elf-fixups
This will allow changes in dependency processing during non-lazy binding, for more precise processing of NODELETE objects: During initial relocation in dlopen, the fate of NODELETE objects is still unclear, so objects which are depended upon by NODELETE objects cannot immediately be marked as NODELETE.
-rw-r--r--elf/dl-reloc.c3
-rw-r--r--sysdeps/generic/ldsodefs.h3
2 files changed, 5 insertions, 1 deletions
diff --git a/elf/dl-reloc.c b/elf/dl-reloc.c
index 725a074a79..7f201fe184 100644
--- a/elf/dl-reloc.c
+++ b/elf/dl-reloc.c
@@ -244,7 +244,8 @@ _dl_relocate_object (struct link_map *l, struct r_scope_elem *scope[],
v = (version); \
_lr = _dl_lookup_symbol_x (strtab + (*ref)->st_name, l, (ref), \
scope, v, _tc, \
- DL_LOOKUP_ADD_DEPENDENCY, NULL); \
+ DL_LOOKUP_ADD_DEPENDENCY \
+ | DL_LOOKUP_FOR_RELOCATE, NULL); \
l->l_lookup_cache.ret = (*ref); \
l->l_lookup_cache.value = _lr; })) \
: l)
diff --git a/sysdeps/generic/ldsodefs.h b/sysdeps/generic/ldsodefs.h
index f3ba13ee68..7d5b80dc57 100644
--- a/sysdeps/generic/ldsodefs.h
+++ b/sysdeps/generic/ldsodefs.h
@@ -914,6 +914,9 @@ enum
DL_LOOKUP_RETURN_NEWEST = 2,
/* Set if dl_lookup* called with GSCOPE lock held. */
DL_LOOKUP_GSCOPE_LOCK = 4,
+ /* Set if dl_lookup is called for non-lazy relocation processing
+ from _dl_relocate_object in elf/dl-reloc.c. */
+ DL_LOOKUP_FOR_RELOCATE = 8,
};
/* Lookup versioned symbol. */