Removed dlsym handle != NULL check for lp64
* Removed unnecessary NULL check in dlsym * Fixed dlsym_failure test to account for correct RTLD_DEFAULT value * Added temporary check for legacy RTLD_DEFAULT value for non-yet-recompiled binaries Bug: 15146875 Change-Id: I089fa673762629f5724b6e4fbca019d9cfc39905
This commit is contained in:
parent
3d4a7b02cc
commit
ca1c80220e
@ -89,10 +89,13 @@ void* dlopen(const char* filename, int flags) {
|
||||
void* dlsym(void* handle, const char* symbol) {
|
||||
ScopedPthreadMutexLocker locker(&g_dl_mutex);
|
||||
|
||||
#if !defined(__LP64__)
|
||||
if (handle == NULL) {
|
||||
__bionic_format_dlerror("dlsym library handle is null", NULL);
|
||||
return NULL;
|
||||
}
|
||||
#endif
|
||||
|
||||
if (symbol == NULL) {
|
||||
__bionic_format_dlerror("dlsym symbol name is null", NULL);
|
||||
return NULL;
|
||||
@ -100,9 +103,9 @@ void* dlsym(void* handle, const char* symbol) {
|
||||
|
||||
soinfo* found = NULL;
|
||||
ElfW(Sym)* sym = NULL;
|
||||
if (handle == RTLD_DEFAULT) {
|
||||
if (handle == RTLD_DEFAULT || handle == (void*)0xffffffffL) {
|
||||
sym = dlsym_linear_lookup(symbol, &found, NULL);
|
||||
} else if (handle == RTLD_NEXT || handle == (void*)0xffffffffL) {
|
||||
} else if (handle == RTLD_NEXT || handle == (void*)0xfffffffeL) {
|
||||
void* caller_addr = __builtin_return_address(0);
|
||||
soinfo* si = find_containing_library(caller_addr);
|
||||
|
||||
|
@ -101,6 +101,8 @@ TEST(dlfcn, dlsym_failures) {
|
||||
|
||||
void* sym;
|
||||
|
||||
// lp64 RTLD_DEFAULT=(void*)0
|
||||
#if !defined(__LP64__)
|
||||
// NULL handle.
|
||||
sym = dlsym(NULL, "test");
|
||||
ASSERT_TRUE(sym == NULL);
|
||||
@ -109,6 +111,7 @@ TEST(dlfcn, dlsym_failures) {
|
||||
#else
|
||||
ASSERT_SUBSTR("undefined symbol: test", dlerror()); // glibc isn't specific about the failure.
|
||||
#endif
|
||||
#endif // !defined(__LP64__)
|
||||
|
||||
// NULL symbol name.
|
||||
#if defined(__BIONIC__)
|
||||
|
Loading…
x
Reference in New Issue
Block a user