diff options
| -rw-r--r-- | ldso/ldso/dl-elf.c | 11 | ||||
| -rw-r--r-- | ldso/ldso/readelflib1.c | 11 | 
2 files changed, 10 insertions, 12 deletions
| diff --git a/ldso/ldso/dl-elf.c b/ldso/ldso/dl-elf.c index 032c59607..2dad09d6d 100644 --- a/ldso/ldso/dl-elf.c +++ b/ldso/ldso/dl-elf.c @@ -223,9 +223,8 @@ struct elf_resolve *_dl_load_shared_library(int secure, struct dyn_elf **rpnt,  	const char *pnt, *pnt1;  	struct elf_resolve *tpnt1;  	const char *libname; -	const char libc6[] = "libc.so.6"; -	const char libc5[] = "libc.so.5"; -	const char aborted_wrong_lib[] = "%s: aborted attempt to load %s!\n"; +	static const char libc[] = "libc.so."; +	static const char aborted_wrong_lib[] = "%s: aborted attempt to load %s!\n";  	_dl_internal_error_number = 0;  	libname = full_libname; @@ -251,11 +250,11 @@ struct elf_resolve *_dl_load_shared_library(int secure, struct dyn_elf **rpnt,  	/* Make sure they are not trying to load the wrong C library!  	 * This sometimes happens esp with shared libraries when the  	 * library path is somehow wrong! */ -	if ((pnt1 = libc6, (_dl_strcmp(libname, pnt1) == 0)) ||  -			(pnt1 = libc5, (_dl_strcmp(libname, pnt1) == 0))) +	if ((_dl_strcmp(libname, libc) == 0) &&  +			( libname[8]=='6' || libname[8]=='5'))  	{  		if (!_dl_trace_loaded_objects) { -			_dl_dprintf(2, aborted_wrong_lib, pnt1, _dl_progname); +			_dl_dprintf(2, aborted_wrong_lib, libname, _dl_progname);  		}  		return NULL;  	} diff --git a/ldso/ldso/readelflib1.c b/ldso/ldso/readelflib1.c index 032c59607..2dad09d6d 100644 --- a/ldso/ldso/readelflib1.c +++ b/ldso/ldso/readelflib1.c @@ -223,9 +223,8 @@ struct elf_resolve *_dl_load_shared_library(int secure, struct dyn_elf **rpnt,  	const char *pnt, *pnt1;  	struct elf_resolve *tpnt1;  	const char *libname; -	const char libc6[] = "libc.so.6"; -	const char libc5[] = "libc.so.5"; -	const char aborted_wrong_lib[] = "%s: aborted attempt to load %s!\n"; +	static const char libc[] = "libc.so."; +	static const char aborted_wrong_lib[] = "%s: aborted attempt to load %s!\n";  	_dl_internal_error_number = 0;  	libname = full_libname; @@ -251,11 +250,11 @@ struct elf_resolve *_dl_load_shared_library(int secure, struct dyn_elf **rpnt,  	/* Make sure they are not trying to load the wrong C library!  	 * This sometimes happens esp with shared libraries when the  	 * library path is somehow wrong! */ -	if ((pnt1 = libc6, (_dl_strcmp(libname, pnt1) == 0)) ||  -			(pnt1 = libc5, (_dl_strcmp(libname, pnt1) == 0))) +	if ((_dl_strcmp(libname, libc) == 0) &&  +			( libname[8]=='6' || libname[8]=='5'))  	{  		if (!_dl_trace_loaded_objects) { -			_dl_dprintf(2, aborted_wrong_lib, pnt1, _dl_progname); +			_dl_dprintf(2, aborted_wrong_lib, libname, _dl_progname);  		}  		return NULL;  	} | 
