Android 7.0 dlopen的不同
在逆向分析某代码时,get到一处有点差异的地方。
开始觉得很奇怪,判断了dlopen返回值最后一位,若为1则知道版本7.0以后,查看源码分析后才知,7.0之后dlopen代码做了一些改动,而该判断是否为7.0前后版本依据为如下源码:
为什么要这样做呢,主要是7.0开始不再允许获取soinfo对象,贴一下大概流程以及依据:
6.0:
dlopen -> dlopen_ext:返回soinfo* result = do_dlopen(filename, flags, extinfo);
->do_dlopen:soinfo* si = find_library(name, flags, extinfo);return si;
7.0:
dlopen -> dlopen_ext:返回void* result = do_dlopen(filename, flags, extinfo, caller_addr);
->do_dlopen:
soinfo* si = find_library(ns, translated_name, flags, extinfo, caller);
return si->to_handle();
to_handle() -> 判断版本号,调用get_handle()
get_handle() -> 返回handle_
handle_ -> 定义在struct soinfo结构体中,类型为 uintptr_t.
handle为随机生成的一个hash值,指向soinfo存在了 g_soinfo_handles_map字典中。
PS:好像8.0又可以获取soinfo了….
转载请注明出处。
以上是 Android 7.0 dlopen的不同 的全部内容, 来源链接: utcz.com/a/69606.html