我无法让objcopy --rename-sym
工作。
在一个新的Android项目中,我创建了目录jni和文件stub.c:
#include <jni.h>
#include "dlog.h"
jint JNI_OnLoad(JavaVM* vm, void* reserved) {
DLOG("~~~~~~~~~~~~~~~~~~~~~~~ JNI_OnLoad ~~~~~~~~~~~~~~~~~~~~~~~~~");
return JNI_VERSION_1_6;
}
int myfunc() { return 0; }
命令~/an/ndk-build -j 4
说:
[armeabi-v7a] Install : libTest.so => libs/armeabi-v7a/libTest.so
[armeabi] Install : libTest.so => libs/armeabi/libTest.so
[x86] Install : libTest.so => libs/x86/libTest.so
[mips] Install : libTest.so => libs/mips/libTest.so
(有链接:
an -> ~/android-ndk-r9d/
ax -> android-ndk-r9d/toolchains/arm-linux-androideabi-4.8/prebuilt/linux-x86/bin/
ay -> ~/android-ndk-r9d/toolchains/arm-linux-androideabi-4.6/prebuilt/linux-x86/bin/
)
然后我做
~/ax/arm-linux-androideabi-objcopy --redefine-sym myfunc=ourfunc libTest.so libTest-x.so
并获得相同的 libTest-x.so。当然,我尝试了~/ay/*objcopy
,结果相同。
我没有收到任何错误消息。并且 myfunc()仍然存在,并且没有 ourfunc()。
如何在.so文件中重命名某个功能?
答案 0 :(得分:1)
重命名函数的最简单方法是在不更改长度且不更改哈希值的情况下更改名称。
保持相同的哈希值有点棘手,您必须了解elf_hash()
的工作原理::
elfhash.c:
#include <stdio.h>
unsigned long
elf_hash(const unsigned char *name)
{
unsigned long h = 0 , g ;
while (*name)
{
h = ( h << 4 ) + * name ++ ;
if (g = h & 0xf0000000) {
h ^= g >> 24 ;
}
h &= ~g ;
}
return h ;
}
int main(int argc, char**argv) {
char* name = argv[1];
printf("[%s]\n",name);
unsigned long hash = elf_hash(name);
printf("0x%lx\n",hash);
return 0;
}
[[编辑:较新版本为https://github.com/18446744073709551615/reDroid/blob/master/hosttools/elfhash.c
(它找到一个具有相同哈希值的名称)
]]
gcc
它,用法是:
$ ./a.out myFunc
[myFunc]
0x74ddc43
$ ./a.out myFums
[myFums]
0x74ddc43
$ ./a.out myFuoC # Note: a different hash value
[myFuoC]
0x74ddc33
$ ./a.out myFupC
[myFupC]
0x74ddc43
ASCII表的相关部分是:
! " # $ % & ' ( ) * + , - . /
0 1 2 3 4 5 6 7 8 9 : ; < = > ?
@ A B C D E F G H I J K L M N O
P Q R S T U V W X Y Z [ \ ] ^ _
` a b c d e f g h i j k l m n o
p q r s t u v w x y z { | } ~
然后
sed s/myFunc/myFums/g <libStuff.so >libStufx.so
或通过hexedit libStuff.so
进行手动替换。