1
0
mirror of https://sourceware.org/git/glibc.git synced 2025-08-08 17:42:12 +03:00

elf: Split _dl_lookup_map, _dl_map_new_object from _dl_map_object

So that they can eventually be called separately from dlopen.
This commit is contained in:
Florian Weimer
2025-02-02 20:10:08 +01:00
parent a7aad6e2b7
commit aa1bf89039
2 changed files with 42 additions and 12 deletions

View File

@@ -1887,24 +1887,14 @@ open_path (const char *name, size_t namelen, int mode,
return -1;
}
/* Map in the shared object file NAME. */
struct link_map *
_dl_map_object (struct link_map *loader, const char *name,
int type, int trace_mode, int mode, Lmid_t nsid)
_dl_lookup_map (Lmid_t nsid, const char *name)
{
int fd;
const char *origname = NULL;
char *realname;
char *name_copy;
struct link_map *l;
struct filebuf fb;
assert (nsid >= 0);
assert (nsid < GL(dl_nns));
/* Look for this name among those already loaded. */
for (l = GL(dl_ns)[nsid]._ns_loaded; l; l = l->l_next)
for (struct link_map *l = GL(dl_ns)[nsid]._ns_loaded; l; l = l->l_next)
{
/* If the requested name matches the soname of a loaded object,
use that object. Elide this check for names that have not
@@ -1933,6 +1923,22 @@ _dl_map_object (struct link_map *loader, const char *name,
return l;
}
return NULL;
}
/* Map in the shared object file NAME. */
struct link_map *
_dl_map_new_object (struct link_map *loader, const char *name,
int type, int trace_mode, int mode, Lmid_t nsid)
{
int fd;
const char *origname = NULL;
char *realname;
char *name_copy;
struct link_map *l;
struct filebuf fb;
/* Display information if we are debugging. */
if (__glibc_unlikely (GLRO(dl_debug_mask) & DL_DEBUG_FILES)
&& loader != NULL)
@@ -2183,6 +2189,17 @@ _dl_map_object (struct link_map *loader, const char *name,
type, mode, &stack_end, nsid);
}
struct link_map *
_dl_map_object (struct link_map *loader, const char *name,
int type, int trace_mode, int mode, Lmid_t nsid)
{
struct link_map *l = _dl_lookup_map (nsid, name);
if (l != NULL)
return l;
return _dl_map_new_object (loader, name, type, trace_mode, mode, nsid);
}
struct add_path_state
{
bool counting;