最近看了一些安卓中ELF文件的资料,总结了一下几点,可能有些地方不太准确,只是一点个人总结而已。
安卓中ELF文件与linux中ELF文件的几个不同点:
1、在linux中和符号相关的表有:动态链接符号表、符号表、重定位表。
在安卓中只有一个字符串表(.dynstr)、一个符号表(.dynsym)。
2、在linux中.got表和.got.plt表是分开的。
在安卓中与之相对应的是只有一个.got表
3、在安卓中rel.plt对应函数重定位,类型是 R_ARM_JUMP_SLOT;rel.dyn对应数据的重定位,类型是R_ARM_GLOB_DAT。
4、安卓在加载动态共享库(.so文件)后运行程序前重定位已经进行完,没有PLT过程。
在linux中有PLT过程。
5、获得全局符号表的句柄的方法:dlopen(filename,flag),当filename=0时函数返回的是全局符号表的句柄。