From b2140451129070b2f0144914a9945cd43d4fe631 Mon Sep 17 00:00:00 2001 From: midipix Date: Mon, 18 Mar 2024 04:58:28 +0000 Subject: lt_dlpathopen_locked(): bypass path-based search when module path is absolute. --- src/core/lt_path.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) (limited to 'src') diff --git a/src/core/lt_path.c b/src/core/lt_path.c index 76c465b..d3f7ec1 100644 --- a/src/core/lt_path.c +++ b/src/core/lt_path.c @@ -291,6 +291,21 @@ static int lt_dlpathopen_locked( memcpy(path,module,mlen); + if (path[0] == '/') { + if ((fdmod = open(path,SLTDL_MODULE_OPEN_OPTIONS,0)) >= 0) { + if (mpath) { + if (!(*mpath = realpath(path,0))) { + close(fdmod); + return lt_setstatus(-1,SLTDL_SYSTEM_ERROR); + } + } + + return lt_setstatus(fdmod,SLTDL_OK); + } + + return lt_setstatus(-1,SLTDL_PATH_NO_ENTRY); + } + for (ppath=lt_pathv; ppath && *ppath; ppath++) { fdat = open(*ppath,O_RDONLY|O_DIRECTORY|O_CLOEXEC,0); -- cgit v1.2.3