admin管理员组

文章数量:1568307

2024年3月27日发(作者:)

定位 init 或init_array函数

_Z17dvmLoadNativeCodePKcP6ObjectPPc

ThreadStatus oldStatus = dvmChangeStatus(self, THREAD_VMWAIT);

handle = dlopen(pathName, RTLD_LAZY);//此so没有被加载过,调用dlopen加

载此so

dvmChangeStatus(self, oldStatus);

dlopen函数源码:

void* dlopen(const char* filename, int flags) {

ScopedPthreadMutexLocker locker(&gDlMutex);

soinfo* result = do_dlopen(filename, flags);

if (result == NULL) {

__bionic_format_dlerror("dlopen failed", linker_get_error_buffer());

return NULL;

}

return result;

}

函数受限获取一个互斥量。这个互斥量用于保护动态链接库的链表。

2.调用do_dlopen函数完成do_dlopen函数完成正真so加载,初始化调用工作

do_dlopen函数源码:

soinfo* do_dlopen(const char* name, int flags) {

if ((flags & ~(RTLD_NOW|RTLD_LAZY|RTLD_LOCAL|RTLD_GLOBAL)) != {

本文标签: 函数互斥加载调用脱壳